亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解決MySQL server has gone away錯誤的方案

 更新時間:2020年11月15日 21:51:29   作者:陽光下的幸福  
在本篇文章里小編給大家分享的是一篇關于MySQL server has gone away錯誤的解決辦法,有需要的朋友們可以參考下。

PHP中MySQL server has gone away問題

一.背景

之前在Codeigniter里面寫過類似console命令行的腳本. 腳本里存在sleep語句時間比較久, 導致出現(xiàn)一個現(xiàn)象就是sleep之前的SQL都是操作成功的,但是sleep之后,再執(zhí)行SQL操作竟然報錯: MySQL server has gone away. 也就是mysql的這個連接失效. 后來分析才知道, MySQL中存在2個重要的配置參數(shù):

interactive_timeout
wait_timeout

這2個參數(shù)的單位都是秒(s). 默認是8小時(28800). interactive_timeout從單詞上看指的是交互超時時間. mysql的連接方式一般分為2種, 一種稱之為"交互式", 一種稱為"非交互式". 一般常見的使用mysql -u root xxx之類的或者主從復制的連接為"交互式連接", 使用如Java的JDBC、PHP的PDO驅(qū)動連接的方式一般是"非交互式連接". 然而interactive_timeout如果未修改的情況下,這個值是一直不會變的,但是wait_timeout在不同連接方式下,值是不一樣的.

wait_timeout在"交互式連接"下, 其值是interactive_timeout的值. 如果在"非交互式連接"情況下, 則wait_timeout的值是原來mysql.cnf中配置的原始值.

最終起作用的只是wait_timeout的值.這配置項限定了處于sleep狀態(tài)(通過 show processlist查看當前連接數(shù)情況)的連接,如果這個連接sleep休眠時間超過wait_timeout的值,則這個連接被斷掉或者說被清理掉.

二.wait_timeout分析

1.首先查看mysql.conf配置

在這里插入圖片描述

首先我們配置了interactive_timeout=10 wait_timeout=5, 此時通過mysql客戶端(交互式連接)查看這2個配置項的值: show variables like ‘%timeout%';

2.交互式連接

客戶端的結(jié)果: wait_timeout竟然不是我們msyql.conf配置的10s, 而是 5s.

那我們再來看看PHP連接MySQL(非交互式連接),執(zhí)行相同的語句,得到什么結(jié)構:

3.非交互式連接

在這里插入圖片描述

在這里插入圖片描述

此時wait_timeout是我們原來在mysql.cnf配置的值了.

綜上所述: wait_timeout這個值,在不同的"連接模式"下面,拿到的值是不一樣的.

三.gone away原因分析

結(jié)合上面的情況,我們就知道了。 一開始某些SQL執(zhí)行成功,但是后面的SQL執(zhí)行失敗報錯gone away,大部分原因就是這個連接被閑置超過了wait_timeout,mysql服務器單方面斷掉了這個連接。但是客戶端代碼,還是在用這個連接變量,以為連接還是ok的(其實mysql server端已經(jīng)斷開了,只是我們以為這個連接還有效),去執(zhí)行SQL必然報錯.

那么我們怎么解決這個情況呢?

1.可以適當調(diào)整wait_timeout的值, 調(diào)大一點,這樣不容易觸發(fā)這個gone away情況.但是弊端就是,sleep的長連接不被清理,資源白白浪費了.

2.通過try-cach如果拋出gone way msyql的連接問題, 先把之前的db調(diào)用close().在重新獲取db連接open,然后再執(zhí)行之前的代碼. 不過代碼看起來感覺很蛋疼.偽代碼:

$db = db();

try {
   fun1$db); // 一開始執(zhí)行成功
   sleep(3600*10) // 假設sleep了10個小時
   fun2($db);   // 10小時之后 由于連接已經(jīng)被mysql干掉 導致報錯 gone away
}catch(Exception $e) {
  // 報錯后 我們把無效的連接close 在 open新的連接 
  $db->close();
  $db->open();
  // 再拿到新的連接執(zhí)行
  // fun2($db)  
}

3.如果是使用類似swoole或者easyswoole框架, 建議使用mysql pool連接池的形式.并且一般連接池都有關于心跳檢查ping、連接存活檢測間隔時間設置、最大閑置連接數(shù)等等設置, 只要配置一次就好了。 例如可以配置測活連接間隔時間短一點,來保證連接不會被msyql服務器干掉.例如 easyswoole配置:

在這里插入圖片描述

例如之前我設置wait_timeout=10, 但是如果我沒修改這個easyswoole的mysql連接池測活間隔時間變小, 同樣會出現(xiàn)gone way的情況. 第一次訪問接口成功返回SQL執(zhí)行結(jié)果,但是超過10s以后我再次訪問接口,報錯mysql has gone away。修改setIntervalCheckTime()之后,就不會出現(xiàn)這個問題了. 我們通過mysql的show processlist;查看連接數(shù)情況:

在這里插入圖片描述

這些都是easyswoole幫我們維護的連接數(shù). 當sleep超過3秒時, 由于檢查時間是3秒存活, 連接池幫我們?;顧z查, sleep的時間又從0開始計算.

下面是其他網(wǎng)友的補充

進入MySQL

cmd

mysql -u用戶名 -p密碼

在我們使用mysql導入大文件sql時可能會報MySQL server has gone away錯誤,該問題是max_allowed_packet配置的默認值設置太小,只需要相應調(diào)大該項的值之后再次導入便能成功。該項的作用是限制mysql服務端接收到的包的大小,因此如果導入的文件過大則可能會超過該項設置的值從而導致導入不成功!下面我們來看一下如何查看以及設置該項的值。

查看 max_allowed_packet 的值

show global variables like 'max_allowed_packet';
+--------------------+---------+
| Variable_name | Value |
+--------------------+---------+
| max_allowed_packet | 4194304 |
+--------------------+---------+

可以看到默認情況下該項的大小只有4M,接下來將該值設置成150M(1024*1024*150)

set global max_allowed_packet=157286400;

此時再查看大小

show global variables like 'max_allowed_packet';

通過調(diào)大該值,一般來說再次導入數(shù)據(jù)量大的sql應該就能成功了,如果任然報錯,則繼續(xù)再調(diào)大一些就行,請注意通過在命令行中進行設置只對當前有效,重啟mysql服務之后則恢復默認值,但可以通過修改配置文件(可以在配置文件my.cnf中添加max_allowed_packet=150M即可)來達到永久有效的目的,可其實我們并不是經(jīng)常有這種大量數(shù)據(jù)的導入操作,所以個人覺得通過命令行使得當前配置生效即可,沒有必要修改配置文件。

以上就是本次介紹的全部相關知識點內(nèi)容,希望腳本之家整理的內(nèi)容能夠幫助到你。

相關文章

  • Mysql執(zhí)行原理之索引合并步驟詳解

    Mysql執(zhí)行原理之索引合并步驟詳解

    這篇文章主要介紹了Mysql執(zhí)行原理之索引合并詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • mysql日志滾動

    mysql日志滾動

    日志滾動解決日志文件過大問題,比如我開啟了general_log,這個日志呢是記錄mysql服務器上面所運行的所有sql語句;比如我開啟了mysql的慢查詢
    2014-01-01
  • mysql添加索引和不添加索引的區(qū)別及說明

    mysql添加索引和不添加索引的區(qū)別及說明

    這篇文章主要介紹了mysql添加索引和不添加索引的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 深入理解MySQL公共表表達式

    深入理解MySQL公共表表達式

    公用表達式是MySQL8.0的新特性,它是一個命名的臨時結(jié)果集,作用范圍是當前語句,本文主要介紹了MySQL公共表表達式使用,感興趣的可以了解一下
    2024-09-09
  • 深入了解mysql的4種常用、重要的數(shù)據(jù)類型

    深入了解mysql的4種常用、重要的數(shù)據(jù)類型

    對于在開發(fā)大型電子商務網(wǎng)站時,如果碰到有限的硬件和系統(tǒng)環(huán)境情況下,合理的數(shù)據(jù)庫表結(jié)構的設計是必不可少的
    2014-05-05
  • MySQL中的TRUNCATE TABLE命令的使用

    MySQL中的TRUNCATE TABLE命令的使用

    TRUNCATE TABLE命令是一個用于快速刪除表中所有數(shù)據(jù)的重要工具,本文介紹了MySQL中的TRUNCATE TABLE命令的用法、工作原理以及實際應用中的注意事項,感興趣的可以了解一下
    2024-08-08
  • MySQL索引優(yōu)化之分頁探索詳細介紹

    MySQL索引優(yōu)化之分頁探索詳細介紹

    大家好,本篇文章主要講的是MySQL索引優(yōu)化之分頁探索詳細介紹,感興趣的同學趕快來看看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • 徹底搞懂MySQL存儲過程和函數(shù)

    徹底搞懂MySQL存儲過程和函數(shù)

    我們大家都知道MySQL 存儲過程是從 MySQL 5.0 開始逐漸增加新的功能,下面這篇文章主要給大家介紹了關于MySQL存儲過程和函數(shù)的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • 數(shù)據(jù)庫查詢優(yōu)化之子查詢優(yōu)化

    數(shù)據(jù)庫查詢優(yōu)化之子查詢優(yōu)化

    今天小編就為大家分享一篇關于數(shù)據(jù)庫查詢優(yōu)化之子查詢優(yōu)化,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • MySQL查詢和修改auto_increment的方法

    MySQL查詢和修改auto_increment的方法

    這篇文章主要介紹了MySQL查詢和修改auto_increment的方法,實例分析了select查詢auto_increment及ALTER修改auto_increment的技巧,需要的朋友可以參考下
    2015-02-02

最新評論