ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

php – 高峰时段Memcached“无法连接”错误

2019-05-21 13:24:04  阅读:152  来源: 互联网

标签:php memcached


我在我的网站上使用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,因为有一些bug
>查看日志,是否有任何错误或通知被报告连接失败?
>看看/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子句中经常有不同的变量,那么这种缓存总是会失败.您可能希望在发生缓存未命中时进行记录

标签:php,memcached
来源: https://codeday.me/bug/20190521/1147345.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有