php常见使用的服务的长链接方法(mysql,redis,memcache,mongodb)

16 篇文章 0 订阅
14 篇文章 0 订阅

在一个高流量的服务器,如果不使用长链接的话 会造成大量的 time_wait ,这样就会导致没有可用的tcp资源,导致系统很慢,负载很高,还经常出现无法connect的情况

 

所以我们需要长链接来解决问题

 

mysql:

            $db_string
='mysql:host='.$config['host'].';port='.$config['port'].';dbname='.$config['db'];
            $charset = $config['charset']?:'utf8';
            $this->debug($db_string);
            try {
                $pdo = new PDO($db_string, $config['user'], $config['pass'], [
                    PDO::ATTR_PERSISTENT => true
                ]);
            } catch  (PDOException $e) {
                file_put_contents("/tmp/pdo_errors.log",$db_string.",".$e->getMessage()."\r\n",FILE_APPEND);

                #print "Error!: " . $e->getMessage() . "<br/>";
                die();
            }

主要就是加上 PDO::ATTR_PERSISTENT => true

注意这时候要增加mysql的最大连接数,不然后可能会出现toomanyconnections这种报错,可以加到1024,因为短链接的情况下,可能保持连接的就10几个,但是time_wait有几千个,长链接之后要根据你的fpm设置情况来计算,比如有150个fpm进程,就是150个长链接,但是time_wait一般小于10个

 

memcache:

            $memcache = new Memcached("mc");//持久化链接,注意参数"mc"
            $memcache ->setOption(Memcached::OPT_LIBKETAMA_COMPATIBLE, true);
            if (!count($memcache ->getServerList())) {
                $memcache ->addServer("192.168.0.1", "11211");
            }

就是在构造函数上增加一个参数,这样加一个fpm一个链接,你可以随机两个id,一个fpm就有两个链接

注意一定要按照我的这种方法写,不然可能会出问题

 

mongodb:

使用mongodb driver即可,默认就是长链接的

 

redis:

很简单,使用pconnect 即可

 

redis-cluster:

版本需求 php > 7.0

phpredis >= 5.0.1   5.0.0这个版本有问题,千万不要使用

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值