demo中有封装好的mysql连接池以及mysql类,复制demo中的MysqlPool.php和MysqlObject.php并放入App/Utility/Pool中即可使用
在,produce.php
中添加配置信息:
在EasySwooleEvent.php
的initialize方法中注册连接池对象(注意命名空间,新版本可以无需注册,自动注册)
<?php
// 注册mysql数据库连接池
//注册之后会返回conf配置,可继续配置,如果返回null代表注册失败
连接池不是跨进程的,进程间的连接池连接数是相互独立的,默认最大值是10个;如果开了4个worker,最大连接数可以达到40个。
在控制器 通过mysql连接池获取mysql操作对象
invoke
可通过invoke
静态方法直接从连接池取出一个连接,直接使用,回调函数结束后自动回收:
defer
使用defer
方法直接获取一个连接池连接,直接使用,协程结束后自动回收:
<?php
$db = MysqlPool::defer();
$model->insert(new UserBean($this->request()->getRequestParam()));
新增preload方法,可在程序启动后预创建连接,避免在启动时突然大量请求,造成连接来不及创建从而失败的问题.
示例:
在EasySwooleEvent文件,mainServerCreate事件中增加onWorkerStart回调事件中预热启动: