mysql的max_allowed_packet配置
開(kāi)發(fā)中經(jīng)常出現(xiàn)批量的插入或者更新操作,當(dāng)批量操作的數(shù)據(jù)較多時(shí),比如到了幾萬(wàn)行數(shù)據(jù),會(huì)遇到操作數(shù)據(jù)庫(kù)報(bào)錯(cuò)的情況,這個(gè)其中一種原因就是max_allowed_packet的配置問(wèn)題,max_allowed_packet配置了數(shù)據(jù)庫(kù)單次執(zhí)行sql語(yǔ)句的大小,若超出配置的大小,就會(huì)出現(xiàn)報(bào)錯(cuò)。
錯(cuò)誤信息:
1、Packets larger than max_allowed_packet are not allowed
2、Packet?for?query?is?too?large?(1706?>?1024).?You?can?change?this?value?on?the?server?by?setting?the?max_allowed_packet'?variable.
3、程序(如python里面executemany)在插入大量數(shù)據(jù)時(shí)出現(xiàn)"MySQL server has gone away"
如何查看max_allowed_packet配置:
查詢(xún)語(yǔ)句:
SHOW GLOBAL VARIABLES;
或?show variables like '%max_allowed_packet%'
查詢(xún)結(jié)果:
max_allowed_packet ? ?4194304
備注:本機(jī)是windows下的5.7.23版本的mysql,默認(rèn)是4194304byte,即4M。
方式一:sql語(yǔ)句修改
1、首先登陸mysql查看當(dāng)前該值的大小。
show variables like '%max_allowed_packate%'
???? 2、修改其大小為1G(1024*1024=1M)
???????????set global max_allowed_packet = 1024*1024*1024
這種修改方式修改后,需要重新登陸Mysql查看,才能看到修改后的值。并且,這種方式修改的mysql max_allowed_packet,在Mysql重啟后,可能失效。
方式二:my.ini修改
1、在my.ini文件中添加如下語(yǔ)句。比如:改為1G.如下圖所示。修改完成后,需要重啟mysql。
注意:方式2中max_allowed_packed一定是添加在【mysqld】才能生效。
方式三:linux系統(tǒng)中my.ini修改
linux系統(tǒng)中,my.ini文件在/etc/my.cnf文件中,可直接打開(kāi)此文件,修改下面兩行,主要是第二行。如果文件中沒(méi)有這兩行,可直接插入。
保存并退出后,需要重啟mysql服務(wù)
重啟命令:service mysql restart.
再次運(yùn)行show variables like '%max_allowed_packate%'?可發(fā)現(xiàn)該值已有變化
?附,linux操作指令:
進(jìn)入文件夾?cd /etc
找到文件 ls
打開(kāi)文件 vi my.cnf
編輯? a
保存?按“esc”后,
linux系統(tǒng)下保存命令分八種情況:保存但不退出:“:w” ;將修改保存到file中不退出vi:“:w file” ;強(qiáng)制保存,不退出vi:“:w! ”;保存并退出vi:“:wq”;強(qiáng)制保存并退出vi:“:wq!”;不保存退出vi:“q:”;不保存強(qiáng)制退出vi:“:q!”;放棄修改:“:e!”。
總結(jié)
以上是生活随笔為你收集整理的mysql的max_allowed_packet配置的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: ESP32 HTTP Client接口使
- 下一篇: linux mysql max_allo