在一个高流量的服务器,如果不使用长链接的话 会造成大量的 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这个版本有问题,千万不要使用