Не могу снова запустить Discourse

Привет:
Я запускал Discourse в течение последних месяцев без проблем.
Мне пришлось сбросить хост, и теперь я не могу снова запустить Discourse.

/var/discourse# ./launcher rebuild app

Убедитесь, что launcher актуален

Получение origin

Launcher актуален

cat: 80:80: Нет такого файла или каталога

cat: 443:443: Нет такого файла или каталога

cd /pups && git pull && /pups/bin/pups --stdin

/usr/bin/docker: недопустимый формат ссылки: имя репозитория должно быть в нижнем регистре.

См. '/usr/bin/docker run --help'.

cat: cids/app_bootstrap.cid: Нет такого файла или каталога

"docker rm" требует как минимум 1 аргумент.

См. 'docker rm --help'.

Использование: docker rm [OPTIONS] КОНТЕЙНЕР [КОНТЕЙНЕР...]

Удаление одного или нескольких контейнеров

rm: не удалось удалить «cids/app_bootstrap.cid»: Нет такого файла или каталога

** СБОЙ ПРИ ИНИЦИАЛИЗАЦИИ ** прокрутите вверх и поищите более ранние сообщения об ошибках, их может быть несколько.

./discourse-doctor может помочь диагностировать проблему.

Команды “run” и “bootstrap” делают одно и то же :frowning:

Doctor говорит:

./discourse-doctor 
DISCOURSE DOCTOR Вс Фев 16 11:59:15 CET 2020
ОС: Linux XXXXXXXXXXXX 3.16.0-7-amd64 #1 SMP Debian 3.16.59-1 (2018-10-03) x86_64 GNU/Linux


Найден containers/app.yml

==================== НАСТРОЙКИ YML ====================
awk: недопустимый параметр: --field-separator=:
DISCOURSE_HOSTNAME=
awk: недопустимый параметр: --field-separator=:
SMTP_ADDRESS=
awk: недопустимый параметр: --field-separator=:
DEVELOPER_EMAILS=
awk: недопустимый параметр: --field-separator=:
SMTP_PASSWORD=
awk: недопустимый параметр: --field-separator=:
SMTP_PORT=
awk: недопустимый параметр: --field-separator=:
SMTP_USER_NAME=
awk: недопустимый параметр: --field-separator=:
LETSENCRYPT_ACCOUNT_EMAIL=

==================== ИНФОРМАЦИЯ О DOCKER ====================
ВЕРСИЯ DOCKER: Docker version 18.06.3-ce, build d7080c1

ПРОЦЕССЫ DOCKER (docker ps -a)

IDENTIFIKATOR КОНТЕЙНЕРА        ИЗОБРАЖЕНИЕ               КОМАНДА             СОЗДАН              СТАТУС              ПОРТЫ               ИМЯ

==================== СЕРЬЁЗНАЯ ПРОБЛЕМА!!!! ====================
app не запущен!
Попытка пересборки
==================== ЖУРНАЛ ПЕРЕСБОРКИ ====================
Убедитесь, что launcher актуален
Получение origin
Launcher актуален
cat: 80:80: Нет такого файла или каталога
cat: 443:443: Нет такого файла или каталога
cd /pups && git pull && /pups/bin/pups --stdin
/usr/bin/docker: недопустимый формат ссылки: имя репозитория должно быть в нижнем регистре.
См. '/usr/bin/docker run --help'.
cat: cids/app_bootstrap.cid: Нет такого файла или каталога
"docker rm" требует как минимум 1 аргумент.
См. 'docker rm --help'.

Использование:  docker rm [OPTIONS] КОНТЕЙНЕР [КОНТЕЙНЕР...]

Удаление одного или нескольких контейнеров
rm: не удалось удалить «cids/app_bootstrap.cid»: Нет такого файла или каталога
** СБОЙ ПРИ ИНИЦИАЛИЗАЦИИ ** прокрутите вверх и поищите более ранние сообщения об ошибках, их может быть несколько.
./discourse-doctor может помочь диагностировать проблему.
==================== КОНЕЦ ЖУРНАЛА ПЕРЕСБОРКИ ====================
Не удалось пересобрать app.

Проверка вашего доменного имени . . .

Соединение с 443 успешно.
Возможно, вам следует удалить все нестандартные плагины и выполнить пересборку.
Попытка перезапуска существующего контейнера . . . 

cat: 80:80: Нет такого файла или каталога
cat: 443:443: Нет такого файла или каталога
+ /usr/bin/docker run --shm-size=512m -d --restart=always '#<NoMethodError: undefined method `[]'\'' for false:FalseClass>' '#<NoMethodError: undefined method `[]'\'' for false:FalseClass>' -e LANG=en_US.UTF-8 -e RAILS_ENV=production -e UNICORN_WORKERS=4 -e UNICORN_SIDEKIQS=1 -e RUBY_GLOBAL_METHOD_CACHE_SIZE=131072 -e RUBY_GC_HEAP_GROWTH_MAX_SLOTS=40000 -e RUBY_GC_HEAP_INIT_SLOTS=400000 -e RUBY_GC_HEAP_OLDOBJECT_LIMIT_FACTOR=1.5 -e DISCOURSE_DB_SOCKET=/var/run/postgresql -e DISCOURSE_DB_HOST= -e DISCOURSE_DB_PORT= -e LETSENCRYPT_DIR=/shared/letsencrypt -e DISCOURSE_HOSTNAME=XXXXXXXXXXXX -e DISCOURSE_DEVELOPER_EMAILS=XXXXXXXXXXXX -e DISCOURSE_SMTP_ADDRESS=XXXXXXXXXXXX -e DISCOURSE_SMTP_PORT=587 -e DISCOURSE_SMTP_USER_NAME=XXXXXXXXXXXX -e DISCOURSE_SMTP_PASSWORD=XXXXXXXXXXXX -e DISCOURSE_SMTP_ENABLE_START_TLS=false -e LETSENCRYPT_ACCOUNT_EMAIL=XXXXXXXXXXXX '#<NoMethodError: undefined method `[]'\'' for false:FalseClass>' '#<NoMethodError: undefined method `[]'\'' for false:FalseClass>' -h vps659319-app -e DOCKER_HOST_IP=172.17.0.1 --name app -t '#<NoMethodError: undefined method `[]'\'' for false:FalseClass>' '#<NoMethodError: undefined method `[]'\'' for false:FalseClass>' -v /var/discourse/shared/standalone:/shared -v /var/discourse/shared/standalone/log/var-log:/var/log --mac-address 02:62:5b:d4:b7:80 local_discourse/app /sbin/boot
/usr/bin/docker: недопустимый формат ссылки: имя репозитория должно быть в нижнем регистре.
См. '/usr/bin/docker run --help'.
Не удалось перезапустить контейнер.


==================== ПЛАГИНЫ ====================
          - git clone https://github.com/discourse/docker_manager.git
          - git clone https://github.com/discourse/discourse-plugin-linkedin-auth.git
          - git clone https://github.com/discourse/discourse-oauth2-basic.git
          - git clone https://github.com/discourse/discourse-solved.git
          - git clone https://github.com/discourse/discourse-voting.git
          - git clone https://github.com/discourse/discourse-assign.git
          - git clone https://github.com/discourse/discourse-staff-notes.git
          - git clone https://github.com/discourse/discourse-checklist.git
          - git clone https://github.com/discourse/discourse-social-share.git
          - git clone https://github.com/rcfox/Discourse-LinkedIn-Sharing-Button.git
          - git clone https://github.com/BeXcellent/discourse-allowiframe.git

ПРЕДУПРЕЖДЕНИЕ:
Похоже, у вас есть неофициальные плагины.
Если у вас возникли проблемы, отключите их и попробуйте выполнить пересборку снова.

См. https://github.com/discourse/discourse/blob/master/lib/plugin/metadata.rb для официального списка.

========================================
Версия Discourse в : НЕ НАЙДЕНА
Версия Discourse в localhost: НЕ НАЙДЕНА


==================== ИНФОРМАЦИЯ О ПАМЯТИ ====================
ОЗУ (МБ): 2009

             total       used       free     shared    buffers     cached
Mem:          1962       1819        142         45         86        586
-/+ buffers/cache:       1146        815
Swap:         2047        190       1857

==================== ПРОВЕРКА СВОБОДНОГО МЕСТА НА ДИСКЕ ====================
---------- Свободное место на диске ОС ----------
Файловая система      Размер  Использовано  Доступно  Использ%  Смонтировано на
/dev/sda1        20G  9.1G  9.7G  49% /

==================== ИНФОРМАЦИЯ О ДИСКАХ ====================

Диск /dev/sdb: 50 ГиБ, 53687091200 байт, 104857600 секторов
Единицы: сектора по 1 * 512 = 512 байт
Размер сектора (логический/физический): 512 байт / 512 байт
Размер ввода-вывода (минимальный/оптимальный): 512 байт / 512 байт
Диск /dev/sda: 20 ГиБ, 21474836480 байт, 41943040 секторов
Единицы: сектора по 1 * 512 = 512 байт
Размер сектора (логический/физический): 512 байт / 512 байт
Размер ввода-вывода (минимальный/оптимальный): 512 байт / 512 байт
Тип метки диска: dos
Идентификатор диска: 0x7f0953e7

Устройство     Загрузочный  Начало      Конец  Сектора  Размер Id Тип
/dev/sda1  *     2048 41941883 41939836  20G 83 Linux

==================== КОНЕЦ ИНФОРМАЦИИ О ДИСКАХ ====================

==================== ТЕСТ ПОЧТЫ ====================
Для надёжного теста получите адрес на http://www.mail-tester.com/
Или просто отправьте тестовое сообщение себе.
Адрес электронной почты для теста почты? ('n' для пропуска) []: XXXXXXXXXXXX
Отправка письма на XXXXXXXXXXXX . . . 
Ошибка: Нет такого контейнера: app

Замена: SMTP_PASSWORD
Замена: LETSENCRYPT_ACCOUNT_EMAIL
Замена: DEVELOPER_EMAILS
Замена: DISCOURSE_DB_PASSWORD
Замена: Отправка письма на

==================== ГОТОВО! ====================

Вы можете просмотреть вывод этого скрипта с помощью 
LESS=-Ri less /tmp/discourse-debug.txt

НО СНАЧАЛА убедитесь, что вы знаете первые три команды ниже!!!

Команды, которые нужно знать при просмотре файла с помощью вышеуказанной команды (называемой 'less'): 
q              -- выход
/error<ENTER>  -- поиск слова 'error'
n              -- поиск следующего вхождения
g              -- переход в начало файла
f              -- переход на одну страницу вперёд
b              -- переход на одну страницу назад
G              -- переход в конец файла

Убедитесь, что настройки, выделенные Doctor, заполнены корректно и не пусты.

Например: DISCOURSE_HOSTNAME: mydomain.com (обратите внимание, разделителем должен быть :, а не =)

Вы можете проверить синтаксис с помощью онлайн-валидатора YML: http://www.yamllint.com/

этот файл не был изменен вообще… он такой же, как когда всё работало :frowning:
Я проверил строку за строкой, ошибок нет…

Вот он:

## это шаблон автономного контейнера 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"
  - "templates/web.socketed.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:#
  - "80:80"   # http
  - "443:443" # https

params:
  db_default_text_search_config: "pg_catalog.english"

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

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

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

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

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

  ## TODO: Доменное имя, на которое будет реагировать этот экземпляр Discourse
  ## Обязательно. Discourse не будет работать с обычным IP-адресом.
  DISCOURSE_HOSTNAME: 'XXXXXXXXXXXX'

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

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

  ## TODO: SMTP-сервер, используемый для проверки новых учётных записей и отправки уведомлений
  ## Адрес SMTP, имя пользователя и пароль обязательны
  ## ВНИМАНИЕ: символ '#' в пароле SMTP может вызвать проблемы!
  DISCOURSE_SMTP_ADDRESS: XXXXXXXXXXXX
  DISCOURSE_SMTP_PORT: 587
  DISCOURSE_SMTP_USER_NAME: XXXXXXXXXXXX
  DISCOURSE_SMTP_PASSWORD: "XXXXXXXXXXXX"
  DISCOURSE_SMTP_ENABLE_START_TLS: false           # (опционально, по умолчанию true)

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

  ## Адрес CDN (http или https) для этого экземпляра Discourse (настроен на загрузку)
  ## см. https://meta.discourse.org/t/14857 для деталей
  #DISCOURSE_CDN_URL: https://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/discourse/discourse-plugin-linkedin-auth.git
          - git clone https://github.com/discourse/discourse-oauth2-basic.git
          - git clone https://github.com/discourse/discourse-solved.git
          - git clone https://github.com/discourse/discourse-voting.git
          - git clone https://github.com/discourse/discourse-assign.git
          - git clone https://github.com/discourse/discourse-staff-notes.git
          - git clone https://github.com/discourse/discourse-checklist.git
          - git clone https://github.com/discourse/discourse-social-share.git
          - git clone https://github.com/rcfox/Discourse-LinkedIn-Sharing-Button.git
          - git clone https://github.com/BeXcellent/discourse-allowiframe.git

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

Попробуйте удалить символы ' в имени хоста и адресах электронной почты разработчиков

'XXXXXXXXXXXX'

Почему команда закомментирована?

#expose:#
  - "80:80"   # http
  - "443:443" # https

Это объясняет вывод об ошибке:

cat: 80:80: Нет такого файла или каталога
cat: 443:443: Нет такого файла или каталога

Но мне нужно, чтобы эти строки оставались на месте!

Прочитайте, что я сказал. Вы добавили #.

Должно быть:

expose:
  - "80:80"   # http
  - "443:443" # https

Я не сделал это так просто, потому что кто-то должен подумать, как могли возникнуть такие ошибки, если это правда?