免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2990 | 回复: 0
打印 上一主题 下一主题

python MySQLdb 长时间idle connection timeout, ping() [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-23 02:28 |只看该作者 |倒序浏览
By default, MySQL-5.0 does not automatically reconnect. 

mysql连接如果长时间idle的话,(时间:默认为8小时),会自动断开,而且不会为原连接自动恢复。 

在python中,如果应用程序某个模块使用了持久化的db链接,则失效后,继续使用,会报错: 2006,MySQL server has gone away 

解决办法: 比较ugly 

在每次连接之前,判断该链接是否有效。 MySQLdb提供的接口是 Connection.ping(), 
(奇怪,ping() 这个方法在 MySQLdb 的文档中居然没有文档化, 害我找了好久) 

采用 类似: 
try: 
   conn.ping() 
except Excption,e:      #实际对应的  MySQLdb.OperationalError 这个异常 
   conn = new conn 

的方法解决 

为了测试出 ping()的效果, 
我在代码中先关闭了 conn, 示意如下: 

try: 
   conn.close() 
   conn.ping() 
except Excption,e:      #实际对应的  MySQLdb.OperationalError 这个异常 
   print e 
   conn = new conn 

结果爆出了另外一个错误: 
InterfaceError: (0, '') 

google了一大圈都没找到正确原因,一度还以为是: 
  File "/usr/lib/pymodules/python2.6/MySQLdb/cursors.py", line 147, in execute charset = db.character_set_name() 
的问题, (因为错误的traceback 指向了此处...) 

实际上: 对任何已经close的conn进行 db相关 操作,包括ping()都会爆出这个错误。 
(这说明 长时间idle导致的conn失效与 conn.close()之后的状态是不一样的)
精确catch 这个错误的Exception 是   MySQLdb.Error 。 

关于此错误详细的解释帖子: 
http://sourceforge.net/projects/mysql-python/forums/forum/70461/topic/1536427 



因此:处理长时间idle问题,正常使用ping(),并且明确的创建一个新的连接即可。

贴上我的代码
def executeSQL(self,sql=""):
        try:
            self.conn.ping()
        except Exception,e:
            self.log.error("Msql出了问题")
            self.log.error(str(e))
            while True:
                try:
                    self.conn = MySQLdb.connect(self.config.get('mysql_server'),self.config.get('mysql_user'),self.config.get('mysql_pass'),self.config.get('mysql_db_name'),connect_timeout=60,compress=True,charset="UTF8")
                    break
                except Exception,e:
                    self.log.error("尝试重连接失败")
                    time.sleep(2)
                    continue
            self.cursor=self.conn.cursor()
        try:
            self.cursor.execute(sql)
            self.conn.commit()
            return 1
        except Exception,e:
            self.log.error(str(e))
            return 0
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP