com.mysql.jdbc.PacketTooBigException: Packet for query is too large (1155209 >
1048576). You can change this value on the server by setting the
max_allowed_packet' variable.
?
mysql根據配置文件會限制server接受的數據包大小。
有時候大的插入和更新會被max_allowed_packet 參數限制掉,導致失敗。
查看目前配置?
show VARIABLES like '%max_allowed_packet%';
以上說明目前的配置是:1M
修改方法
?
可以編輯my.cnf來修改(windows下my.ini),在[mysqld]段或者mysql的server配置段進行修改。(在[mysqld]下加上max_allowed_packet=16M,保存重啟mysql后)
max_allowed_packet = 20M
如果找不到my.cnf可以通過
mysql --help | grep my.cnf
去尋找my.cnf文件。
?
重啟mysql
1.點擊“開始”->“運行”(快捷鍵Win+R)
2.啟動:輸入 net stop mysql
3.停止:輸入 net start mysql
?
max_allowed_packet 參數說明:
?
參數的作用是,用來控制其通信緩沖區的最大長度。
?
注意:該參數對應的分配內存是每連接獨占!
?
如果有100個連接,那么實際分配的總共排序緩沖區大小為100 × 6 = 600MB。
?
所以,對于內存在4GB左右的服務器推薦設置為6-8M。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
