这次来是因为上篇文章swoole实现多对多群聊进阶篇的pdo链接有效时间好像不是那么的长!!!导致数据完全丢失!!!
通过测试,发现pdo链接在一个小时左右后就不会再往数据库插入数据了,而且sql语句执行也不会报错,具体什么情况一时间还不清楚,然后开始找是不是pdo链接不支持长链接,百度了一下,果然需要配置才能实现长链接
PDO有一项参数,名为PDO::ATTR_PERSISTENT是个booleans值,默认不开启,
屁颠屁颠的开启跑去测试后发现,还是不行,还是会断开,这我又想不通了,如果断开,执行sql理应会报错啊,然后在try catch 语句下手
try {
$stmt = $this->pdo->prepare($sql);
$stmt->execute();
} catch (Exception $e) {
$this->pdo = new PDO(
"mysql:host=********;dbname=******;charset=utf8;",
"********",
"********",[\PDO::ATTR_CASE => \PDO::CASE_NATURAL]
);
}
这里的意图是,如果执行sql报错,我就从新初始化pdo链接,不过结果也不尽人意,执行sql什么事都没有,数据库没有记录,也不报错,想来想去,只能是小弟搞得鬼了,要把小弟拉出去祭天!
上篇文章中的小弟相关的代码
//创建token找几个小弟
$this->ws->set([
'worker_num' => WORKER_NUM,
'task_worker_num' => TASK_WORKER_NUM,
]);
//token线程监听
$this->ws->on("task", [$this, 'onTask']);
$this->ws->on('finish',[$this,'onFinish']