RabbitMQ — программный брокер сообщений на основе стандарта AMQP — тиражируемое связующее программное обеспечение, ориентированное на обработку сообщений. Создан на основе системы Open Telecom Platform, написан на языке Erlang, в качестве движка базы данных для хранения сообщений использует Mnesia.
Состоит из сервера, библиотек поддержки протоколов HTTP, XMPP и STOMP[en], клиентских библиотек AMQP для Java и .NET Framework и различных плагинов (таких как плагины для мониторинга и управления через HTTP или веб-интерфейс или плагин «Shovel» для передачи сообщений между брокерами). Имеется реализация клиентов для доступа к RabbitMQ для целого ряда языков программирования, в том числе для Perl, Python, Ruby, PHP. Поддерживается горизонтальное масштабирование для построения кластерных решений.
Источник информации.
Данная статья применима к:
- ОС СН Смоленск 1.6
Установка пакета
Пакет rabbitmq-server, устанавливающий службу RabbitMQ, не входит в состав стандартного дистрибутива ОС СН Atra Linux SE Смоленск 1.6, поэтому для установки службы нужно подключить репозиторий Debian.
После подключения репозитория пакет может быть rabbitmq-server установлен с помощью графического менеджера пакетов или из командной строки командами
Настройка пакета
Настройка плагинов:
Добавление пользователя для RabbitMQ, задание пароля, назначение прав
rabbitmqctl set_user_tags user administrator && \
rabbitmqctl set_permissions -p / user ".*" ".*" ".*"
Для выполнения дальнейших настроек остановить службу:
Создать каталоги для работы с мандатными метками и назначить их владельцем автоматически созданного при установке пакета пользователя rabbitmq:
mkdir /opt/rabbitmq
mkdir /opt/rabbitmq/etc
mkdir /opt/rabbitmq/log
mkdir /opt/rabbitmq/run
chown -R rabbitmq:rabbitmq /opt/rabbitmq/
Отредактировать конфигурационный файл /etc/rabbitmq/rabbitmq-env.conf, добавив или изменив следующие строки (в параметре NODE_IP_ADDRESS указать ip-адрес сервера):
NODE_IP_ADDRESS=<IP-address>
NODE_PORT=5672
LOG_BASE=/opt/rabbitmq/log
HOME=/opt/rabbitmq
MNESIA_BASE=/var/lib/rabbitmq/mnesia
Переместить файлы настроек в ранее созданный каталог:
Отредактировать юнит запуска службы в /etc/systemd/system/multi-user.target.wants/rabbitmq-server.service, добавив в него параметр с нужной мандатной меткой:
Description=RabbitMQ Messaging Server
After=network.target
[Service]
PDPLabel=3:0:0
Type=simple
User=rabbitmq
SyslogIdentifier=rabbitmq
LimitNOFILE=65536
ExecStart=/usr/bin/rabbitmq-server
ExecStartPost=/usr/lib/rabbitmq/bin/rabbitmq-server-wait
ExecStop=/usr/bin/rabbitmqctl stop
[Install]
WantedBy=multi-user.target
После выполнения редактирования юнита запуска службы обновить конфигурацию для загрузки внесённых изменений:
Отредактировать файл запуска службы в /etc/init.d/rabbitmq-server, исправив пути к файлам:
....
INIT_LOG_DIR=/opt/rabbitmq/log
PID_FILE=/opt/rabbitmq/run/pid
...
Отредактировать запускающий файл /usr/lib/rabbitmq/bin/rabbitmq-script-wrapper, исправив пути к файлам журналов:
/usr/lib/rabbitmq/bin/rabbitmq-server "$@" > "/opt/rabbitmq/log/startup_log" 2> "/opt/rabbitmq/log/startup_err"
Отредактировать файл переменных по умолчанию /usr/lib/rabbitmq/bin/rabbitmq-defaults. Изменить пути до файлов ENABLED_PLUGINS_FILE, CONF_ENV_FILE:
...
ENABLED_PLUGINS_FILE=${SYS_PREFIX}/opt/rabbitmq/etc/enabled_plugins
...
CONF_ENV_FILE=${SYS_PREFIX}/opt/rabbitmq/etc/rabbitmq-env.conf
...
Назначить уровень мандатных меток на директории и файлы
pdpl-file -Rv 3:0:0:CCNRA /opt/rabbitmq
pdpl-file -v 3:0:0:CCNRA /usr
pdpl-file -v 3:0:0:CCNRA /usr/lib
pdpl-file -Rv 3:0:0:CCNRA /usr/lib/rabbitmq
pdpl-file -v 3:0:0:CCNRA /var
pdpl-file -v 3:0:0:CCNRA /var/lib
pdpl-file -Rv 3:0:0:CCNRA /var/lib/rabbitmq
Создать файлы журналов и назначить на них права доступа:
chown -R rabbitmq:rabbitmq /opt/rabbitmq/
Запустить службу: