Markdown JS と 2 つのプロトコル

バージョン: 2.7.0.beta1
インストール: discourse-docker

皆さん、こんにちは。

これ以上うまく表現する方法がわかりませんが、Discourse のインストール環境にある markdown-it の JS バンドルが正しく動作していません。何らかの理由で、JavaScript の URL(CDN を経由して提供され、S3 バケットに保存されているもの)に「https」という追加プロトコルが付加されてしまいます。

スクリーンショットを添付しました。
image

他のすべてのリソースは正常に動作しています。

この問題だけが原因で、プレビュー機能が利用できません :frowning:

お時間をいただきありがとうございます。ご回答をお待ちしております :slight_smile:

他の稼働中のリソースのスクリーンショット:

app.yml ファイルをここに共有してもらえますか?

はい、もちろん。

\n
## Ansible で管理されています。サーバー上で変更しないでください
## これは、すべてを 1 つにまとめたスタンドアロンの 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:
  - "80:80"   # http
  - "443:443" # https

params:
  db_default_text_search_config: "pg_catalog.english"

  ## db_shared_buffers を総メモリの最大 25% に設定します。
  ## ブートストラップによって検出された RAM に基づいて自動的に設定されますが、上書きすることも可能です
  db_shared_buffers: '16GB'

  ## ソートパフォーマンスを向上させることができますが、接続あたりのメモリ使用量が増加します
  #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 は IP アドレス単体では動作しません。
  DISCOURSE_HOSTNAME: 'community-dev.stackit.cloud'

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

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

  ## TODO: 新規アカウントの検証および通知送信に使用する SMTP メールサーバー
  # SMTP アドレス、ユーザー名、パスワードは必須です
  # 警告: SMTP パスワードに '#' 文字が含まれていると問題が発生する可能性があります!
  DISCOURSE_SMTP_ADDRESS: '1.2.3.4'
  DISCOURSE_SMTP_PORT: 587
  DISCOURSE_SMTP_USER_NAME: 'xx@xx.de'
  DISCOURSE_SMTP_PASSWORD: 'xxx'
  DISCOURSE_SMTP_ENABLE_START_TLS: true
  DISCOURSE_SMTP_OPENSSL_VERIFY_MODE: none

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

  ## この Discourse インスタンスの http または https CDN アドレス(プル用に設定)
  ## 詳細については https://meta.discourse.org/t/14857 を参照してください
  #DISCOURSE_CDN_URL: https://discourse-cdn.example.com
  #DISCOURSE_CDN_URL: community-cdn.change.me

  ## IP アドレス検索用の Maxmind 地理位置 IP アドレスキー
  ## 詳細については https://meta.discourse.org/t/-/137387/23 を参照してください
  #DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456

  DISCOURSE_DB_POOL: 16
  DISCOURSE_DB_USERNAME: 'discourse'
  DISCOURSE_DB_PASSWORD: 'yyy'
  DISCOURSE_DB_HOST: 1.2.3.4
  DISCOURSE_DB_NAME: 'discourse'
  DISCOURSE_DB_PORT: 5432

  DISCOURSE_REDIS_HOST: 'y.de'
  DISCOURSE_REDIS_PASSWORD: 'xxx'
  DISCOURSE_REDIS_PORT: 49456

  DISCOURSE_MESSAGE_BUS_REDIS_ENABLED: true
  DISCOURSE_MESSAGE_BUS_REDIS_HOST: 'y.de'
  DISCOURSE_MESSAGE_BUS_REDIS_PORT: 49456
  DISCOURSE_MESSAGE_BUS_REDIS_PASSWORD: 'xxx'

  DISCOURSE_USE_S3: true
  DISCOURSE_S3_REGION: whatever
  DISCOURSE_S3_ENDPOINT: https://assets.xxx
  DISCOURSE_S3_ACCESS_KEY_ID: 'discourse-dev'
  DISCOURSE_S3_SECRET_ACCESS_KEY: 'xxx'
  DISCOURSE_S3_CDN_URL: https://discourse-dev.assets.xxx
  DISCOURSE_S3_BUCKET: 'discourse-dev'
  DISCOURSE_S3_BACKUP_BUCKET: 'discourse-dev/backups'
  DISCOURSE_BACKUP_LOCATION: s3
  DISCOURSE_S3_INSTALL_CORS_RULE: false

## 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-cakeday.git
      - git clone https://github.com/discourse/discourse-oauth2-basic.git
      #- git clone https://github.com/discourse/discourse-bbcode.git

  after_assets_precompile:
- exec:
    cd: $home
    cmd:
      - sudo -E -u discourse bundle exec rake s3:upload_assets

## ビルド後に実行する任意のカスタムコマンド
run:
  - exec: echo "Beginning of custom commands"
  ## 最初の登録時の 'From' メールアドレスを設定したい場合は、コメントを外して変更してください
  ## 最初の登録メールを受け取った後、再度コメントアウトしてください。1 回だけ実行すれば十分です
  - exec: rails r "SiteSetting.notification_email='xxx@xxx.de'"
  - exec: echo "End of custom commands"

リバースプロキシの背後で動作していますか?設定で force_https を有効にしましたか?

はい、force_https は設定されています。また、内蔵の nginx 以外にリバースプロキシは存在しません。

奇妙なのは、他の JS ファイルは CDN URL で正常に動作しているのに、markdown-it だけがうまくいかない点です。

Ruby の知識がないため、コードのどこを確認すればよいかわかりません。 :slight_smile: :grinning:

「いいね!」 1

解決策を特定するために、他に必要となる情報はありますか?もしかしてコードを確認すべきでしょうか?

こんにちは、これの解決策をご存知の方はいませんか?

「いいね!」 1

設定に何かおかしい点があります。

S3 CDN が設定されていますが、それはバケットと同じ URL になっていますか?

data-s3-cdn="https://discourse-dev.assets.schwarz" 
data-s3-base-url="//discourse-dev.assets.schwarz"

Meta と比較すると:

data-s3-cdn="https://d11a6trkgmumsb.cloudfront.net" 
data-s3-base-url="//assets-meta-cdck-prod-meta.s3.dualstack.us-west-1.amazonaws.com"

動的スクリプトを読み込むコードは、S3_BASE_URLS3_CDN に置換しようとしています。

https://github.com/discourse/discourse/blob/master/app/assets/javascripts/discourse-common/addon/lib/get-url.js#L35-L37

「いいね!」 1

はい、両方の URL は同じです。S3 互換のオブジェクトストレージとして Minio を使用しているためです。

@Falco さん、おっしゃる通りでした。2 つの URL を分離することで問題が解決しました :slight_smile:

お手伝いいただき、ありがとうございます :slight_smile:

「いいね!」 1

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.