本文介绍了phpredis中与redis建立连接的两种方式:connect(短连接)和pconnect(长连接)的区别。
问题背景:
项目采用LNMP架构,考虑到数据访问性能问题,因此使用redis来做数据存储,之前一直都是通过直连IP的方式来访问redis,但是运维说redis用sentinel做的高可用,如果直连IP去访问,高可用就无法生效了,因此决定切换成域名的访问方式。
切换域名之后,问题就来了,很多接口出现调用超时的情况,在php-fpm的慢日志中可以看到超时接口的函数调用栈,接口的逻辑很简单,只是从redis取一些数据出来,并没有做其他事情,甚至连日志都没打,为何会超时呢?
问题追踪:
既然当天做了切换访问方式的变更,就一定跟这个有关。切换前后唯一的区别就是切换成域名的访问方式之后,每次连接redis需要先到域名服务器将域名解析成IP,然后再去连接,如果直连IP就可以省去域名解析的过程,难道是域名解析速度太慢导致超时?
问题定位:
写了一个简单的脚本,看了一下域名访问和IP访问的耗时差别到底多大,代码如下,
//test.php
<?php
function microtime_float()
{
list($usec, $sec) = explode(” “, microtime());
return ((float)$usec + (float)$sec);
}
$begin = microtime_float();
$redis=new Redis();
$redis->connect(“10.100.24.198″,6380);
$end = microtime_float();
$ip_cost = intval(($end – $begin)*1000000);
$begin = microtime_float();
$redis->connect(“videogh-6380-redis1.m6.tudou.com”,6380);
$end = microtime_float();
$domain_cost = intval(($end – $begin)*1000000);
echo “ip costip_cost us,domain_costdomain_cost us\n”;
//结果
ip cost:514 us,domain_cost:26972 us
IP直连和域名连接的耗时竟然差了40倍之多!!难怪会有如此多的请求超时。
问题解决:
既然切换成域名后,与redis频繁建立连接导致超时,因此考虑redis的长连接方式,即pconnect方式。注意,这里说的长连接和短连接,并不是指TCP和UDP,其实redis本身也只支持域套接字和TCP连接,这里说的长连接是指多次请求之间可以对redis连接进行复用,即只在第一次执行请求是建立连接,以后每次请求只是从连接池中将连接取出,不再重新建立连接;而短连接表示连接在多次请求之间不可复用,每次请求都需要重新建立连接。
理论上虽然可行,但还需要对pconnect的实际执行效果进行验证,验证过程如下。
验证过程:
考虑用抓包和lsof两种方式进行验证,
准备工作
环境:
Linux+nginx+fpm+PHP5.5
将fpm的参数配置为
pm.max_children = 1;
pm.start_servers = 1;
pm.max_spare_servers = 1;
通过修改php-fpm的参数,将php-fpm的进程设置为一个,这样就可以准确找到执行请求的php-fpm进程id,
页面对应的php代码
public function test_redis()
{
$redis = new Redis();
//redis->connect(“127.0.0.1”, 6379); //connect连接
redis->pconnect(“127.0.0.1”, 6379); //pconnect连接
exit();
}
1、lsof方式
先用pconnect的方式连接方式请求页面的test_redis函数,并执行命令lsof –n –p (fpm-pid),查看php-fpm的句柄使用情况,如下图所示
说明请求结束后,php-fpm中仍然保持与redis的连接,下次请求仍然可以对该连接进行复用;如果使用connect,则获取不到连接信息。
2、抓包方式
抓包命令:tcpdump –i any –X –v –vv tcp and dst port 6379
同样用connec方式和pconnect方式执行多次,通过抓包发现,使用connect方式连接每次都能抓到包,说明connect每次都会建立连接;使用pconnect方式连接只有第一次访问的时候能抓到包,以后每次执行都抓不到包,说明连接只建立一次。
而且,当使用pconnect方式连接时,通过redis-cli连接到redis,并执行info clients,可以看到connected_clients=2,排除终端的命令行连接以外,还有一个是与php-fpm保持的长连接,说明即使请求结束,php-fpm仍然会保留与redis的连接;如果采用connect方式进行连接,则connected_clients=1,即请求结束后php-fpm就释放了与redis的连接。

原文链接:http://bbs.redis.cn/forum.php?mod=viewthread&tid=721

Redis长短链接的区别的更多相关文章

  1. C#语法——泛型的多种应用 C#语法——await与async的正确打开方式 C#线程安全使用(五) C#语法——元组类型 好好耕耘 redis和memcached的区别

    C#语法——泛型的多种应用   本篇文章主要介绍泛型的应用. 泛型是.NET Framework 2.0 版类库就已经提供的语法,主要用于提高代码的可重用性.类型安全性和效率. 泛型的定义 下面定义了 ...

  2. 转:Redis和Memcache的区别分析

    Redis和Memcache的区别分析  原文链接:http://blog.csdn.net/u013474436/article/details/48632665 简单区别: 1. Redis中,并 ...

  3. MySQL、MongoDB、Redis 数据库之间的区别与使用(本章迭代更新)

    MySQL.MongoDB.Redis 数据库之间的区别与使用 MySQL.MongoDB.Redis 数据库之间的区别与使用(本章迭代更新) update:2019年2月20日 15:21:19(本 ...

  4. Redis与Memcache的区别

    Redis与Memcache的区别 数据类型:  redis数据类型丰富,支持set liset等类型          memcache支持简单数据类型,需要客户端自己处理复杂对象 持久性: red ...

  5. Redis和Memcache的区别

    Redis和Memcache的区别 总结一: 1.数据类型 redis数据类型丰富,支持set liset等类型 memcache支持简单数据类型,需要客户端自己处理复杂对象 2.持久性 redis支 ...

  6. Redis与Memcached的区别

    传统MySQL+ Memcached架构遇到的问题 实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量 ...

  7. 也谈谈 Redis 和 Memcached 的区别

    本文作者: 伯乐在线 - 朱小厮 . 说到redis就会联想到memcached,反之亦然.了解过两者的同学有那么个大致的印象: redis与memcached相比,比仅支持简单的key-value数 ...

  8. 【转载】Redis与Memcached的区别

    传统MySQL+ Memcached架构遇到的问题 实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量 ...

  9. redis 资料链接

    redis 资料链接  http://blog.nosqlfan.com/html/3537.html

随机推荐

  1. std::replace函数

    需包含头文件#include <algorithm> template <class ForwardIterator, class T> void replace (Forwa ...

  2. 【计算机视觉】关于OpenCV中GPU配置编译的相关事项

    [计算机视觉]关于OpenCV中GPU配置编译的相关事项 标签(空格分隔): [计算机视觉] 前一段发现了OpenCV中关于GPU以及opencl的相关知识,打算升级一下对OpenCV的使用,但是发现 ...

  3. outlook寻找/删除指定日期范围内的邮件

    总是收到很多系统预警邮件,时间久了攒了好多垃圾邮件.实际上只需保存近期预警邮件,之前的完全可以删除. 上网找了一圈也没找到方法,然后自己想到了一种,步骤如下: 使用outlook规则,将指定日期范围内 ...

  4. 最新 快乐阳光java校招面经 (含整理过的面试题大全)

    从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.快乐阳光等10家互联网公司的校招Offer,因为某些自身原因最终选择了快乐阳光.6.7月主要是做系统复习.项目复盘.Leet ...

  5. LeetCode 第 164 场周赛

    访问所有点的最小时间 不难看出,从点(x1,y1) 到 (x2,y2) 的步数需要 min(dx,dy),其中 dx = abs(x1-x2),dy = abs(y1-y2) class Soluti ...

  6. redis集群(多机)分布

    一.实现原理 一致性哈希算法(Consistent Hashing): http://www.zsythink.net/archives/1182 二.配置两个redis服务,端口号要不一致 三.代码 ...

  7. 报错Could not find resource cn/smbms/dao/provider/ProviderMapper.xml

    原因:由于idea不会编译src下的java目录下的xml文件,所以找不到xml文件 方案一:在pom.xml中添加如下内容 <build> <resources> <r ...

  8. springboot service dockerfile

    FROM java:8u111 MAINTAINER ianthony7@163.com # 定义变量 ENV WORK_DIR /opt ENV LOG_DIR /data/logs EXPOSE ...

  9. 从cbv到fbv:用函数写视图与用类写视图的区别(drf与restful)

    FBV 基于函数的视图 (function base views) CBV 基于类的视图 (class base views) 也就是说我们是用函数编写视图~还是类编写视图我们来看下两个的简单实现 u ...

  10. Idea中maven的设置

    File->setting    输入MAVEN     看到右侧设置情况     Maven home directory 熟路本地moven 仓库目录:D:/springboot/apach ...