PHPCMS 2008的一个mySQL错误,求高手解答

来源:百度知道 编辑:UC知道 时间:2024/06/24 12:24:48
MySQL Query : SELECT * FROM phpcms_process WHERE workflowid=1 ORDER BY processid
MySQL Error : MySQL server has gone away
MySQL Errno : 2006
Message : MySQL Query Error
MySQL Query : REPLACE INTO `discuz`.`phpcms_session` (`sessionid`, `userid`, `ip`, `lastvisit`, `groupid`, `module`, `catid`, `contentid`, `data`) VALUES('5fde1f1f4688b15a11fc6d6de5d1b3c1', '1', '127.0.0.1', '1247621500', '1', 'phpcms', '12', '3', 'admin_groupid|s:1:\"1\";is_admin|i:1;')
MySQL Error : MySQL server has gone away
MySQL Errno : 2006
Message : MySQL Query Error
MySQL Query : DELETE FROM `discuz`.`phpcms_session` WHERE `lastvisit`<1247619700
MySQL Error : MySQL server has gone away
MySQL Errno : 2006
Message : MySQL Query Error
不是修改my.ini吗?
my.cnf在哪里的?求解。

MySQL server has gone away有几种情况。
1、应用程序(比如PHP)长时间的执行批量的MYSQL语句。
最常见的就是采集或者新旧数据转化。
解决方案:

在my.cnf文件中添加或者修改以下两个变量:
wait_timeout=2880000
interactive_timeout = 2880000

关于两个变量的具体说明可以google或者看官方手册。
如果不能修改my.cnf,则可以在连接数据库的时候设置CLIENT_INTERACTIVE,比如:
sql = "set interactive_timeout=24*3600";
mysql_real_query(...)
2、执行一个SQL,但SQL语句过大或者语句中含有BLOB或者longblob字段。
比如,图片数据的处理
解决方案
在my.cnf文件中添加或者修改以下变量:
max_allowed_packet = 10M(也可以设置自己需要的大小)
max_allowed_packet 参数的作用是,用来控制其通信缓冲区的最大长度。

看样子像数据库坏了,看看var/下???.err里都有什么东西