[英]Python mysqldb error closing connection
关闭连接时出现问题,如下所示:
database = 'sed_database'
conn = MySQLdb.Connect(host='remote_host', user='default',
passwd='pass', db=database)
try:
try:
cursor = conn.cursor()
cursor.execute(sql_str)
results = cursor.fetchall()
except MySQLdb.Error, e:
print "MySQL/Server Error using query: %s" % sql_str
print "Using database: %s" % database
raise e
finally:
if cursor:
cursor.close()
if conn:
conn.close()
这给出:
Traceback (most recent call last):
File "trass.py", line 579, in ?
main(sys.argv)
File "trass.py", line 555, in main
old_rows, changes_list = auto_analyse_test(f, args.build, args.quiet, args.debug)
File "trass.py", line 352, in auto_analyse_test
last_analysed_build = get_sed_baseline_ref(test_file_name, old_delivery_stream)
File "trass.py", line 151, in get_sed_baseline_ref
results = execute_sql_query(sql, delivery_stream)
File "trass.py", line 197, in execute_sql_query
passwd='pass', db=database)
File "C:\Python24\Lib\site-packages\MySQLdb\__init__.py", line 75, in Connect
return Connection(*args, **kwargs)
File "C:\Python24\Lib\site-packages\MySQLdb\connections.py", line 164, in __init__
super(Connection, self).__init__(*args, **kwargs2)
_mysql_exceptions.InternalError: (3, "Error writing file 'D:\\MySQL_Datafiles\\Logfiles\\query.
log' (Errcode: 9)")
Python的MySQLDB库信息如下:
>>> print MySQLdb.get_client_info()
4.1.18
>>> print MySQLdb.__version__
1.2.1_p2
>>> print MySQLdb.__revision__
410
奇怪的是:
服务器error.log中显示“连接中断...(读取通讯包时出错)”
虽然“回溯”似乎显示与连接创建相关的错误,但直到关闭连接(或函数结束,我猜默认情况下会关闭),该错误才会发生。 我尝试在打开和关闭之间放置额外的输出或暂停。 每当关闭时发生异常。 那么关闭连接时可能导致此错误的原因是什么?
这是我到目前为止发现的。
似乎在MySQLdb.Connect(...)
粘贴代码中的第二行MySQLdb.Connect(...)
打开连接时触发了错误,而不是在关闭连接时触发了错误。
完整回溯:
让我们解码异常
InternalError:
(3,
"Error writing file 'D:\\MySQL_Datafiles\\Logfiles\\query.log'
(Errcode: 9)")
EE_WRITE
3 ERROR_INVALID_BLOCK
”存储控制块地址无效。“ 相当神秘,但是它会去检查该文件是否存在,是否可写以及是否可能经过logrotate或类似操作。 检查磁盘空间,作为一项很好的措施,请同时进行磁盘检查。 它似乎是客户端错误。 请检查您的客户端my.cnf
[client]
部分。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.