最新のDiscourseバージョンでリビルドが壊れる、Redisポートが既に使用されています

OS: Ubuntu 20.04
サーバー: vServer 4 コア、16 GB
ディスク: SSD 160GB

最近、Discourse の最新バージョンにアップグレードしました。しかし、Discourse がポート 6379 が使用中であると報告し、コンテナをビルドできないという問題に直面しています:

使用中のすべてのポートを確認しましたが、そのポートは空いています:

Discourse のチェックのどこかが、ポートが空いていることを正しく認識できていないようです。
Docker では、Discourse コンテナのみが起動し、その他すべてが失敗していることが確認できます:

この問題は本当にパラドックスに発展してしまいました。
Discourse が Docker 内で redis-server の PID を開始すると、すでにプロセスが起動しているためクラッシュしてしまいます。

ホスト側にはメインの Redis インストールが動作していますが、ポート 6800 を使用しているため、干渉するはずがありません。

どうやらチェックが自身で失敗しているようです。Redis が正常に起動した直後に「アドレスが使用中」と報告して失敗しています。

app.yml ファイルを共有していただけますか?

はい、もちろん、確認ありがとうございます :smiley:。这是我的 app.yml:

## これはオールインワンのスタンドアロン Discourse Docker コンテナテンプレートです
##
## このファイルを編集した後、必ず再構築してください
## /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) を追加したい場合は、以下の 2 行のコメントを外してください
  #- "templates/web.ssl.template.yml"
  #- "templates/web.letsencrypt.ssl.template.yml"

## このコンテナが公開する TCP/IP ポートはどれですか?
## Discourse を Apache や nginx などの他の Web サーバーとポートを共有したい場合は、
## 詳細については 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% に設定します。
  ## 検出された RAM に基づいてブートストラップによって自動的に設定されますが、上書きすることもできます
  db_shared_buffers: "4096MB"

  ## ソートパフォーマンスを向上させることができますが、接続ごとにメモリ使用量が増加します
  #db_work_mem: "40MB"

  ## このコンテナが使用する Git リビジョンはどれですか?(デフォルト:tests-passed)
  #version: tests-passed

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

  ## 同時にサポートされる Web リクエスト数は?メモリと CPU コア数に依存します。
  ## 検出された CPU に基づいてブートストラップによって自動的に設定されますが、上書きすることもできます
  UNICORN_WORKERS: 8

  ## TODO: この Discourse インスタンスが応答するドメイン名
  DISCOURSE_HOSTNAME: discourse.forum

  ## 上記で指定したホスト名(-h オプション)と同じホスト名でコンテナを起動したい場合は、コメントを外してください
  #DOCKER_USE_HOSTNAME: true

  ## TODO: 初期登録時に管理者および開発者にされるメールアドレスのカンマ区切りリスト
  ## 例:'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

  ## この Discourse インスタンスの CDN アドレス(プルするように設定されています)
  ## 詳細については 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 "カスタムコマンドの開始"
  ## 最初の登録用の 'From' メールアドレスを設定したい場合は、以下のコメントを外して変更してください
  ## 最初のサインアップメールを受信した後、再度コメントアウトしてください。一度だけ実行すれば十分です
  ##- exec: rails r "SiteSetting.notification_email='email@email"
  - exec: echo "カスタムコマンドの終了"

フルの再ビルド出力も投稿していただけますか?

あなたが目にするその行は、昔からすべての再ビルドで表示されるものであり、再ビルドを妨げるものではありません。なぜなら、単に2つの異なるフックでRedisが実行されていることを確認しているだけだからです。問題は別の場所にあります。

もちろん。他のログが必要であれば、提供できます :slight_smile:
3226 行を超えてフォーラムの投稿制限を超えるため、Pastebin に投稿しました:Discourse Rebuild Log - Pastebin.com

その出力は、正常な再ビルドを示しています。

あなたのサイトはポート 12080 で動作していないのでしょうか?

はい、サイトは正常に再構築されました。
サイトが正しく読み込まれなかった原因が分かりました。
問題はSSLリバース証明書にあり、自動更新が行われなかったため、画像の読み込みが失敗し、Redisキャッシュが機能していないと誤解してしまいました🤦‍♂️

ビルドには通知が表示されていますが、Redisサーバーは正常に動作しています。
SSL証明書を更新したところ、サイトは再び正常に動作するようになりました。

サポートいただきありがとうございます。私の不注意をお詫び申し上げます:sweat_smile: