Новейшая версия Discourse ломает пересборку, порт Redis уже занят

ОС: Ubuntu 20.04
Сервер: vServer, 4 ядра, 16 ГБ
Диск: SSD 160 ГБ

Недавно я обновился до последней версии Discourse. Теперь я столкнулся с проблемой: Discourse сообщает, что порт 6379 занят, и поэтому контейнер не может быть собран:

Когда я проверяю все занятые порты, этот порт свободен:

Что-то в проверке Discourse не распознаёт, что порт свободен.
В Docker я вижу, что запущен только контейнер Discourse, а всё остальное не работает:

Эта проблема действительно превратилась в парадокс.
Discourse запускает процесс redis-server в Docker, а затем падает, потому что процесс уже был запущен:

У меня на хосте работает основная установка Redis, но она использует порт 6800, поэтому она не должна мешать.

Кажется, что проверка не проходит сама по себе, потому что Redis успешно запускается, а затем сообщает об ошибке: адрес занят:

Не могли бы вы поделиться своим файлом app.yml?

Да, конечно, спасибо, что посмотрели :smiley:. Вот мой файл app.yml:

## это шаблон контейнера Docker Discourse «всё в одном», автономный
##
## После внесения изменений в этот файл вы ОБЯЗАНЫ выполнить пересборку
## /var/discourse/launcher rebuild app
##
## БУДЬТЕ *ОЧЕНЬ* ОСТОРОЖНЫ ПРИ РЕДАКТИРОВАНИИ!
## YAML-ФАЙЛЫ ЧРЕЗВЫЧАЙНО-ЧРЕЗВЫЧАЙНО ЧУВСТВИТЕЛЬНЫ К ОШИБКАМ В ПРОБЕЛАХ ИЛИ ВЫРАВНИВАНИИ!
## при необходимости проверяйте этот файл на сайте http://www.yamllint.com/

templates:
  - "templates/postgres.template.yml"
  - "templates/redis.template.yml"
  - "templates/web.template.yml"
  - "templates/web.ratelimited.template.yml"
## Раскомментируйте эти две строки, если хотите добавить Lets Encrypt (https)
  #- "templates/web.ssl.template.yml"
  #- "templates/web.letsencrypt.ssl.template.yml"

## какие TCP/IP-порты должен открывать этот контейнер?
## Если вы хотите, чтобы Discourse использовал один порт с другим веб-сервером, например Apache или nginx,
## см. https://meta.discourse.org/t/17247 для деталей
expose:
  - "12080:80"   # http
  - "12443:443" # https

params:
  db_default_text_search_config: "pg_catalog.english"

  ## Установите db_shared_buffers максимум в 25% от общего объёма памяти.
  ## будет установлено автоматически при загрузке на основе обнаруженной оперативной памяти, либо вы можете переопределить
  db_shared_buffers: "4096MB"

  ## может улучшить производительность сортировки, но увеличивает потребление памяти на каждое подключение
  #db_work_mem: "40MB"

  ## Какую ревизию Git должен использовать этот контейнер? (по умолчанию: tests-passed)
  #version: tests-passed

env:
  LANG: en_US.UTF-8
  # DISCOURSE_DEFAULT_LOCALE: en

  ## Сколько одновременных веб-запросов поддерживается? Зависит от объёма памяти и количества ядер процессора.
  ## будет установлено автоматически при загрузке на основе обнаруженных процессоров, либо вы можете переопределить
  UNICORN_WORKERS: 8

  ## TODO: Доменное имя, на которое будет реагировать этот экземпляр Discourse
  DISCOURSE_HOSTNAME: discourse.forum

  ## Раскомментируйте, если хотите, чтобы контейнер запускался с тем же
  ## именем хоста (опция -h), что указано выше (по умолчанию "$hostname-$config")
  #DOCKER_USE_HOSTNAME: true

  ## TODO: Список email-адресов через запятую, которые станут администраторами и разработчиками
  ## при первой регистрации, например 'user1@example.com,user2@example.com'
  DISCOURSE_DEVELOPER_EMAILS: 'developer@email'

  ## TODO: SMTP-сервер, используемый для проверки новых учётных записей и отправки уведомлений
  DISCOURSE_SMTP_ADDRESS: mailserver
  DISCOURSE_SMTP_PORT: 587
  DISCOURSE_SMTP_USER_NAME: email@email
  DISCOURSE_SMTP_PASSWORD: "****"
  #DISCOURSE_SMTP_AUTHENTICATION: plain
  #DISCOURSE_SMTP_ENABLE_START_TLS: true           # (опционально, по умолчанию true)

  ## Если вы добавили шаблон Lets Encrypt, раскомментируйте ниже, чтобы получить бесплатный SSL-сертификат
  #LETSENCRYPT_ACCOUNT_EMAIL: me@example.com

  ## Адрес CDN для этого экземпляра Discourse (настроен на извлечение)
  ## см. https://meta.discourse.org/t/14857 для деталей
  #DISCOURSE_CDN_URL: //discourse-cdn.example.com

## Контейнер Docker не сохраняет состояние; все данные хранятся в /shared
volumes:
  - volume:
      host: /var/discourse/shared/standalone
      guest: /shared
  - volume:
      host: /var/discourse/shared/standalone/log/var-log
      guest: /var/log

## Плагины размещаются здесь
## см. https://meta.discourse.org/t/19157 для деталей
hooks:
  after_code:
    - exec:
        cd: $home/plugins
        cmd:
          - git clone https://github.com/discourse/docker_manager.git
          - git clone https://github.com/angusmcleod/discourse-question-answer.git
          - git clone https://github.com/discourse/discourse-solved.git
          - git clone https://github.com/discourse/discourse-voting.git
          - git clone https://github.com/gdpelican/retort.git
          - git clone https://github.com/davidtaylorhq/discourse-whos-online.git
          - git clone https://github.com/vinkas0/discourse-navigation.git
          - git clone https://github.com/discourse/discourse-spoiler-alert.git
          - git clone https://github.com/iunctis/discourse-formatting-toolbar.git
          - git clone https://github.com/discourse/discourse-tooltips.git
          - git clone https://github.com/gdpelican/babble.git
          - git clone https://github.com/paviliondev/discourse-quick-messages.git
          - git clone https://github.com/worldismine/PM-Scanner.git
          - git clone https://github.com/paviliondev/discourse-ratings.git
          - git clone https://github.com/discourse/discourse-calendar.git
          - git clone https://github.com/jannolii/discourse-topic-trade-buttons.git

## Любые пользовательские команды для запуска после сборки
run:
  - exec: echo "Начало пользовательских команд"
  ## Если вы хотите установить адрес электронной почты в поле 'От' для вашей первой регистрации, раскомментируйте и измените:
  ## После получения первого письма о регистрации снова закомментируйте строку. Выполняется только один раз.
  ##- exec: rails r "SiteSetting.notification_email='email@email"
  - exec: echo "Конец пользовательских команд"

Можете также опубликовать полный вывод пересборки?

Я почти уверен, что строки, которые вы видите, появляются при каждой пересборке уже очень давно и никак не блокируют процесс, так как мы просто проверяем, запущен ли Redis, в двух разных хуках. Ваша проблема находится в другом месте.

Конечно. Если понадобятся другие логи, я могу их предоставить :slight_smile:
Я разместил их на Pastebin, так как они занимают более 3226 строк и превышают лимит поста на форуме: Discourse Rebuild Log - Pastebin.com

Этот вывод показывает успешную пересборку…

Ваш сайт не работает на порту 12080?

Да, сайт успешно перестроен снова.
Я выяснил причину проблемы, из-за которой сайт не загружался у меня.
Ошибка была в SSL-сертификате обратного прокси, который не продлился автоматически, из-за чего сайт не мог загрузить изображения, что заставило меня предположить, что Redis-кэш не работает :man_facepalming:

В сборке отображается уведомление, но сервер Redis работает нормально.
После продления SSL-сертификата сайт снова заработал.

Спасибо за вашу поддержку и извините за мою глупость :sweat_smile: