我有基于 Memcached 变量的聊天引擎,将它们放入数组并通过 jquery 在另一端读取它们,
这在 95% 的情况下工作正常,但是当服务器负载高 memcached(假设它是 memcached)时,崩溃和浏览器会卡住。
我不认为它的 jquery 问题,因为这只发生在服务器负载非常高的时候。
我需要一种方法来监视 memcached 服务器或以某种方式将日志文件写入失败/错误出现的位置......
关于我该怎么做的任何想法?或者知道为什么 memcached 服务器会失败?我按如下方式运行 memcached
$GLOBALS['MemCached'] = FALSE;
$GLOBALS['MemCached'] = new Memcache;
$GLOBALS['MemCached']->pconnect('localhost', 11211);
我的 memcached 配置如下
#! /bin/sh
#
# chkconfig: - 55 45
# description: The memcached daemon is a network memory cache service.
# processname: memcached
# config: /etc/sysconfig/memcached
# pidfile: /var/run/memcached/memcached.pid
# Standard LSB functions
#. /lib/lsb/init-functions
# Source function library.
. /etc/init.d/functions
PORT=11211
USER=memcached
MAXCONN=1024
CACHESIZE=128
OPTIONS=""
if [ -f /etc/sysconfig/memcached ];then
. /etc/sysconfig/memcached
fi
# Check that networking is up.
. /etc/sysconfig/network
if [ "$NETWORKING" = "no" ]
then
exit 0
fi
RETVAL=0
prog="memcached"
pidfile=${PIDFILE-/var/run/memcached/memcached.pid}
lockfile=${LOCKFILE-/var/lock/subsys/memcached}
start () {
echo -n $"Starting $prog: "
# Ensure that /var/run/memcached has proper permissions
if [ "`stat -c %U /var/run/memcached`" != "$USER" ]; then
chown $USER /var/run/memcached
fi
daemon --pidfile ${pidfile} memcached -d -p $PORT -u $USER -m $CACHESIZE -c $MAXCONN -P ${pidfile} $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch ${lockfile}
}
stop () {
echo -n $"Stopping $prog: "
killproc -p ${pidfile} /usr/bin/memcached
RETVAL=$?
echo
if [ $RETVAL -eq 0 ] ; then
rm -f ${lockfile} ${pidfile}
fi
}
restart () {
stop
start
}
# See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status -p ${pidfile} memcached
RETVAL=$?
;;
restart|reload|force-reload)
restart
;;
condrestart|try-restart)
[ -f ${lockfile} ] && restart || :
;;
*)
echo $"Usage: $0 {start|stop|status|restart|reload|force-reload|condrestart|try-restart}"
RETVAL=2
;;
esac
exit $RETVAL
首先,您没有显示 memcached 配置,而是显示启动脚本。您需要查找一个名为
/etc/memcached.conf
. 要启用日志记录,您需要取消注释该行-v
此外,您可以通过启用或-vv
选项来增加详细程度。如果 memcached 崩溃,您可以查看系统日志
/var/log/messages
并/var/log/syslog
检查可能的错误情况。在 中定义一个附加变量
/etc/sysconfig/memcached
:如下编辑
start()
初始化脚本中的函数:然后重新启动 memcached,您将在以下内容中看到类似的内容
/var/log/memcached.log
:不要忘记配置 logrotate。
考虑到您的 memcached 配置位于 [/etc/sysconfig/memcached](Redhat RHEL 和 Centos 8 等),您只需将以下开关添加到您的选项并重新启动 memcached。然后它会将内容记录到 /var/log/messages(如果你以后愿意,可以添加轮换)
如果您不想记录太多日志,请删除其中一个 v
以下配置将使 memcache 监听 localhost 并禁用 udp 除了记录到 /var/log/messages
在您对日志记录感到满意并且不再需要日志记录后,只需从选项 [OPTIONS=""] 中删除所有内容,然后使用以下命令检查何时需要:
或者