Быстрый старт
Данное руководство предназначено для ознакомления с продуктом Tarantool Queue Enterprise, функциональность MQ (далее по тексту – TQE(MQ)).
В руководстве приведены варианты быстрой установки и запуска приложения – локально и c помощью Docker. Информация об установке TQE(MQ) для промышленного использования будет приведена в "Руководстве по установке".
Далее описываются шаги по настройке модуля API (gRPC-сервера) и параметров подключения к очереди. После этого проверяется корректность установки и работоспособности приложения.
- Системные требования
- Установка экземпляра
- Запуск приложения
- Настройка конфигурации после установки
- Проверка установки приложения
TQE(MQ) поддерживает установку на следующие операционные системы (ОС):
- РЕД ОС 7.3;
- Astra Linux.
Также возможно установка на другие ОС – ALTLinux, AlmaLinux, Ubuntu, CentOS – но полноценная работоспособность не гарантируется.
Для работы приложения необходима библиотека glibc версии 2.17-260.el7_6.6 и выше. Для проверки текущей установленной
версии glibc и обновления необходимо выполнить:
$ rpm -q glibc
$ yum update glibc
- Распакуйте архив с дистрибутивом TQE(MQ):
$ tar -xzf <имя_архива>.tar.gz
- Перейдите в директорию с распакованным дистрибутивом:
$ cd message-queue-ee
- Для запуска ядра TQE(MQ) выполните команду:
$ tt start
Ответ должен иметь вид:
• Starting an instance [message-queue-ee:app]...
Теперь убедимся, что приложение было успешно запущено:
$ tt statusINSTANCE STATUS PID MODEmessage-queue-ee:app RUNNING 10841 RO
- Далее необходимо настроить конфигурацию хранилища данных для очереди сообщений.
В данном случае используются преднастроенные файлы конфигурации instances.yml и config.yml. Они поставляются в дистрибутиве и после распаковки находятся в корневой директории message-queue-ee/.
В них определяется топология кластера – какие узлы какую роль будут выполнять, а также задается группировка узлов по наборам реплик (replica sets) для резервирования данных.
Также на этом шаге выполняется инициализация базы данных в кластере.
$ tt replicaset vshard bootstrap .
Ответ должен иметь вид:
• Discovery application...Orchestrator: centralized configReplicasets state: bootstrapped• appFailover: offMaster: single• app 127.0.0.1:3301 rw• Bootstrapping vshard• Done.
Теперь нода с приложением должна перейти в режим работы RW:
$ tt statusINSTANCE STATUS PID MODEmessage-queue-ee:app RUNNING 10841 RW
Помимо варианта локального запуска, приведенного выше, можно запустить приложение в Docker.
Это удобный способ запустить несколько экземпляров в кластерной конфигурации с помощью одной команды.
Для определения конфигурации приложения и параметров запуска также используется преднастроенный файл compose.yaml
(находится в корневой директории message-queue-ee/).
$ docker-compose up -d --build
- Определение параметров модуля API (gRPC-сервера):
$ cat > config.service.yml <<EOFapp_name: MESSAGE_QUEUE_EE_APIapp_version: testcore_host: 0.0.0.0core_port: 18184grpc_host: 0.0.0.0grpc_port: 18182producer:enabled: truetarantool:user: userpass: passqueues:queue:connections:routers:- "localhost:3301"consumer:enabled: truepolling_timeout: 500mstarantool:user: userpass: passqueues:queue:connections:storage-1:- "localhost:3301"EOF
Отсутствие ошибок в терминале сигнализирует о корректной настройке модуля API (gRPC-сервера).
- Запуск модуля API (gRPC-сервера):
$ bin/message-queue-ee -d -config config.service.yml
В директории message-queue-ee/scripts расположены скрипты, с помощью которых можно проверить работоспособность приложения.
Для работы скриптов требуется установить утилиту grpcurl.
- Работа установленного приложения проверяется командой:
$ ./scripts/test.sh localhost:18182Test passed.
Сообщение Test passed. сообщает о корректной установке и работе дистрибутива.
- Если существуют ошибки в установке или работе приложения, то при выполнении скрипта
test.shбудет выдано подобное сообщение:
$ ./scripts/test.sh localhost:18182Test failed: message id expected "1", got "2".
Оно информирует о возникновении проблем и необходимости убедиться в корректности настроек на этапе конфигурации приложения.
Проверка публикации в очередь сообщений выполняется командой:
$ grpcurl -plaintext -d '{"queue": "queue", "messages": [{"payload": "TestGeneratedMessage", "metadata": [{"key": "date", "value": "121225"}]}]}' \localhost:18182 tarantool.queue_ee.Producer/Produce
Ожидаемый ответ:
{"ids": ["7358127929391316992"],"isDuplicates": [false]}
Для проверки подписки нужно выполнить следующую последовательность действий. Откройте двунаправленный стрим командой:
$ grpcurl -plaintext -d @ \localhost:18182 tarantool.queue_ee.ConsumerService/Subscribe
Далее нужно отправить запрос на подписку:
{"subscribe_request": {"queue": "queue", "cursor": ""}}
Ожидаемый ответ:
{"notifications": [{"cursor": "AQAAAAAAAAAJAAAAAAAAAHN0b3JhZ2UtMQAAwICKOwxm","message": {"id": "7358127929391316992","queue": "queue","payload": "SomeData","metadata": [{"key": "date","value": "121225"}],"timestamp": "1753167571459351000"}},]}
Совпадение идентификаторов сообщения (поля id) при выполнении публикации сообщения в очереди
и подписки на нее говорит о корректном завершении установки приложения и настройки очереди сообщений.