MySQL 的 max_allowed_packet
一、簡述
max_allowed_packet是 MySQL 中的一個設定參數,用于設定所接受的包的大小,根據情形不同,其缺省值可能是 1M 或者 4M。比如是 4M 的情況下,這個值的大小即為:4*1024*1024= 4194304。
當日志中出現了諸如:“Package for query is too large (xxxxxxxx > 4194304). You can change this value on the server by setting the max_allowed_package variable”的提示的時候,錯誤的本身就清楚的提示了對應的方式。
二、確認 max_allowed_package
使用如下的方式可以確認當前設定值
select @@max_allowed_packet;
show variables like 'max_allowed_packet';
三、修改
可以使用 set 命令來修改,但是只是臨時修改,重啟后即丟失。也可以直接修改過 mysql 的設定文件并重啟 mysql 服務,即可永久化保證設定。
根據 mysql 的安裝不同修改的文件也會有所不同,普通安裝方式可能會修改my.cnf,這里使用 mysql 的官方鏡像,其修改的文件應該為:/etc/mysql/mysql.conf.d/mysqld.cnf
修改內容:向此文件中添加如下設定
max_allowed_packet = 256M
修改前
[mysqld]
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
datadir = /var/lib/mysql
log-error = /var/log/mysql/error.log
By default we only accept connections from localhost
bind-address = 127.0.0.1
Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
修改后
[mysqld]
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
datadir = /var/lib/mysql
log-error = /var/log/mysql/error.log
By default we only accept connections from localhost
bind-address = 127.0.0.1
Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
max_allowed_packet = 256M
重啟容器并確認即可。
總結
以上是生活随笔為你收集整理的MySQL 的 max_allowed_packet的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【C语言开源库】C语言必备实用第三方库M
- 下一篇: SQLException:no opra