Оглавление
Информация |
---|
RabbitMQ — программный брокер сообщений на основе стандарта AMQP — тиражируемое связующее программное обеспечение, ориентированное на обработку сообщений. Создан на основе системы Open Telecom Platform, написан на языке Erlang, в качестве движка базы данных для хранения сообщений использует Mnesia. Состоит из сервера, библиотек поддержки протоколов HTTP, XMPP и STOMP[en], клиентских библиотек AMQP для Java и .NET Framework и различных плагинов (таких как плагины для мониторинга и управления через HTTP или веб-интерфейс или плагин «Shovel» для передачи сообщений между брокерами). Имеется реализация клиентов для доступа к RabbitMQ для целого ряда языков программирования, в том числе для Perl, Python, Ruby, PHP. Поддерживается горизонтальное масштабирование для построения кластерных решений. |
Информация |
---|
Данная статья применима к:
|
Установка пакета
Пакет rabbitmq-server, устанавливающий службу RabbitMQ, не входит в состав стандартного дистрибутива ОС СН Atra Linux SE Смоленск 1.6, поэтому для установки службы нужно подключить репозиторий Debian.
После подключения репозитория пакет может быть rabbitmq-server установлен с помощью графического менеджера пакетов или из командной строки командами
Command |
---|
apt update && apt install rabbitmq-server |
Настройка пакета
Настройка плагинов:
Command |
---|
rabbitmq-plugins enable rabbitmq_management |
Добавление пользователя для RabbitMQ, задание пароля, назначение прав
Command |
---|
rabbitmqctl add_user user password && \ rabbitmqctl set_user_tags user administrator && \ rabbitmqctl set_permissions -p / user ".*" ".*" ".*" |
Для выполнения дальнейших настроек остановить службу:
Command |
---|
systemctl stop rabbitmq-server |
Информация |
---|
Остановка службы может занимать довольно много времени, это нормально. |
Создать каталоги для работы с мандатными метками и назначить их владельцем автоматически созданного при установке пакета пользователя rabbitmq:
Command |
---|
mkdir /opt/rabbitmq chown -R rabbitmq:rabbitmq /opt/rabbitmq/ |
Отредактировать конфигурационный файл /etc/rabbitmq/rabbitmq-env.conf, добавив или изменив следующие строки (в параметре NODE_IP_ADDRESS указать ip-адрес сервера):
Информация |
---|
NODENAME=example-rabbit NODE_IP_ADDRESS=<IP-address> NODE_PORT=5672 LOG_BASE=/opt/rabbitmq/log HOME=/opt/rabbitmq MNESIA_BASE=/var/lib/rabbitmq/mnesia |
Переместить файлы настроек в ранее созданный каталог:
Command |
---|
mv /etc/rabbitmq/* /opt/rabbitmq/etc/ |
Отредактировать юнит запуска службы в /etc/systemd/system/multi-user.target.wants/rabbitmq-server.service, добавив в него параметр с нужной мандатной меткой:
Информация |
---|
[Unit] 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 |
После выполнения редактирования юнита запуска службы обновить конфигурацию для загрузки внесённых изменений:
Command |
---|
systemctl daemon-reload |
Отредактировать файл запуска службы в /etc/init.d/rabbitmq-server, исправив пути к файлам:
Информация |
---|
.... |
Отредактировать запускающий файл /usr/lib/rabbitmq/bin/rabbitmq-script-wrapper, исправив пути к файлам журналов:
Информация |
---|
if [ `id -u` = `id -u rabbitmq` -a "$SCRIPT" = "rabbitmq-server" ] ; then /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:
Информация |
---|
... |
Назначить уровень мандатных меток на директории и файлы
Информация |
---|
pdpl-file -v 3:0:0:CCNRA /opt/ 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 |
Создать файлы журналов и назначить на них права доступа:
Command |
---|
touch /opt/rabbitmq/log/startup_log /opt/rabbitmq/log/startup_err |
Запустить службу:
Информация |
---|
systemctl start rabbitmq-server |