成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

解決mysql服務器在無操作超時主動斷開連接的情況

瀏覽:3日期:2023-10-13 16:25:19

我們在使用mysql服務的時候,正常情況下,mysql的設置的timeout是8個小時(28800秒),也就是說,如果一個連接8個小時都沒有操作,那么mysql會主動的斷開連接,當這個連接再次嘗試查詢的時候就會報個”MySQL server has gone away”的誤,但是有時候,由于mysql服務器那邊做了一些設置,很多情況下會縮短這個連接timeout時長以保證更多的連接可用。有時候設置得比較變態,很短,30秒,這樣就需要客戶端這邊做一些操作來保證不要讓mysql主動來斷開。

查看mysql的timeout

使用客戶端工具或者Mysql命令行工具輸入show global variables like ’%timeout%’;就會顯示與timeout相關的屬性,這里我用docker模擬了一個測試環境。

mysql> show variables like ’%timeout%’; +-----------------------------+----------+| Variable_name| Value |+-----------------------------+----------+| connect_timeout | 10 || delayed_insert_timeout | 300 || have_statement_timeout | YES || innodb_flush_log_at_timeout | 1 || innodb_lock_wait_timeout | 50 || innodb_rollback_on_timeout | OFF || interactive_timeout | 30 || lock_wait_timeout | 31536000 || net_read_timeout | 30 || net_write_timeout | 60 || rpl_stop_slave_timeout | 31536000 || slave_net_timeout | 60 || wait_timeout| 30 |+-----------------------------+----------+13 rows in set

wait_timeout:服務器關閉非交互連接之前等待活動的秒數,就是你在你的項目中進行程序調用

interactive_timeout: 服務器關閉交互式連接前等待活動的秒數,就是你在你的本機上打開mysql的客戶端,cmd的那種

使用pymysql進行查詢

我在數據庫里隨便創建了一個表,插入兩條數據

mysql> select * from person;+----+------+-----+| id | name | age |+----+------+-----+| 1 | yang | 18 || 2 | fan | 16 |+----+------+-----+2 rows in set

我使用pymysql這個庫對其進行查詢操作,很簡單

#coding:utf-8import pymysqldef mytest(): connection = pymysql.connect( host=’localhost’, port=3306, user=’root’, password=’123456’, db=’mytest’, charset=’utf8’) cursor = connection.cursor() cursor.execute('select * from person') data = cursor.fetchall() cursor.close() for i in data: print(i) cursor.close() connection.close()if __name__ == ’__main__’: mytest()

可以正確的得到結果

(1, ’yang’, 18)

(2, ’fan’, 16)

連接超時以后的查詢

上面可以正常得到結果是由于當創建好一個鏈接以后,就立刻進行了查詢,此時還沒有超過它的超時時間,如果我sleep一段時間,看看什么效果。

#coding:utf-8import pymysqlimport timedef mytest(): connection = pymysql.connect( host=’localhost’, port=3306, user=’root’, password=’123456’, db=’mytest’, charset=’utf8’) cursor = connection.cursor() cursor.execute('select * from person') data = cursor.fetchall() for i in data: print(i) cursor.close() time.sleep(31) cursor = connection.cursor() cursor.execute('select * from person') data2 = cursor.fetchall() for i in data2: print(i) cursor.close() connection.close()if __name__ == ’__main__’: mytest()

這里進行了兩次查詢,因為我把mysql的wait_timeout設置了30秒,所以我在第一次查詢之后停了31秒,目的讓mysql服務主動的和我剛才創建的連接斷開,得到的結果是

(1, ’yang’, 18)(2, ’fan’, 16)Traceback (most recent call last): File 'F:/python/python3Test/mysqltest.py', line 29, in <module> mytest() File 'F:/python/python3Test/mysqltest.py', line 22, in mytest cursor.execute('select * from person') ... ... File 'C:Python35libsite-packagespymysqlconnections.py', line 702, in _read_bytes CR.CR_SERVER_LOST, 'Lost connection to MySQL server during query')pymysql.err.OperationalError: (2013, ’Lost connection to MySQL server during query’)Process finished with exit code 1

可以看到在停了31秒鐘以后,再次使用該連接進行查詢將拋出2013, ’Lost connection to MySQL server during query’錯誤。

解決辦法

解決的方法有兩種,既然這里的超時是由于在規定時間內沒有任何操作導致mysql主動的將鏈接關閉,pymysql的connection對象有一個ping()方法,可以檢查連接是否有效,在每次執行查詢操作之前先執行一下ping()方法,該方法默認的有個reconnect參數,默認是True,如果失去連接了會重連。

#coding:utf-8import pymysqlimport timedef mytest(): connection = pymysql.connect( host=’localhost’, port=3306, user=’root’, password=’123456’, db=’mytest’, charset=’utf8’) connection.ping() cursor = connection.cursor() cursor.execute('select * from person') data = cursor.fetchall() for i in data: print(i) cursor.close() time.sleep(31) connection.ping() cursor = connection.cursor() cursor.execute('select * from person') data2 = cursor.fetchall() for i in data2: print(i) cursor.close() connection.close()if __name__ == ’__main__’: mytest()

我曾嘗試使用另外一個線程不停來執行ping()操作,但是當我這樣做以后連接就會丟失,之后的操作就不能進行了。這個問題我再研究研究。

#coding:utf-8import pymysqlimport timeimport threadingimport tracebackdef ping(conn): while True: try: conn.ping() except: print(traceback.format_exc()) finally: time.sleep(1)def mytest(): connection = pymysql.connect( host=’localhost’, port=3306, user=’root’, password=’123456’, db=’mytest’, charset=’utf8’) cursor = connection.cursor() # 放在此處不行,必須等待cursor的一個execute之后再運行才可以 # th = threading.Thread(target=ping, args=(connection,)) # th.setDaemon(True) # th.start() cursor.execute('select * from person') data = cursor.fetchall() for i in data: print(i) cursor.close() # 線程放在此處啟動可以 th = threading.Thread(target=ping, args=(connection,)) th.setDaemon(True) th.start() time.sleep(31) cursor = connection.cursor() cursor.execute('select * from person') data2 = cursor.fetchall() for i in data2: print(i) cursor.close() connection.close()if __name__ == ’__main__’: mytest()

還有一種方法是使用連接池,連接池中保持著指定數量的可用連接,每次重新獲取一個有效的連接進行查詢操作,pymysql本身不具有連接池功能,需要借住DBUtils

#coding:utf-8import pymysqlimport timefrom DBUtils.PooledDB import PooledDB, SharedDBConnectiondef mytest(): pool = PooledDB( creator=pymysql, # 初始化時,連接池至少創建的空閑連接,0表示不創建 maxconnections=3, # 連接池中空閑的最多連接數,0和None表示沒有限制mincached=2, # 連接池中最多共享的連接數量,0和None表示全部共享(其實沒什么卵用) maxcached=5,maxshared=3, host=’localhost’, port=3306, user=’root’, password=’123456’, db=’mytest’, charset=’utf8’ ) connection = pool.connection() cursor = connection.cursor() cursor.execute('select * from person') data = cursor.fetchall() for i in data: print(i) time.sleep(40) cursor.execute('select * from person') data2 = cursor.fetchall() for i in data2: print(i) cursor.close() connection.close()if __name__ == ’__main__’: mytest()

這種方式雖然可以正確的獲取結果,但是實際的項目中并不會這么使用,而是在執行完查詢語句以后要將connection關閉,注意這里的關閉并不是真正的關閉,而只是將連接返回給連接池讓其它人使用.

#coding:utf-8import pymysqlimport timefrom DBUtils.PooledDB import PooledDB, SharedDBConnectiondef mytest(): pool = PooledDB( creator=pymysql, maxconnections=3, # 初始化時,連接池至少創建的空閑連接,0表示不創建 mincached=2, # 連接池中空閑的最多連接數,0和None表示沒有限制 maxcached=5, # 連接池中最多共享的連接數量,0和None表示全部共享(其實沒什么卵用) maxshared=3, host=’localhost’, port=3306, user=’root’, password=’123456’, db=’mytest’, charset=’utf8’ ) connection = pool.connection() cursor = connection.cursor() cursor.execute('select * from person') data = cursor.fetchall() for i in data: print(i) cursor.close() # 關閉連接,其實并沒有真正關閉,只是將連接返回給連接池 connection.close() time.sleep(40) connection = pool.connection() cursor = connection.cursor() cursor.execute('select * from person') data2 = cursor.fetchall() for i in data2: print(i) cursor.close() connection.close()if __name__ == ’__main__’: mytest()

以上這篇解決mysql服務器在無操作超時主動斷開連接的情況就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: MySQL 數據庫
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产精品久久久久毛片软件| 在线看不卡av| 亚洲综合免费观看高清完整版在线| 亚洲图片你懂的| 亚洲午夜久久久久久久久久久| 伊人夜夜躁av伊人久久| 亚洲国产成人精品视频| 色综合欧美在线视频区| 欧美特黄一级| 亚洲精品韩国| 色婷婷综合久久久中文字幕| 欧美另类z0zxhd电影| 日韩欧美二区三区| 国产日本亚洲高清| 一区二区三区成人| 久久狠狠亚洲综合| 国产伦精品一区二区三区免费| av一区二区三区| 亚洲激情网址| 国产婷婷色一区二区三区在线| 一区二区在线观看免费| 色综合天天综合色综合av | 美女视频黄 久久| 国产suv精品一区二区6| 欧美日韩喷水| 精品国产免费一区二区三区四区| 亚洲国产高清aⅴ视频| 亚洲国产日日夜夜| 亚洲一区免费| 久久综合九色综合97_久久久| 日本三级亚洲精品| 成人免费黄色大片| 久久青青草原一区二区| 精品乱码亚洲一区二区不卡| 天天综合天天做天天综合| 9l国产精品久久久久麻豆| 精品国产乱码久久久久久久久 | 欧洲一区二区三区在线| 琪琪一区二区三区| 国产在线精品二区| 欧美日韩成人激情| 亚洲伦理在线精品| 99久久综合色| 久久精品人人爽人人爽| 99国产精品久| 久久综合一区| 天天色图综合网| 色呦呦一区二区三区| 久久九九久久九九| 欧美呦呦网站| 老色鬼久久亚洲一区二区| 亚洲女同一区二区| 免费av成人在线| 日本韩国欧美一区| 国产日韩欧美一区二区三区综合| 国产黄色91视频| 激情视频一区二区| 国产精品区一区| 91精品国产综合久久精品性色| 国产精品第四页| 日韩精彩视频在线观看| 99re热这里只有精品免费视频| 欧美成人一区二区| 成人午夜激情在线| 欧美一卡二卡在线| 亚洲免费色视频| 亚洲免费播放| 欧美丰满少妇xxxxx高潮对白| 蜜桃视频在线观看一区二区| 在线精品视频一区二区三四| 日本欧美在线观看| 在线视频国产一区| 亚洲午夜精品网| 欧美精选一区二区| 国产盗摄一区二区| 日韩精品一区在线| 97精品视频在线观看自产线路二| 久久青草国产手机看片福利盒子| 亚洲成国产人片在线观看| 香蕉精品999视频一区二区 | 久久久久久久国产精品影院| 99综合电影在线视频| 久久综合网色—综合色88| 不卡视频在线观看| 久久久99爱| 中文欧美字幕免费| 久久www免费人成看片高清| 在线精品视频免费观看| 老司机精品视频导航| 在线播放中文字幕一区| 丁香婷婷深情五月亚洲| 久久综合狠狠综合久久综合88| 91丨九色丨蝌蚪富婆spa| 欧美高清在线精品一区| 国产精品初高中精品久久 | 久久国产99| 日韩av中文字幕一区二区三区 | 久久久精品影视| 国产一区二区三区四区三区四| 国产精品日日摸夜夜摸av| 午夜视频一区| 亚洲丝袜美腿综合| 久久九九电影| 国产成人免费视频精品含羞草妖精 | 成人理论电影网| 久久久国产精品麻豆| 国产精品久久7| 久久国产人妖系列| 精品国产三级电影在线观看| 国内成人在线| 亚洲成人av一区二区三区| 欧美性一级生活| 岛国av在线一区| 国产精品灌醉下药二区| 久久精品国产清高在天天线| 狠狠色狠狠色合久久伊人| 精品久久人人做人人爰| 亚洲午夜精品久久久久久app| 亚洲在线观看免费视频| 欧美色欧美亚洲另类二区| 综合久久久久综合| a91a精品视频在线观看| 久久国产精品一区二区| 精品成人一区二区三区| 久久久久欧美| 国产乱码精品一区二区三区五月婷| 久久久亚洲综合| 亚洲性图久久| 免费日本视频一区| 精品国内二区三区| 中文精品一区二区三区| 美女一区二区在线观看| 久久影院视频免费| 国产一区二区久久久| 国产一区二区三区在线观看免费视频 | 亚洲午夜高清视频| 亚洲bt欧美bt精品777| 日韩欧美中文一区| 日韩午夜激情| 国产99一区视频免费| 欧美国产激情一区二区三区蜜月| 久久一区亚洲| 99re亚洲国产精品| 亚洲线精品一区二区三区| 欧美三级视频在线| 91老师片黄在线观看| 亚洲6080在线| 精品国产乱码久久久久久闺蜜 | 国内久久精品视频| 亚洲午夜三级在线| 精品久久久久久久人人人人传媒| 亚洲精品在线视频观看| 国产成人精品免费看| 一区二区成人在线| 精品福利av导航| 色激情天天射综合网| 亚洲欧美伊人| 久久国产欧美日韩精品| 中文字幕一区免费在线观看| 在线亚洲人成电影网站色www| 欧美影院一区| 成人性生交大片免费看在线播放| 一二三区精品福利视频| 日韩欧美国产一区二区在线播放| 国产精品一区二区三区免费观看| hitomi一区二区三区精品| 日本不卡视频在线| 国产精品成人网| 欧美一区二区高清| 国产精品亚洲综合| 91论坛在线播放| 极品美女销魂一区二区三区 | 国产一区二区三区香蕉| 亚洲国产欧美在线| 久久精品视频在线免费观看 | 国产aⅴ综合色| 欧美aaaaa成人免费观看视频| 一区二区中文字幕在线| 欧美成人精品3d动漫h| 欧美在线视频你懂得| 亚洲精品少妇| 91在线观看一区二区| 亚洲国产视频在线| 久久久久久久综合色一本| 欧美三区在线视频| 在线一区日本视频| 亚洲精品无人区| 欧洲生活片亚洲生活在线观看| 在线看片欧美| 黄色精品网站| 成人不卡免费av| 美女爽到高潮91| 亚洲大片在线观看| 中文字幕五月欧美| 欧美成人激情免费网| 欧洲在线/亚洲| 久久精品30| 国产专区一区| av电影在线观看一区| 老司机精品视频导航|