
我有基於 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
答案1
在中定義一個附加變數/etc/sysconfig/memcached
:
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="64"
LOGFILE="/var/log/memcached.log"
OPTIONS=""
編輯start()
init腳本中的函數如下:
start () {
#echo -n $"Starting $prog: "
# insure that /var/run/memcached has proper permissions
if [ "`stat -c %U /var/run/memcached`" != "$USER" ]; then
chown $USER /var/run/memcached
fi
#daemon --pidfile /var/run/memcached/memcached.pid memcached -d -p $PORT -u $USER -m $CACHESIZE -c $MAXCONN -P /var/run/memcached/memcached.pid $OPTIONS -vv > $LOGFILE 2>&1
$prog -d -p $PORT -u $USER -m $CACHESIZE -c $MAXCONN -P /var/run/memcached/memcached.pid $OPTIONS -vv > $LOGFILE 2>&1
RETVAL=$?
#echo
[ $RETVAL -eq 0 ] && action $"Starting $prog: " /bin/true && touch /var/lock/subsys/memcached
}
然後重新啟動memcached,你會在以下位置看到類似的內容/var/log/memcached.log
:
slab class 40: chunk size 616944 perslab 1
slab class 41: chunk size 771184 perslab 1
slab class 42: chunk size 1048576 perslab 1
<26 server listening (auto-negotiate)
<27 server listening (auto-negotiate)
<28 send buffer was 129024, now 268435456
<29 send buffer was 129024, now 268435456
<28 server listening (udp)
<29 server listening (udp)
不要忘記設定 logrotate。
答案2
首先,您沒有顯示 memcached 配置,而是顯示啟動腳本。您需要尋找一個名為/etc/memcached.conf
.若要啟用日誌記錄,您需要取消註解該行
logfile /var/log/memcached.log
-v
此外,您還可以透過啟用或選項來增加詳細程度-vv
。
如果 memcached 崩潰,您可以查看系統日誌/var/log/messages
並/var/log/syslog
檢查可能的錯誤情況。
答案3
考慮到您的 memcached 設定位於 [/etc/sysconfig/memcached](Redhat RHEL 和 Centos 8 等),您只需將下列開關新增至您的選項並重新啟動 memcached。然後它會將內容記錄到 /var/log/messages 中(如果您以後願意,可以添加輪換)
OPTIONS="-vv"
如果您不想進行太多日誌記錄,請刪除其中一個 v
除了記錄到 /var/log/messages 之外,以下配置將使 memcache 偵聽 localhost 並停用 udp
OPTIONS="-l 127.0.0.1, -U 0, -vv"
當您對日誌記錄感到滿意並且不再需要日誌記錄時,只需從選項 [OPTIONS=""] 中刪除所有內容,然後使用以下命令來檢查何時需要:
memcached-tool 127.0.0.1:11211 stats
或者
echo stats | nc 127.0.0.1 11211