Отладка 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()функцию в скрипте инициализации, как показано ниже:

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 и отключит udp в дополнение к записи в /var/log/messages

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

Связанный контент