内存的妙用 -- PHP终于可以 vs JAVA啦

目录

  1. 初探 Swoole -- 用 Swoole 启动一个 hello world

  2. 内存的妙用 -- PHP终于可以 vs JAVA啦

  3. 初级应用 -- 实现用户注册登录 [撰写中]

  4. 展望 -- Swoole 的局限性分析及我个人的期待 [撰写中]

原生 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]  | 1. PHP web应用不可长驻运行1. 不可借助第三方服务如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) ] |
| || |
| || | PHP有了连接池,我们的应用就可以不用再在收到请求时去创建数据库连接了。
试试上面的代码,与曾经碰到过3000+数据库连接的烦恼bye bye吧~

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

关键字:php, swoole

版权声明

本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部