我在我的网站上使用 memecached (php,mysql,apache,ubuntu ..)它工作得非常快,但在“高峰时段”我得到了很多“无法连接< / strong>“错误消息,有时用户需要刷新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;
}
}
}
?>
我做得对吗?
答案 0 :(得分:5)
我认为你在启动memcached时意外地翻转了-c和-p参数:
memcached -d -u nobody -m 8192 -p 11212 -c 12000
替换
$m->connect('localhost', 11211) or die ("Could not connect");
与
$m->addServer('localhost', 11211) or die ("Could not connect");