博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
swoole实现数据库连接池
阅读量:6501 次
发布时间:2019-06-24

本文共 2511 字,大约阅读时间需要 8 分钟。

hot3.png

原生 PHP CURD

让我们来回顾一下PHP中数据库的使用

prepare('SELECT * FROM `user` WHERE `id`=:id');$stmt ->bindValue(':id', $id);$user = $stmt->fetch();var_dump($user);

上述代码, 本身是没有任何问题。这里我们也不是来挑出问题的,只是以一位多年PHPer的经验与大家交流下。

上面程序执行过程是什么样子的呢?

_______________________                |                       |    [浏览器请求] ==>   [mod_php/php-fpm]  |                |           ||          |                |           ||          |                |           \/          |                |       [curd.php]      |                |           ||          |                |           ||          |                |           \/          |                |    [PDO::_construct]  | <== 请求的开销                |           ||          |                |           ||          |                |           \/          |    [Response] <==      [PDO::CURD]     |                |           ||          |                |           ||          |                |           \/          |                |       [PDO::close]    |                |_______________________|

Swoole PHP CURD

Java应用中,大家在进行数据库CURD的时候,会维护一个数据库连接池。在PHP的世界中,要想做连接池挺困难的:

  • PHP web应用不可长驻运行

  • 不可借助第三方服务如KV转存句柄

而在Swoole中我们就可以实现连接池了!

db->dbh = new PDO();$http->on('request', function(swoole_http_request $req, swoole_http_response $res) use($http) { $id = 1; $stmt = $http->db->dbh->prepare('SELECT * FROM `user` WHERE `id`=:id'); $stmt ->bindValue(':id', $id); $user = $stmt->fetch(); $res->end(var_export($user, true)); unset($stmt);});

执行流程

[php app.php]                           ||                           ||                           \/                    [PDO::__construct]                           ||               ____________||________________              |            \/                |  [浏览器请求] ==>   [ ->onRequest(\Closure) ] |              |            ||                |              |            ||                | <== 请求开销              |            \/                |  [Response] <==      [PDO::CURD]            |              |____________||________________|                           ||                           \/                     [PDO::close]

分析上面流程, Swoole不用再每次请求时去建立数据库连接, 既避免了给数据库过多压力, 也更迅速的处理核心业务逻辑. 也许你觉得这优势不明显, 但是在c10k问题(Connections over 10,000)场景中, 优势就非常明显了吧?当然, 上面的demo只是抛砖引玉, 没有实现multi connections pool, 如果大家要做生产化代码, 务必实现连接池, idle连接数按照业务需要, 比如80%的时间连接数200, 设置200个idle的连接池是最优的.

PHP有了连接池,我们的应用就可以不用再在收到请求时去创建数据库连接了。

试试上面的代码,与曾经碰到过3000+数据库连接的烦恼bye bye吧~

[本节完, 文字未校对, 程序未测试]

转载于:https://my.oschina.net/u/1762916/blog/777536

你可能感兴趣的文章
Eclipse中设置在创建新类时自动生成注释
查看>>
我的友情链接
查看>>
CoreOS 手动更新
查看>>
golang 分页
查看>>
再论机械式针对接口编程
查看>>
25 个 Linux 性能监控工具
查看>>
C#程序员整理的Unity 3D笔记(十三):Unity 3D基于组件的思想
查看>>
Tengine-2.1.1 ngx_http_concat_module 400问题
查看>>
Windows中挂载安装ISO文件
查看>>
Wayland 1.0发布
查看>>
golang的goroutine是如何实现的?
查看>>
乐视云基于Kubernetes的PaaS平台建设
查看>>
R 学习笔记《十》 R语言初学者指南--图形工具
查看>>
PHP通过读取DOM抓取信息
查看>>
DICOM医学图像处理:DICOM网络传输
查看>>
nio和传统Io的区别
查看>>
移动端网页布局中需要注意事项以及解决方法总结
查看>>
(原创)Linux下查看系统版本号信息的方法
查看>>
oracle
查看>>
redis使用过程中主机内核层面的一些优化
查看>>