1. 程式人生 > >Mysql DataPacketTooBigException異常處理

Mysql DataPacketTooBigException異常處理

安裝 mysqli 配置 art server internal rec my.ini exe

在本地上運行好好,然後發布到服務器上去, 總是報錯,後來查了一下日誌,得到了如下的錯誤日誌:

[org.hibernate.engine.jdbc.spi.SqlExceptionHelper] Packet for query is too large (1079 > 1024). You can change this value on the server by setting the max_allowed_packet‘ variable. [n/a]
com.mysql.jdbc.PacketTooBigException: Packet for query is too large (1079 > 1024). You can change this value on the server by setting the max_allowed_packet‘ variable.
at com.mysql.jdbc.MysqlIO.send(MysqlIO.java:3248)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1940)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2113)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2568)
at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2113)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:2275)

解決

MySQL配置文件在Windows下叫my.ini,在MySQL的安裝根目錄下;在Linux下叫my.cnf,該文件位於/etc/my.cnf。

找到這個配置文件,

vim /etc/my.cnf

在裏面加入一行 或 修改這行的值:

[mysqldump]

max_allowed_packet = 32M

這個值主要視個人的情況而定, 我這原來的值為 16M , 還是不夠, 加大了一倍. 暫時設置為 32M,

重啟mysql,就可以解決了.

=====================

附linux 重啟 mysql 命令:

1.啟動:/etc/init.d/mysql start
2.停止:/etc/init.d/mysql stop
3.重啟:/etc/init.d/mysql restart

Mysql DataPacketTooBigException異常處理