关闭连接时遇到问题如下:
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显示“Aborted connection ...(读取通信数据包时出错)”
虽然Traceback似乎显示与连接创建相关的错误,但在连接关闭之前不会发生(或者函数结束,我猜默认关闭它)。我已经尝试在打开和关闭之间添加额外的输出或暂停。每次关闭时发生异常。那么什么可能导致关闭连接时出现此错误?
答案 0 :(得分:3)
这是我到目前为止所发现的。
在粘贴代码的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]
部分。