python mysql断开重连的实现方法


Posted in Python onJuly 26, 2019

后台服务在运行时发现一个问题,运行约15分钟后,接口请求报错

pymysql.err.InterfaceError: (0, '')

这个错误提示一般发生在将None赋给多个值,定位问题时发现

pymysql.err.OperationalError: (2013, 'Lost connection to MySQL server during query')

如何解决这个问题呢

出现问题的代码

class MysqlConnection(object):

	"""
	mysql操作类,对mysql数据库进行增删改查
	"""

	def __init__(self, config):
		# Connect to the database
		self.connection = pymysql.connect(**config)
		self.cursor = self.connection.cursor()

	def Query(self, sql):
		"""
		查询数据
		:param sql:
		:return:
		"""
		self.cursor.execute(sql)
		return self.cursor.fetchall()

在分析问题前,先看看Python 数据库的Connection、Cursor两大对象

Python 数据库图解流程

python mysql断开重连的实现方法

Connection、Cursor形象比喻

python mysql断开重连的实现方法

Connection()的参数列表

  • host,连接的数据库服务器主机名,默认为本地主机(localhost)
  • user,连接数据库的用户名,默认为当前用户
  • passwd,连接密码,没有默认值
  • db,连接的数据库名,没有默认值
  • conv,将文字映射到Python类型的字典
  • cursorclass,cursor()使用的种类,默认值为MySQLdb.cursors.Cursor
  • compress,启用协议压缩功能
  • named_pipe,在windows中,与一个命名管道相连接
  • init_command,一旦连接建立,就为数据库服务器指定一条语句来运行
  • read_default_file,使用指定的MySQL配置文件
  • read_default_group,读取的默认组
  • unix_socket,在unix中,连接使用的套接字,默认使用TCP
  • port,指定数据库服务器的连接端口,默认是3306

python mysql断开重连的实现方法

connection对象支持的方法

python mysql断开重连的实现方法

Cursor对象支持的方法

用于执行查询和获取结果

python mysql断开重连的实现方法

execute方法:执行SQL,将结果从数据库获取到客户端

python mysql断开重连的实现方法

调试代码,将超时时间设置较长

self.connection._write_timeout = 10000

发现并没有生效

使用try...except... 方法捕获失败后重新连接数据库

try:
	self.cursor.execute(sql)
except:
	self.connection()
	self.cursor.execute(sql)

直接抛出异常,并没有执行except代码段

打印self.connection ,输出如下:

<pymysql.connections.Connection object at 0x0000000003E2CCC0>

抛出异常重新connect是不行的,因为connections 仍存在未失效

找到一种方法可以解决问题,在每次连接之前,判断该链接是否有效,pymysql提供的接口是 Connection.ping()

这个该方法的源码

def ping(self, reconnect=True):
    """Check if the server is alive"""
    if self._sock is None:
      if reconnect:
        self.connect()
        reconnect = False
      else:
        raise err.Error("Already closed")
    try:
      self._execute_command(COMMAND.COM_PING, "")
      return self._read_ok_packet()
    except Exception:
      if reconnect:
        self.connect()
        return self.ping(False)
      else:
        raise

在每次请求数据库前执行如下代码

def reConnect(self):
	try:
		self.connection.ping()
	except:
		self.connection()

不过这样的方式虽然能解决问题,但是感觉相对较low,希望有更好的处理方法

目前已实现的数据库查询这部分的代码

import pymysql
class DBManager(object):

  def __init__(self,config):
    self.connection = pymysql.connect(**config) # config为数据库登录验证配置信息
    self.cursor = self.connection.cursor()

  def query(self, sql, params):
    try:
      with self.connection.cursor() as cursor:
        cursor.execute(sql, params)
        result = cursor.fetchall()
        self.connection.commit()
        return result
        # self.connection.close()
    except Exception as e:
      traceback.print_exc()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现把回车符\r\n转换成\n
Apr 23 Python
python获取当前日期和时间的方法
Apr 30 Python
Python3通过Luhn算法快速验证信用卡卡号的方法
May 14 Python
python十进制和二进制的转换方法(含浮点数)
Jul 07 Python
pandas中apply和transform方法的性能比较及区别介绍
Oct 30 Python
python+selenium 定位到元素,无法点击的解决方法
Jan 30 Python
对python_discover方法遍历所有执行的用例详解
Feb 13 Python
python覆盖写入,追加写入的实例
Jun 26 Python
解决Django 在ForeignKey中出现 non-nullable field错误的问题
Aug 06 Python
python GUI库图形界面开发之PyQt5切换按钮控件QPushButton详细使用方法与实例
Feb 28 Python
python如何实现DES加密
Sep 21 Python
OpenCV实现机器人对物体进行移动跟随的方法实例
Nov 09 Python
seek引发的python文件读写的问题及解决
Jul 26 #Python
python经典趣味24点游戏程序设计
Jul 26 #Python
对django后台admin下拉框进行过滤的实例
Jul 26 #Python
python函数的万能参数传参详解
Jul 26 #Python
Python企业编码生成系统之主程序模块设计详解
Jul 26 #Python
Django REST Framework序列化外键获取外键的值方法
Jul 26 #Python
django admin.py 外键,反向查询的实例
Jul 26 #Python
You might like
PHP输出数组中重名的元素的几种处理方法
2012/09/05 PHP
jQuery+php实现ajax文件即时上传的详解
2013/06/17 PHP
日常整理PHP中简单的图形处理(经典)
2015/10/26 PHP
对php 判断http还是https,以及获得当前url的方法详解
2019/01/15 PHP
jquery 选择器部分整理
2009/10/28 Javascript
juqery 学习之五 文档处理 包裹、替换、删除、复制
2011/02/11 Javascript
通过js动态操作table(新增,删除相关列信息)
2012/05/23 Javascript
用js获取电脑信息(是使用与IE浏览器)
2013/01/15 Javascript
Thinkphp模板没有解析直接原样输出的解决方法
2014/10/31 Javascript
js在指定位置增加节点函数insertBefore()用法实例
2015/01/12 Javascript
DEDECMS如何为文章添加HOT NEW标志图片
2015/08/14 Javascript
jQuery配合coin-slider插件制作幻灯片效果的流程解析
2016/05/13 Javascript
JavaScript实现通过select标签跳转网页的方法
2016/09/29 Javascript
使用JavaScript获取URL中的参数(两种方法)
2016/11/16 Javascript
vue.js语法及常用指令
2017/10/29 Javascript
解决Vue+Electron下Vuex的Dispatch没有效果问题
2019/05/20 Javascript
VUE安装使用教程详解
2019/06/03 Javascript
vue+element-ui JYAdmin后台管理系统模板解析
2020/07/28 Javascript
python基于右递归解决八皇后问题的方法
2015/05/25 Python
举例详解Python中threading模块的几个常用方法
2015/06/18 Python
Python的组合模式与责任链模式编程示例
2016/02/02 Python
Python中列表元素转为数字的方法分析
2016/06/14 Python
pycharm安装图文教程
2017/05/02 Python
Python cookbook(数据结构与算法)实现优先级队列的方法示例
2018/02/18 Python
利用python如何处理百万条数据(适用java新手)
2018/06/06 Python
python实现爬山算法的思路详解
2019/04/09 Python
Python通过类的组合模拟街道红绿灯
2020/09/16 Python
如何用PyPy让你的Python代码运行得更快
2020/12/02 Python
雅诗兰黛旗下走天然植物路线的彩妆品牌:Prescriptives
2016/08/14 全球购物
Wedgwood美国官网:英国骨瓷,精美礼品及家居装饰
2018/02/17 全球购物
程序运行正确, 但退出时却"core dump"了,怎么回事
2014/02/19 面试题
C#面试题
2016/05/06 面试题
大专毕业自我鉴定
2014/02/04 职场文书
使用pd.merge表连接出现多余行的问题解决
2022/06/16 Python
Win11怎么添加用户?Win11添加用户账户的方法
2022/07/15 数码科技
SpringBoot详解自定义Stater的应用
2022/07/15 Java/Android