Мониторинг статистики Django проектов с помощью Pinba на Debian GNU/Linux

от автора

В данном топике, будет рассказано о пошаговой настройке и конфигурации проекта и сервера с использованием связки pinba-engine + pinboard + django-pinba, для сбора и визулизации статистики проектов на django.

Все проекты являются бесплатными и их исходный код доступен на GitHub под лицензиями GPL или MIT.

Почему pinba?

В команде есть проекты, которые были написаны на php. Посещаемость у проектов достаточно высокая(свыше 200к). Есть очень много узких мест. Часто после каких-либо обновлений и новшеств, мы получали огромные тормоза, о которых мы узнавали не сразу. Нужно было решение, которое повернуто лицом к заказчику и программисту. Закачик очень не любит zabbix и munin. Решение нашлось. Это был pinboard и pinba. Заказчику понравилось. Он попросил прикрутить pinba на все проекты, которые крутились на django.

Поехали

Настройка состоит из нескольких частей:
1. Установка pinba-engine-mysql в качестве сервера для мониторинга(на Debian GNU/Linux)
2. Установка pinboard, для просмотра текущего состояния проекта
3. Установка батарейки django-pinba, для отправки статистики

1. Установка pinba-engine-mysql в качестве сервера для мониторинга(на Debian GNU/Linux)

1.1. Подключаем дополнительный репозиторий, от автора проекта pinba:

# echo "deb http://php53.dotdeb.org stable all" >> /etc/apt/sources.list && echo "deb-src http://php53.dotdeb.org stable all" >> /etc/apt/sources.list # gpg --keyserver keys.gnupg.net --recv-key 89DF5277 && gpg -a --export 89DF5277 | sudo apt-key add - # apt-get update && apt-get upgrade -y 

1.2. Установливаем MySQL и Pinba-Engine:

# apt-get install dialog mysql-server -y # apt-get install pinba-engine-mysql-5.5 -y 

1.3. Проверяем слушает ли pinba-engine-mysql нужный нам порт:

# netstat -uln|grep :30002 

2. Установка pinboard, для просмотра текущего состояния проекта

2.1. Устанавливаем все необходимые зависимости:

# apt-get install git-core nginx php5-fpm curl php-apc php5-cli php5-mysqlnd vim -y 

2.2. Клонируем проект и подтягиваем необходимые пакеты:

# cd /var/www/ && git clone git://github.com/intaro/pinboard.git && cd ./pinboard # git checkout v1.0 # curl -sS https://getcomposer.org/installer | php && php composer.phar install # cp config/parameters.yml.dist config/parameters.yml 

2.3. Настраиваем параметры подключения к БД:

# vim config/parameters.yml 

2.4. Мигрируем и регистрируем задания в кроне:

# ./console migrations:migrate # ./console register-crontab 

2.5. Настраиваем виртуальный хост nginx:

# touch /etc/nginx/sites-available/pinba.conf && ln -s /etc/nginx/sites-available/pinba.conf /etc/nginx/sites-enabled/ && vim /etc/nginx/sites-enabled/pinba.conf 

2.6. Вставляем конифигурацию вирутального хоста и указываем необходимый server_name:

server {     listen 80;     server_name pinboard.example.com;     root /var/www/pinboard/web;      location = / {         try_files @site @site;     }      location / {         try_files $uri $uri/ @site;     }      location ~ \.php$ {        return 404;     }      location @site {         fastcgi_pass unix:/var/run/php5-fpm.sock;         include fastcgi_params;         fastcgi_param  SCRIPT_FILENAME $document_root/index.php;         fastcgi_param HTTPS $https if_not_empty;     }      location ~ /\.(ht|svn|git) {         deny  all;     } } 

2.7. Перезагружаем демон nginx:

# /etc/init.d/nginx restart 

2.8. Добавляем конфигурацию тайм-зоны в php.ini:

# sed -i 's/;date.timezone =/date.timezone = Europe\/Moscow/g' /etc/php5/cli/php.ini /etc/php5/fpm/php.ini 

2.9. Проверим работу скрипта, прописанного в кроне:

# /var/www/pinboard/src/Pinboard/Command/../../../console aggregate 

Если скрипт выполнил работу без ошибок, значит все работает верно. На этом настройка pinboard закончена.

3. Установка батарейки django-pinba, для отправки статистики

3.1. Установим батарейку:

$ pip install django-pinba 

3.2. Откроем файл настройки settings.py и добавим django-pinba в MIDDLEWARE_CLASSES:

MIDDLEWARE_CLASSES = (     'pinba.middleware.PinbaMiddleware',     ... ) 

3.3. Укажем настройки нашего сервера с pinba-engine:

PINBA_SERVER = '192.168.55.11' PINBA_PORT = 30002 PINBA_ENABLED = True 

Желательно не держать статистику на одном сервере с проектом.

Заключение

Теперь можно открыть в окне браузера наш сайт, подождать некоторое время, которое было указано в crontab для pinboard, и любоваться красивыми графиками. Нагрузку для теста, можно создать с помощью ab или wget.

Интерфейс выглядит следующим образом:
image

ссылка на оригинал статьи http://habrahabr.ru/post/200128/


Комментарии

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *