アクティブ化メール:discourse-doctor は機能しますが、discourse 自体は機能しません

皆さんこんにちは、

タイトル通りです。discourse-doctor は、ホストマシン上で動作しているメールサーバーに、外部およびインターネットに面したインターフェース(localhost ではありません)経由で接続しますが、discourse 自体は接続できません。

discourse からの接続尝试は、Rails の production ログにもメールサーバーのログにも記録されていません。Docker インターフェース上でパケットスニッファを実行しても、メールのトラフィックは確認できませんでした。

一方、discourse-doctor は期待通りにメールサーバーにログエントリを作成し、メールクライアントでメールを読むことができます。

以下の設定で Docker コンテナを複数回再構築しました。

## これはオールインワンのスタンドアロン 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 などの他のウェブサーバーとポートを共有したい場合は、
## https://meta.discourse.org/t/17247 を参照してください
expose:
  - "127.0.0.1:1234:80"   # http
    ###   - "127.0.0.1:1235: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

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

  ## TODO: この Discourse インスタンスが応答するドメイン名
  ## 必須です。Discourse は IP アドレスのみでは動作しません。
  DISCOURSE_HOSTNAME: example.com

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

  ## TODO: 初期登録時に管理者および開発者として設定されるカンマ区切りのメールアドレスのリスト
  ## 例:'user1@example.com,user2@example.com'
  DISCOURSE_DEVELOPER_EMAILS: 'me@another.com'

  ## TODO: 新しいアカウントの検証と通知送信に使用する SMTP メールサーバー
  # SMTP アドレス、ユーザー名、パスワードは必須です
  # 警告:SMTP パスワードに '#' 文字が含まれていると問題が発生する可能性があります!
  DISCOURSE_SMTP_ADDRESS: submission.example.com # A レコードは機能しますが、CNAME は機能しません
  DISCOURSE_SMTP_PORT: 587
  DISCOURSE_SMTP_USER_NAME: somedumbuser
  DISCOURSE_SMTP_PASSWORD: somedumbpass
  #DISCOURSE_SMTP_ENABLE_START_TLS: true           # (オプション、デフォルトは true)

  ## Lets Encrypt テンプレートを追加した場合、以下をコメント外して無料の SSL 証明書を取得してください
  LETSENCRYPT_ACCOUNT_EMAIL: ssl@yetanother.com

  ## この Discourse インスタンスの http または https CDN アドレス(プルするように設定)
  ## 詳細については 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

## ビルド後に実行する任意のカスタムコマンド
run:
  - exec: echo "Beginning of custom commands"
  ## 最初の登録時の 'From' メールアドレスを設定したい場合は、コメントを外して変更してください:
  ## 最初の登録メールを受信した後、再度その行をコメントアウトしてください。一度だけ実行すれば十分です。
  #- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
  - replace:
      filename: /etc/nginx/conf.d/discourse.conf
      from: "types {"
      to: |
        set_real_ip_from 0.0.0.0/0;
        real_ip_header X-Forwarded-For;
        real_ip_recursive on;
        types {
  - exec: echo "End of custom commands"

なので、/admin/email でメールテストを実行してもメッセージは送信されませんか?/sidekiq は実行されていますか?標準的なインストールを行いましたか?

Discourse を動作させるにはドメイン名が必要ですので、localhost へのバインドのみが原因で問題が発生している可能性があります。

こんにちは、ジェイさん。ご返信ありがとうございます。

sudo docker exec -it app /bin/bash を実行しても、/admin ディレクトリは表示されません。また、git リポジトリからクローンされた /admin ディレクトリも存在しません。

pgrep -afl sidekiq を実行すると、その名前のプロセスが動作していることが確認できます。

私はここで説明した通り、Discourse を HAProxy の背後で実行しており、そのために localhost へのバインドを行っています: How to install Discourse behind Apache mod_proxy?

expose を以下のように変更しましたが、メールサーバーのポート 587 には SYN パケットさえ送信されていません。DISCOURSE_HOSTNAME は正しいドメインに設定されており、sidekiq も実行されていますが、/admin/email の場所がどこにあるのか依然としてわかりません。

expose:
  - "1234:80"   # http

/admin/email は相対パスです
Web ブラウザでアクセスする必要があります:
{あなたの Discourse ホスト名}/admin/email