轻松解决Mysql“信息包过大”的处理方法

时间:2008-06-07 16:50:00 

通信信息包是发送至MySQL服务器的单个SQL语句,或发送至客户端的单一行。

在MySQL 5.1服务器和客户端之间最大能发送的可能信息包为1GB。

当MySQL客户端或mysqld服务器收到大于max_allowed_packet字节的信息包时,将发出“信息包过大”错误,并关闭连接。对于某些客户端,如果通信信息包过大,在执行查询期间,了能回遇到“丢失与MySQL服务器的连接”错误。

客户端和服务器均有自己的max_allowed_packet变量,因此,如你打算处理大的信息包,必须增加客户端和服务器上的该变量。

如果你正在使用mysql客户端程序,其max_allowed_packet变量的默认值为16MB。要想设置较大的值,可用下述方式启动mysql:


mysql> mysql --max_allowed_packet=32M

它将信息包的大小设置为32MB。

服务器的默认max_allowed_packet值为1MB。如果服务器需要处理大的查询,可增加该值(例如,如果准备处理大的BLOB列)。例如,要想将该设置为16MB,可采用下述方式启动服务器:


mysql> mysqld --max_allowed_packet=16M

也能使用选项文件来设置max_allowed_packet。要想将服务器的该变量设置为16MB,可在选项文件中增加下行内容:


[mysqld]
max_allowed_packet=16M

增加该变量的值十分安全,这是因为仅当需要时才会分配额外内存。例如,仅当你发出长查询或mysqld必须返回大的结果行时mysqld才会分配更多内存。该变量之所以取较小默认值是一种预防措施,以捕获客户端和服务器之间的错误信息包,并确保不会因偶然使用大的信息包而导致内存溢出。

如果你正是用大的BLOB值,而且未为mysqld授予为处理查询而访问足够内存的权限,也会遇到与大信息包有关的奇怪问题。如果怀疑出现了该情况,请尝试在mysqld_safe脚本开始增加ulimit -d 256000,并重启mysqld。

标签:MySQL,服务器,信息
0
投稿

猜你喜欢

  • suggest项目总结-用户体验篇

    2008-01-30 20:04:00
  • 修改asp代码防止被杀毒软件误删

    2007-10-07 12:32:00
  • ASP/php/aspx生成静态网页的方法

    2007-10-25 12:01:00
  • 利用SQL语言有没有办法查到表中哪些记录中的全部

    2009-04-10 18:29:00
  • 数据库名词解释

    2008-09-12 17:28:00
  • MySQL数据库中的重要数据应当如何保护

    2008-12-17 15:56:00
  • 五种方法解决 Web2.0设计中的匹配度

    2007-09-22 10:58:00
  • 对学好网页设计很有价值的一句话

    2007-10-28 16:04:00
  • 给验证码增加干扰的杂点

    2008-05-16 11:34:00
  • MySQL身份认证漏洞 升级到5.5.24可修正

    2012-07-11 15:54:09
  • 巧用Dreamweaver4文件库更新网站

    2007-02-03 11:31:00
  • javascript基础之indexOf函数

    2008-06-25 13:28:00
  • 网页版面布局的方法及技巧

    2007-10-29 12:41:00
  • javascript浮点数计算的bug

    2009-12-06 11:43:00
  • 初学ASP编程易犯的一个错误要注意

    2008-11-07 15:08:00
  • 资料:MsSQL常用SQL语句

    2009-02-23 12:54:00
  • sqlserver中获取月份的天数的方法分享

    2011-09-30 11:27:52
  • 简单的文本内容处理工具

    2010-01-28 12:31:00
  • Oracle 触发器的使用小结

    2009-05-24 19:54:00
  • 拖拽翻页(ThrowPage)详解 cool

    2009-12-02 09:54:00
  • asp之家 网络编程 m.aspxhome.com