Discourse サイトのセットアップを試みています。NGINX を経由してルーティングされています。
enable_discourse_id: Discourse ID への自動登録に失敗しました。これは、ネットワーク接続の問題、ファイアウォールの制限、または Discourse ID サービスへの到達不能が原因である可能性があります。詳細についてはサーバーログを確認するか、サポートにお問い合わせください。
現時点ではメールの設定をスキップすることを選択しました。しかし、上記のエラーメッセージのため、セットアップを継続できません。この問題を meta.discourse.org で報告してください。
私の NGINX 設定です。SSO が機能しなくなっている原因がわかりません。
server {
server_name forum.website.net;
location / {
proxy_pass http://localhost:4180;
#proxy_pass http://unix:/var/discourse/shared/standalone/nginx.http.sock:;
proxy_set_header Host $http_host;
proxy_http_version 1.1;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Real-IP $remote_addr;
}
listen [::]:443 ssl; # managed by Certbot
listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/forum.website.net/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/forum.website.net/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}
server {
if ($host = forum.website.net) {
return 301 https://$host$request_uri;
} # managed by Certbot
listen 80; listen [::]:80;
server_name forum.website.net;
return 404; # managed by Certbot
}
web.socketed.template.yml をインポートする際に、Unix ソケットポートを使用しようともしました。
私の 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"
# - "templates/web.socketed.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:
- "4180: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 リビジョンはどれですか?(デフォルト:latest)
#version: latest
env:
LC_ALL: en_US.UTF-8
LANG: en_US.UTF-8
LANGUAGE: en_US.UTF-8
# DISCOURSE_DEFAULT_LOCALE: en
## 同時にサポートされる Web リクエストの数。メモリと CPU コア数に依存します。
## ブートストラップによって検出された CPU に基づいて自動的に設定されますが、上書きすることもできます
UNICORN_WORKERS: 3
## TODO: この Discourse インスタンスが応答するドメイン名
## 必須。Discourse は IP アドレスのみでは動作しません。
DISCOURSE_HOSTNAME: "forum.website.net"
## コンテナを上記で指定したホスト名(-h オプション)と同じホスト名で起動したい場合は、コメントを外してください
## (デフォルト:"$hostname-$config")
#DOCKER_USE_HOSTNAME: true
## TODO: 初期登録時に管理者および開発者として指定されるメールアドレスのカンマ区切りリスト
## 例:'user1@example.com,user2@example.com'
DISCOURSE_DEVELOPER_EMAILS: "email@proton.me"
## TODO: メールサーバーを設定する
## (新規アカウントの検証、通知、ダイジェストなどに使用されます)
## 必須:メール送信に使用する SMTP メールサーバーのホスト名
# DISCOURSE_SMTP_ADDRESS: smtp.example.com
## ポートをデフォルト(25)以外のものに設定する場合はコメントを外してください
#DISCOURSE_SMTP_PORT: 587
## SMTP プロバイダーが認証を必要とする場合は、USER_NAME / PASSWORD が必要です
## 警告:SMTP パスワードに '#' が含まれていると誤解釈される可能性があります。必ず文字列のクォート内に含めてください。例:
## DISCOURSE_SMTP_PASSWORD: "#pass#ord"
# DISCOURSE_SMTP_USER_NAME: user@example.com
# DISCOURSE_SMTP_PASSWORD: "pa$$word"
## 接続時に暗黙的な TLS を有効にするにはコメントを外してください。ポート 465 を使用する場合はおそらく必要です
#DISCOURSE_SMTP_FORCE_TLS: true
## HELO/EHLO ドメインを設定するにはコメントを外してください。プロバイダーが要求する場合のみ設定してください
#DISCOURSE_SMTP_DOMAIN: discourse.example.com
## 通知が送信されるアドレス
#DISCOURSE_NOTIFICATION_EMAIL: noreply@discourse.example.com
## サーバー証明書検証を変更するにはコメントを外してください
#DISCOURSE_SMTP_OPENSSL_VERIFY_MODE: peer # peer|none
## 認証方法をオーバーライドするにはコメントを外してください
#DISCOURSE_SMTP_AUTHENTICATION: plain # plain|login|cram_md5
# オプション:メール設定スキップフラグ
DISCOURSE_SKIP_EMAIL_SETUP: "1" # (オプション)メール設定の検証をスキップするにはコメントを外してください
## この Discourse インスタンスの http または https CDN アドレス(プルするように設定)
## 詳細は https://meta.discourse.org/t/14857 を参照してください
#DISCOURSE_CDN_URL: https://discourse-cdn.example.com
## IP アドレスの検索に使用する Maxmind ジオロケーション IP アカウント ID とライセンスキー
## 詳細は https://meta.discourse.org/t/-/173941 を参照してください
#DISCOURSE_MAXMIND_ACCOUNT_ID: 123456
#DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456
## 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'"
- exec: echo "End of custom commands"
この問題を解決する方法をご存知の方はいませんか?また、近いうちにメールによるサインイン/ログインを使用する予定はありません。SSO のみを使用します。