Memcached 디버깅/서버 로그 Memcached 서버를 모니터링하시겠습니까?

Memcached 디버깅/서버 로그 Memcached 서버를 모니터링하시겠습니까?

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 중 하나를 제거하십시오.

다음 구성은 Memcache가 localhost에서 수신 대기하도록 만들고 /var/log/messages에 로깅하는 것 외에도 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

관련 정보