gearman中worker常驻后台,导致MySQL server has gone away的解决方法
时间:2022-07-27
本文章向大家介绍gearman中worker常驻后台,导致MySQL server has gone away的解决方法,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文实例讲述了gearman中worker常驻后台,导致MySQL server has gone away的解决方法。分享给大家供大家参考,具体如下:
产生这个原因主要有如下几点:
1、mysql服务宕机了
2、长时间没有操作,超过了wait_timeout的设置,mysql自动断开
3、mysql请求链接被主动kill
4、发送的请求或返回结果过大,可设置max_allowed_packet的值
5、程序中你都是通过单例来操作数据库,如果两个操作时间超过wait_timeout。
为了演示的方便,设置wait_timeout时间为10秒
set global wait_timeout=10;
show global variables like 'wait_timeout';
worker.php代码如下:
<?php
//创建一个worker
$worker = new GearmanWorker();
//添加一个job服务
$worker- addServer('127.0.0.1', 4730);
//注册一个回调函数,用于业务处理
$worker- addFunction('longTime', function($job) {
//workload()获取客户端发送来的序列化数据
$data = json_decode($job- workload(), true);
$db = new mysqli('192.168.1.100', 'root', '', 'test');
if($db- connect_error) {
die('connect error');
}
//等待15秒,我们设置mysql的wait_timeout为10秒
sleep(15);
//当执行到这里时,因为超时,所以mysql自动把连接断开了
$ret = $db- query("INSERT INTO test VALUES(NULL, {$data['title']}, {$data['content']});");
if($ret) {
return "插入成功n";
}
});
//死循环
//等待job提交的任务
while($worker- work());
client.php代码如下:
<?php
//创建一个客户端
$client = new GearmanClient();
//添加一个job服务
$client- addServer('127.0.0.1', 4730);
//doNormal同步
$ret = $client- doNormal('longTime', json_encode(array(
'title' = '我是标题',
'content' = '我是内容',
)));
echo $ret;
执行的结果如下图所示,出现了MySQL server has gone away的情况。
一般的解决方法:
1、调大wait_timeout的值(不建议) 2、每次在操作数据库的时候,ping()一下,如果断开就重新连。 3、在wait_timeout时间间隔之内,我们时不时的去query(‘select 1+1’);一下,让mysql知道连接还活着。
修改worker.php代码如下:
<?php
//创建一个worker
$worker = new GearmanWorker();
//添加一个job服务
$worker- addServer('127.0.0.1', 4730);
//注册一个回调函数,用于业务处理
$worker- addFunction('longTime', function($job) {
//workload()获取客户端发送来的序列化数据
$data = json_decode($job- workload(), true);
$db = new mysqli('192.168.1.100', 'root', '', 'test');
if($db- connect_error) {
die('connect error');
}
//等待15秒,我们设置mysql的wait_timeout为10秒
sleep(15);
//ini_set('mysqli.reconnect', 1);
//php手册上说,ping会尝试重新连接,但现实是并不会
//$db- ping();
if(!$db- ping()) {
$db- close();
//重新连接数据库
$db = new mysqli('192.168.1.100', 'root', '', 'test');
}
$ret = $db- query("INSERT INTO test VALUES(NULL, '{$data['title']}', '{$data['content']}');");
if($ret) {
return "插入成功n";
}
});
//死循环
//等待job提交的任务
while($worker- work());
运行结果如下:
更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP进程与线程操作技巧总结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
- 用Python将word文件转换成html
- 1行Python代码实现FTP服务器
- 100行Python代码实现自动抢火车票
- Python交互式数据分析报告框架:Dash
- PyQt5 GUI应用程序工具包入门(2)
- 用Python研究了三千套房子,告诉你究竟是什么抬高了房价?
- 设计模式之装饰模式
- Android网络编程(六)OkHttp3用法全解析
- Android网络编程(五)OkHttp用法全解析
- Android网络编程(一)HTTP协议原理
- Spring Cloud实战小贴士:Zuul统一异常处理(二)
- Android View体系(九)自定义View
- Android网络编程(二)HttpClient与HttpURLConnection
- Spring Batch入门篇
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- 22+ 高频实用的 JavaScript 片段 (2020年)
- 文件上传C:fakepath解决方案
- Asp.net web api部署在某些服务器上老是404
- Spring解决循环依赖的思路
- Spring中Bean的创建流程
- 详解RocketMQ事务消息
- 带你白嫖程序带宽限制命令Trickle
- Fix SSH客户端登录会话超时设置
- JAVA的泛型与反射的联合应用
- 专项测试实战 | 如何测试 App 流畅度(基于 FPS 和丢帧率)
- 计算上传文件的存放路径
- 按照list中实体类的某一属性排序
- java邮件开发
- java计算某日期之后的日期
- 文件上传之Html5 + jQuery上传、asp.net web api接收