Memcached“无法连接”;高峰时段出错


Memcached "Could not connect" error on peak hours

我使用memecached在我的网站(php, mysql, apache, ubuntu..)它的工作非常快,但在"高峰时间"我得到很多"无法连接"错误信息,有时用户需要刷新5时间看到的内容。

我的服务器上有24 gb的ram和"top"命令给我这个memcached进程:

<>之前4135 nobody 20 0 161m 37m 836 S 7 (%CPU) 0.2 (%MEM) 0:07.06 memcached之前

我像这样启动memcached服务器:

memcached -d -u nobody -m 8192 -p 12000 -c 11212
这是我的PHP函数:
<?
function cache_sql($query,$update,$time=0)
{
    $m = new Memcache;
    $m->connect('localhost', 11211) or die ("Could not connect");
    $file = $m->get(md5($query));
    if($update == 1)
    {
        $results = mysql_query($query);
        while($data = mysql_fetch_array($results)){$records[] = $data;}
        if(!$file)
        {
            $m->set(md5($query), $records, NULL, $time);
        }
        else
        {
            $m->replace(md5($query), $records, NULL, $time);
        }
    }
    else
    {
        if(!$file)
        {
            $results = mysql_query($query);
            while($data = mysql_fetch_array($results)){$records[] = $data;}
            $m->set(md5($query), $records, NULL, $time);
            return $records;
        }
        else
        {
            return $file;
        }
    }
}
?>

我做的对吗?

我想你在启动memcached时不小心翻转了-c和-p参数:

memcached -d -u nobody -m 8192 -p 11212 -c 12000
    首先,确保你有最新版本的php pecl/memcache,因为有一些错误
  • 查看日志,是否有任何错误或连接失败的通知被报告?
  • 查看/etc/memcached.conf文件;特别是MAXCONN -连接数
  • 在终端中使用telnet 127.0.0.1 11211,然后输入stats查看curr_connections和total_connections
  • 目前你没有使用持久连接,这将加快速度,虽然我不确定它是否一定有助于连接。使用持久连接:
代替

$m->connect('localhost', 11211) or die ("Could not connect");

$m->addServer('localhost', 11211) or die ("Could not connect");
  • 还有,我应该指出,如果您的查询经常在where子句中有不同的变量,这种缓存总是会失败。您可能希望记录发生缓存丢失的时间