mysql连接池 顺序_关于mysql连接池的一点小坑

之前看过Rango大神写的http://rango.swoole.com/archives/265,里面提到了mysql连接池,觉得很酷,就直接参(chao)考(xi)了,后来跑了两天经常出现一些不成功的情况,开始怀疑是自己代码有问题,后来终于查到了这里。

function my_onTask($serv, $task_id, $from_id, $sql)

{

static $link = null;

if ($link == null) {

$link = mysqli_connect("127.0.0.1", "root", "root", "test");

if (!$link) {

$link = null;

$serv->finish("ER:" . mysqli_error($link));

return;

}

}

$result = $link->query($sql);

if (!$result) {

$serv->finish("ER:" . mysqli_error($link));

return;

}

$data = $result->fetch_all(MYSQLI_ASSOC);

$serv->finish("OK:" . serialize($data));

}

发现$link那里出现了超时不能用的情况,设置了mysql的超时时间变大点也是没用的。于是去查阅了相关的资料,原来是因为mysql的策略是这样的长时间不连接的话,这资源就被mysql服务器释放了,但是我这个地方$link是常驻内存的,还保持着已经失效的资源,正好有几天都没有用户使用的,这个$link其实就已经没用了,于是我在这里做了一点小小的修改

function my_onTask($serv, $task_id, $from_id, $sql)

{

static $link = null;

if ($link == null || mysqli_ping($link) == false) {

$link = mysqli_connect("127.0.0.1", "root", "root", "test");

if (!$link) {

$link = null;

$serv->finish("ER:" . mysqli_error($link));

return;

}

}

$result = $link->query($sql);

if (!$result) {

$serv->finish("ER:" . mysqli_error($link));

return;

}

$data = $result->fetch_all(MYSQLI_ASSOC);

$serv->finish("OK:" . serialize($data));

}

在使用$link的时候,ping一下这个link是否可用,如果不可用了,也重新连一次。

这个效果还不错,至今都没再出过问题了,目前用户量少,这个暂时都够用了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值