phpredis 长连接实现原理

1.长连接的概念理解
长连接其实就是建立了一次连接 然后中间redis的命令都能一直使用,每次使用都不需要重新建立一个连接,这样可以减少建redis连接时间。redis的长连接的生命周期是一个php-fpm进程的时间。再php-fpm这个进程没有关闭之前,这个长连接都是有效的。直观的查看方式就是连续调用两次$redis->connect();和 $redis->pconnect(); 第一个返回的两次的资源id是不一样的,第二个长连接的方式是一样的。
2.长连接的使用
长连接使用其实很简单,直接用pconnect的函数就表示长连接的了。

在传统的网络通信中,普通的交互流程中,客户端发起连接请求,三次握手与服务端建立连接,等客户端做完对应的工作后,会主动关闭连接。

         还有一种是客户端建立起连接,做完对应的工作后,不会主动关闭连接,这样就形成了长连接。

         这种长连接应用于phpredis与redis服务端,但是由于一般都是在FPM-CGI模式下,每次请求的过程后,如果不保存已建立的连接资源的话,就不能让下次请求复用这个长连接,否则还是每个请求都需要重新建立连接。

下面是一张PHP FPM模式下生命周期图,在FPM模式下,每个CGI进程,PHP的各个模块(包括第三方扩展模块)模块初始化都只会加载一次,并且常驻内存,而请求初始化,是每次请求都会执行一次。

所以在FPM-CGI模式下一些全局变量会一直随进程的生命周期一直存在,只有在RINIT请求的过程中的一些变量才需要释放和处理掉。全局的变量和PHP内核内部变量都是用系统内存分配malloc分配,RINIT请求的过程中的所需要分配的内存都是由PHP内存管理器所分配和管理。

下面就贴出一些实际的代码

PHP测试的脚本代码

$redis = new Redis();
 
$redis->pconnect('127.0.0.1', 6379);
 
$result = $redis->ping();
 
print_r($result);
 
exit();

PHP内核实现连接池,建立网络连接资源都是存放在php_stream结构体包装

1.EG(persistent_list) 一个全局变量哈希表, 主要是存放以persistent_id为哈希键存储的连接池 ConnectionPool

2.php_stream是存放在zend_llist list中,所以在FPM-CGI模式下EG(persistent_list) 会一直随进程的生命周期一直存在,所以不同HTTP请求中,如果是长连接模式下,会从对应的哈希键存储的连接池 ConnectionPool中的连接头部取出可以复用的连接,直接使用

3.$redis对象销毁或者主动$redis->close()时才会把这个连接重新放到连接池链表的尾部,从而实现连接池复用连接,减少客户端重复建立连接。


 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

anssummer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值