Инструкция по обновлению Monq до версии 7.1.0
Предыдущая версия Monq: 7.0.2
В обновлении:
Продукт | Новая версия |
---|---|
pl | 7.1.0 |
sm | 7.1.0 |
cl | 7.1.0 |
fm | 7.1.0 |
plugins | 7.1.0 |
Уровень простоя - без простоя.
Релиз Monq 7.1.0 - Базовая информация
Релиз включает обновление различных модулей Monq. Если установлен только определенный набор модулей, например: pl и cl, то разделы с остальными модулями можно проигнорировать.
Проведение миграции 7.0.2 -> 7.1.0
Для запуска обновления требуется скачать клиент управления Monq monqctl и выполнить конфигурацию контекста monqctl, если ранее этого не делалось.
Минимальная версия monqctl: 1.4.0
Примечание: можно настроить 2 контекста для stage и production одновременно.
Примечание 2: токен для доступа в Monq ReleaseHub для скачивания обновления требуется получить, обратившись в поддержку Monq, либо из письма с регистрацией лицензии.
Выполнить предрелизную подготовку
1. Проверить контекст monqctl и статус реестра микросервисов
# Просмотреть текущий контекст, с которым работает monqctl.
monqctl config current-context
# Просмотреть статус реестра микросервисов из контекста.
monqctl registry get status
# Просмотреть статус сервисов в реестре микросервисов из контекста.
monqctl registry get services
Примечание:
В ответе на команду
monqctl registry get status
вывод будет содержать-------------------------
Consul | Failed
-------------------------На данном этапе можно проигнорировать. Сервис Consul добавлен только для возможности получить адрес и токен monqctl, который формирует файл доступа для программы-мигратора. Но для Consul в реестре микросервисов не реализованы методы генерирования шаблонов микросервисов, поэтому и выбрасывается ошибка валидации. Будет исправлено в последующих версиях.
2. Установить контекст релиза, с которым будет работать monqctl в рамках контекста установленного Monq
Команда при этом скачивает и подготавливает релиз:
monqctl release use-version 7.1.0 --product=monq
# Требуется выполнить экспорт релиза в папку
monqctl release version export 7.1.0 --product=monq --dest=<export directory>
# Выполнить команду `use-version` с аргументом `--sourceDir`.
monqctl release use-version 7.1.0 --product=monq --sourceDir=<папка с экспортированным обновлением>
Monq Platform (pl)
Выполнить перекачку контейнеров в Docker репозиторий обновляемого экземпляра Monq
monqctl release update images --module=pl
Выполнить конфигурацию баз данных микросервисов
monqctl release update db pgsql --module=pl --microservice=pl-i18n-service --file pl-i18n-service.sql
Выполнить конфигурацию микросервисов в реестре для микросервисов из обновления и применить шаблоны в Kubernetes
monqctl release update microservices --module=pl
Обновить существующие и установить новые библиотеки автоматона
monqctl release update automaton-libraries --module=pl --file=automaton-libs/automaton.core.import
monqctl release update automaton-libraries --module=pl --file=automaton-libs/automaton.cmdb.import
monqctl release update automaton-libraries --module=pl --file=automaton-libs/automaton.cl.import
При ошибке HTTP 500 и сообщении в теле ответа "Operation timeout exception" повторить команды.
Перезапустить микросервисы автоматон v2
monqctl release exec shell --module=pl --file=restart_microservice.sh --arguments="pl-automaton-v2-processor-service"
monqctl release exec shell --module=pl --file=restart_microservice.sh --arguments="pl-automaton-v2-processor-service-runner"
Сбросить кэш для микросервисов
monqctl instance clear cache --microservice=pl-i18n-service
Monq Service Monitor (sm)
Выполнить перекачку контейнеров в Docker репозиторий обновляемого экземпляра Monq
monqctl release update images --module=sm
Выполнить конфигурацию баз данных микросервисов
monqctl release update db pgsql --module=sm --microservice=sm-signals-service --file sqls/sm-signals-service.sql
Выполнить конфигурацию микросервисов в реестре для микросервисов из обновления и применить шаблоны в Kubernetes
monqctl release update microservices --module=sm
Monq Collector (cl)
Выполнить перекачку контейнеров в Docker репозиторий обновляемого экземпляра Monq
monqctl release update images --module=cl
Выполнить конфигурацию микросервисов в реестре для микросервисов из обновления и применить шаблоны в Kubernetes
monqctl release update microservices --module=cl
Test Forge (fm)
Выполнить перекачку контейнеров в Docker репозиторий обновляемого экземпляра Monq
monqctl release update images --module=fm
Выполнить конфигурацию микросервисов в реестре для микросервисов из обновления и применить шаблоны в Kubernetes
monqctl release update microservices --module=fm
Выполнить обновление плагинов системного агента
kubectl config current-context
namespace="" # указать K8s Namespace. По умолчанию, production. Для STAGE контуров - staging.
monq_agent=$(kubectl get po -n ${namespace} -l app=pl-monq-agent -o=jsonpath='{.items[0].metadata.name}')
plugins="zabbixEventsDataFlow/v1.4.0"
mkdir ./agent-plugins
cd ./agent-plugins
kubectl exec -it -n ${namespace} ${monq_agent} -- mkdir -p /storage/plugins
for plugin in ${plugins}; do
pluginName=$(echo ${plugin} | awk -F'/' '{print $1}')
wget https://downloads.monq.ru/agent-plugins/${plugin}/${pluginName}.zip
unzip ${pluginName}.zip
rm -f ${pluginName}.zip
kubectl cp ${pluginName} ${namespace}/${monq_agent}:/storage/plugins
rm -rf ${pluginName}
done
kubectl delete po -n ${namespace} -l app=pl-monq-agent
Проверка:
В логе микросервиса pl-monq-agent должны отобразится загруженные плагины правильных версий
Installing 0 certificates from /certs ...
Loading plugins from /storage/plugins...
...
[Zabbix - Events Data Flow v1.4.0.0] was loaded.
...
11 plugins was loaded.