workerman引入db类失效怎么办,解决方法是什么
Admin 2022-07-22 群英技术资讯 533 次浏览
为了更高效的服务器访问速度,我们会使用mysql 或者其他数据库的长连接 来提高访问速度,
以下内容以mysql pdo 为例:
问题:
在cli 常驻内存的情况下,会有许多情况造成创建的连接失效;
解决方法:
在访问数据库的时候加上 try catch 捕获
捕获到错误是 2006 或者 2013 的时候 表示连接失效 这时候 重新连接数据库,以保证程序正常运行;
// 在和数据库交互的地方加上try catchpublic function Init($query) { try{ // todo 这里是操作数据库的逻辑 }catch (\Exception $e) { if ( $e->errorInfo[1] === 2006 || $e->errorInfo[1] === 2013 ) { // todo 下面填写 或者调用连接数据库的代码 $dsn = 'mysql:dbname=' . $this->settings["dbname"] . ';host=' . $this->settings["host"] . ''; $this->pdo = new \PDO($dsn, $this->settings["user"], $this->settings["password"], array(\PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8;")); $this->pdo->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION); $this->pdo->setAttribute(\PDO::ATTR_EMULATE_PREPARES, true); return true; } } }
var_dump($e->errorInfo); 的值
array(3) { [0]=> string(5) "HY000" [1]=> int(2006) [2]=> string(26) "MySQL server has gone away"}
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在thinkphp中,可以利用empty标签判断变量是否为空,该标签的作用就是判断模板变量是否为空值,其功能相当于PHP中的empty()函数,语法为“<empty name="变量名">要输出的内容</empty>”。
这篇文章主要介绍了Thinkphp5.0 框架使用模型Model添加、更新、删除数据操作,结合实例形式详细分析了thinkPHP5.0框架Model模型操作数据的添加、更新、删除的各种常用技巧与操作注意事项,需要的朋友可以参考下
这篇文章主要给大家介绍了关于如何利用PHP实现多张上传图片功能的,文中通过示例代码介绍的非常详细,对大家的学习PHP具有一定的帮助,需要的可以参考一下
在学习Laravel框架的时候,我们会接触到Laravel的数据库迁移,也叫做Migrations,很多新手对于为什么要数据库迁移以及好处不是很了解,对此,这篇文章就给大家介绍一下Migrations。
对于日志系统是什么和为什么需要日志系统,很多新手不太了解,下面就给大家简单的介绍一下这两个问题以及选择和安装seaslog,seaslog常用方法小编觉得是比较实用的,也分享给大家参考参考,下面我们就一起来学习一下吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008