Обновление

Перед нужно делать резервную копию.

См. также: политика совместимости версий.

Обновление изолированного экземпляра

  1. Записать в файл .env строку с версией:

    VERSION=vXX.XX
    

    Здесь vXX.XX – целевая версия (например: v20.08 или v20.12.1).

  2. Загрузить актуальный Compose-файл:

    wget https://docs.mitigator.ru/vXX.XX/dist/docker-compose.yml
    

    Здесь vXX.XX – целевая мажорная версия (например: v20.08 или v20.12).

    Если в нем были сделаны правки для адаптеров Mellanox, воспроизвести их в новой версии файла.

  3. Совершить вход в хранилище образов со своими учетными данными:

    docker login docker.mitigator.ru
    
  4. Скачать образы:

    docker-compose pull
    
  5. Перезапустить все компоненты Mitigator´а:

    systemctl restart mitigator
    

Обновление кластера с общим нерезервированным хранилищем

  1. Остановить все Mitigator´ы:

    systemctl stop mitigator
    
  2. На всех экземплярах записать в файл .env строку с версией:

    VERSION=vXX.XX
    

    Здесь vXX.XX – целевая версия (например: v20.08 или v20.12.1).

  3. На всех экземплярах скачать актуальный docker-compose.yml:

    wget https://docs.mitigator.ru/vXX.XX/dist/docker-compose.yml
    

    Здесь vXX.XX – целевая мажорная версия (например: v20.08 или v20.12).

    Если в нем были сделаны правки для адаптеров Mellanox, воспроизвести их в новой версии файла.

  4. На всех экземплярах, кроме базового, скачать актуальный файл docker-compose.worker.yml:

    wget https://docs.mitigator.ru/dist/multi/docker-compose.worker.yml \
       -O docker-compose.worker.yml
    
  5. На базовом экземпляре включить Postgres:

    docker-compose up -d postgres
    
  6. Выполнить на всех экземплярах последовательно, начиная с лидера:

    docker-compose up -d
    

Обновление кластера с внутренним отказоустойчивым хранилищем

  1. Остановить все Mitigator´ы, на которых Postgres работает в режиме standby, после чего остановить экземпляр с Postgres в режиме active:

    systemctl stop mitigator
    
  2. На всех экземплярах записать в файл .env строку с версией:

    VERSION=vXX.XX
    

    Здесь vXX.XX – целевая версия (например: v20.08 или v20.12.1).

  3. На всех экземплярах скачать актуальный docker-compose.yml:

    wget https://docs.mitigator.ru/vXX.XX/dist/docker-compose.yml
    

    Здесь vXX.XX – целевая мажорная версия (например: v20.08 или v20.12).

    Если в нем были сделаны правки для адаптеров Mellanox, воспроизвести их в новой версии файла.

  4. Включить экземпляр с Postgres в режиме active, после чего включить все Mitigator´ы, с Postgres в режиме standby:

    docker-compose up -d
    

Обновление кластера с внешним отказоустойчивым хранилищем

Шаги 1, 7 и 8 зависят от фактической организации СУБД на внешнем сервере.

  1. Отключить для всех экземпляров доступ к БД.

  2. На всех экземплярах записать в файл .env строку с версией:

    VERSION=vXX.XX
    

    Здесь vXX.XX – целевая версия (например: v20.08 или v20.12.1).

  3. На всех экземплярах скачать актуальный docker-compose.yml:

    wget https://docs.mitigator.ru/vXX.XX/dist/docker-compose.yml
    

    Здесь vXX.XX – целевая мажорная версия (например: v20.08 или v20.12).

    Если в нем были сделаны правки для адаптеров Mellanox, воспроизвести их в новой версии файла.

  4. Совершить вход в хранилище образов со своими учетными данными:

    docker login docker.mitigator.ru
    
  5. Скачать образы:

    docker-compose pull
    
  6. Перезапустить все компоненты Mitigator´а:

    systemctl restart mitigator
    
  7. Выполнить необходимые миграции БД.

  8. Включить доступ к БД для всех экземпляров.