MySQL server has gone away

確實出現了這個問題,白天一直沒有問題,腳本跑了一天,次日早上的來看的時候,就是 html

MySQL server has gone away了, 比較悲劇,寫腳本考慮的問題仍是不夠啊,在網上看了篇就標記一下。 mysql

最近作網站有一個站要用到WEB網頁採集器功能,當一個PHP腳本在請求URL的時候,可能這個被請求的網頁很是慢慢,超過了mysql的 wait-timeout時間,而後當網頁內容被抓回來後,準備插入到MySQL的時候,發現MySQL的鏈接超時關閉了,因而就出現了「MySQL server has gone away」這樣的錯誤提示,解決這個問題,個人經驗有如下兩點,或許對你們有用處: sql

第一種方法: 數據庫

固然是增長你的 wait-timeout值,這個參數是在my.cnf(在Windows下臺下面是my.ini)中設置,個人數據庫負荷稍微大一點,因此,我設置的值 爲10,(這個值的單位是秒,意思是當一個數據庫鏈接在10秒鐘內沒有任何操做的話,就會強行關閉,我使用的不是永久連接 (mysql_pconnect),用的是mysql_connect,關於這個wait-timeout的效果你能夠在MySQL的進程列表中看到 (show processlist) ),你能夠把這個wait-timeout設置成更大,好比300秒,呵呵,通常來說300秒足夠用了,其實你也能夠不用設置,MySQL默認是8個小 時。狀況由你的服務器和站點來定。 服務器

第二種方法函數

這也是我我的認爲最好的方法,即檢查 MySQL的連接狀態,使其從新連接。 測試

可能你們都知道有mysql_ping這麼一個函數,在不少資料中都說這個mysql_ping的 API會檢查數據庫是否連接,若是是斷開的話會嘗試從新鏈接,但在個人測試過程當中發現事實並非這樣子的,是有條件的,必需要經過 mysql_options這個C API傳遞相關參數,讓MYSQL有斷開自動連接的選項(MySQL默認爲不自動鏈接),但我測試中發現PHP的MySQL的API中並不帶這個函數,你從新編輯MySQL吧,呵呵。但mysql_ping這個函數仍是終於能用得上的,只是要在其中有一個小小的操做技巧: 網站

這是個人的數據庫操做類中間的一個函數 this

  1. function ping(){    
  2.  
  3.     if(!mysql_ping($this->link)){    
  4.  
  5.         mysql_close($this->link); //注意:必定要先執行數據庫關閉,這是關鍵    
  6.  
  7.         $this->connect();    
  8.  
  9.     }    
  10.  
  11. }  

我須要調用這個函數的代碼多是這樣子 google

  1. $str = file_get_contents(’http://www.tianqiyugao.net’);    
  2.  
  3. $db->ping();//通過前面的網頁抓取後,或者會致使數據庫鏈接關閉,檢查並從新鏈接    
  4.  
  5. $db->query(’select * from table’); 
 

ping()這個函數先檢測數據鏈接是否正常,若是被關閉,整個把當前腳本的MYSQL實例關閉,再從新鏈接。

經 過這樣處理後,能夠很是有效的解決MySQL server has gone away這樣的問題,並且不會對系統形成額外的開銷。

今天遇到相似的情景,MySQL只是冷冷的說:MySQL server has gone away。

大概瀏覽了一下,主要多是由於如下幾種緣由:

一種多是發送的SQL語句太長,以至超過了max_allowed_packet的大小,若是是這種緣由,你只要修改my.cnf,加大max_allowed_packet的值便可。

還有一種多是由於某些緣由致使超時,好比說程序中獲取數據庫鏈接時採用了Singleton的作法,雖然屢次鏈接數據庫,但其實使用的都是同一個鏈接,並且程序中某兩次操做數據庫的間隔時間超過了wait_timeout(SHOW STATUS能看到此設置),那麼就可能出現問題。最簡單的處理方式就是把wait_timeout改大,固然你也能夠在程序裏時不時順手mysql_ping()一下,這樣MySQL就知道它不是一我的在戰鬥。

解決MySQL server has gone away

一、應用程序(好比PHP)長時間的執行批量的MYSQL語句。最多見的就是採集或者新舊數據轉化。

解決方案:

在my.cnf文件中添加或者修改如下兩個變量:

wait_timeout=2880000

interactive_timeout = 2880000

關於兩個變量的具體說明能夠google或者看官方手冊。若是不能修改my.cnf,則能夠在鏈接數據庫的時候設置CLIENT_INTERACTIVE,好比:

sql = "set interactive_timeout=24*3600";

mysql_real_query(...)

二、執行一個SQL,但SQL語句過大或者語句中含有BLOB或者longblob字段。好比,圖片數據的處理

解決方案:

在my.cnf文件中添加或者修改如下變量:

max_allowed_packet = 10M(也能夠設置本身須要的大小)

max_allowed_packet參數的做用是,用來控制其通訊緩衝區的最大長度

原文連接:http://www.cnblogs.com/aiyuchen/archive/2011/05/11/2042798.html

相關文章
相關標籤/搜索