среда, 28 марта 2012 г.

Как проверить, что memcached работает

Установка memcached на Debian подозрительно проста: всего одна команда

sudo apt-get install memcached

и получаем работающий memcached. Оказалось, что развеять все сомнения насчёт того, работает ли кеш на самом деле, нисколько не сложней! Достаточно запустить memcached в режиме "повышенной многословности":

memcached -vv -u USER_NAME

В этом режиме memcached ведёт лог в stdout обо всех операциях с кешем. Если паранойя совсем одолела, то можно раскомментировать соответствующую строку в конфиге /etc/memcached.conf:

# Be even more verbose (print client commands as well)
# -vv

Затем перезапустить демон и наблюдать за теми же логами через файл:

/etc/init.d/memcached restart
less /var/log/memcached.log

вторник, 13 марта 2012 г.

Подсчёт строк в репозитории Mercurial

Иногда хочется посмотреть на красивые циферки, даже если большого смысла они не несут. Например, посчитать число строк в проекте. Если вы используете Mercurial, то сделать это можно одной командой:

$ hg locate -0 | xargs -0 wc -l

Хотя, наверняка в других VCS есть аналог hg locate. Этот метод отлично работает для репозиториев без бинарных данных и переваривает файлы с пробелами в именах благодаря аргументу -0. Если же у вас вдруг в репозитории имеются какие-то бинарники, картинки или шрифты например, то их можно исключить с помощью аргумента -X:

$ hg locate -0 -X website/static | xargs -0 wc -l

Ещё один метод исключения, более гибкий:

$ hg locate | grep -Eiv '\.(png|jpg|tiff)' | tr "\n" "\0" | xargs -0 wc -l

Вместо пространного объяснения использованных опций в предыдущем однострочнике приведу его копию с длинным ключами:

$ hg locate \
  | grep --extended-regexp \
         --ignore-case \
         --invert-match \
         '\.(png|jpg|tiff)' \
  | tr "\n" "\0" \
  | xargs --null wc --lines

Также, может пригодиться явное задание ревизии для locate с помощью стандартного для Mercurial аргумента -r.

В конце пример работы приведённых команд: