Python与MySQL如何保持长连接
介绍
在python后端开发中,时常会与数据库交互,重复的断开、连接 会大大消耗数据库资源。
所以一般都是定义全局变量,来弥补这个缺陷。
但是 Python 与Mysql 长连接的过程中,如果长时间没有交互,它是会断开的。
再次执行sql语句是就会报错。
解决方案
在执行sql前, ping一下连接是否正常。
如果正常,则不受影响,正常执行sql就行了;
如果异常,则需要重新连接数据库。
代码
1 # 此处为类中方法,相关参数也配置在了settings文件中
2 def test_conn(self):
3 try:
4 self.conn.ping()
5 except:
6 self.conn = pymysql.connect(
7 host=MYSQL_HOST,
8 user=MYSQL_USER,
9 password=MYSQL_PASSWORD,
10 database=MYSQL_DATABASE,
11 charset=MYSQL_CHARSET)
12 self.cursor = self.conn.cursor()
只需要在每次将执行sql前,调用一下这个方法即可。