黃聰:2006 MySQL server has gone away錯誤,最大值溢出解決辦法 mysql max_allowed_packet 查詢和修改


1、應用程序(比如PHP)長時間的執行批量的MYSQL語句。
最常見的就是采集或者新舊數據轉化。
解決方案:

my.ini文件中添加或者修改以下兩個變量:
wait_timeout=2880000
interactive_timeout = 2880000


關於兩個變量的具體說明可以google或者看官方手冊。
如果不能修改my.cnf,則可以在連接數據庫的時候設置CLIENT_INTERACTIVE,比如:
sql = "set interactive_timeout=24*3600";
mysql_real_query(...)


2、執行一個SQL,但SQL語句過大或者語句中含有BLOB或者longblob字段。
比如,圖片數據的處理
解決方案


my.cnf文件中添加或者修改以下變量:
max_allowed_packet = 10M  (也可以設置自己需要的大小)

max_allowed_packet 參數的作用是,用來控制其通信緩沖區的最大長度。

 

 

mysql根據配置文件會限制server接受的數據包大小。

有時候大的插入和更新會被max_allowed_packet 參數限制掉,導致失敗。

查看目前配置

show VARIABLES like '%max_allowed_packet%';

顯示的結果為:

+--------------------+---------+ | Variable_name      | Value   | +--------------------+---------+ | max_allowed_packet | 1048576 | +--------------------+---------+  

以上說明目前的配置是:1M

 

修改方法

1) 方法1

可以編輯my.cnf來修改(windows下my.ini),在[mysqld]段或者mysql的server配置段進行修改。

max_allowed_packet = 20M

如果找不到my.cnf可以通過

mysql --help | grep my.cnf

去尋找my.cnf文件。

2) 方法2

(很妥協,很糾結的辦法)

進入mysql server

在mysql 命令行中運行

set global max_allowed_packet = 2*1024*1024*10

然后關閉掉這此mysql server鏈接,再進入。

show VARIABLES like '%max_allowed_packet%';

查看下max_allowed_packet是否編輯成功


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM