Discourse aus einem Unterordner (Pfad-Präfix) statt einer Subdomain bereitstellen

:warning: Offizielle Erklärung von Discourse zur Subfolder-Einrichtung

Wir unterstützen Subfolder-Einrichtungen für unsere gehosteten Kunden ab der Enterprise-Ebene. Aufgrund der hohen technischen Komplexität empfehlen wir dringend, diese Einrichtung nicht zu verwenden, es sei denn, Sie haben umfangreiche Erfahrung mit benutzerdefinierten Subfolder-Einrichtungen.

Es ist entscheidend, dass Sie ein tiefes Verständnis haben für

  • NGINX-Einrichtung im Discourse-Docker-Container
  • Sicheres Weiterleiten der ursprünglichen IP-Adresse mit benutzerdefinierten Headern in der Proxy-Kette
  • Rate-Limiting am Frontend-Proxy-Server

Wenn all das für Sie seltsam und fremd klingt, empfehlen wir dringend, diese Einrichtung zu vermeiden.

Um Discourse aus einem Subfolder (auch bekannt als Pfad-Präfix) auf Ihrer Domain zu bedienen, wie https://www.example.com/=SUBFOLDER=, hier ist die Anleitung!

Docker-Konfiguration

Fügen Sie im env-Abschnitt Ihrer Docker-Container-yml-Datei die Einstellung DISCOURSE_RELATIVE_URL_ROOT mit dem gewünschten Subfolder hinzu. Stellen Sie sicher, dass es nicht mit einem / endet.

Das Bearbeiten dieses Feldes aktualisiert die gesamte Anleitung.

env:
  ...
  DISCOURSE_RELATIVE_URL_ROOT: /=SUBFOLDER=

Der run-Abschnitt benötigt einige Änderungen, um alle Discourse-Routen an den richtigen Ort zu leiten. Hier ist ein vollständiger run-Abschnitt mit Subfolder-Unterstützung:

run:
    - exec:
        cd: $home
        cmd:
          - mkdir -p public/=SUBFOLDER=
          - cd public/=SUBFOLDER= && ln -s ../uploads && ln -s ../backups
    - replace:
       global: true
       filename: /etc/nginx/conf.d/discourse.conf
       from: proxy_pass http://discourse;
       to: |
          rewrite ^/(.*)$ /=SUBFOLDER=/$1 break;
          proxy_pass http://discourse;
    - replace:
       filename: /etc/nginx/conf.d/discourse.conf
       from: etag off;
       to: |
          etag off;
          location /=SUBFOLDER= {
             rewrite ^/=SUBFOLDER=/?(.*)$ /$1;
          }
    - file:
        path: /etc/nginx/conf.d/outlets/server/set-real-ip-from-webroot.conf
        chmod: 644
        contents: |
          set_real_ip_from 123.456.789.ABC; # die IP-Adresse Ihres Upstream-Proxys
    - file:
        path: /etc/nginx/conf.d/outlets/server/real-ip-header.conf
        chmod: 644
        contents: |
          real_ip_header x-forwarded-for;

Für weitere Details zur Erhaltung der IP-Adresse des Endnutzers siehe Handling the "chain of trust" of the end user's real IP.

Nachdem Sie diese Änderungen vorgenommen haben, bootstrappen Sie Ihren Docker-Container wie üblich oder rebuilden Sie ihn, falls Sie einen bestehenden Container ändern.

./launcher bootstrap app

oder

./launcher rebuild app

Angehängt ist eine vollständige Beispiel-yml-Datei für einen eigenständigen Container:
subfolder-sample.yml (3.1 KB)

Bedenken bezüglich Rate-Limiting

Wenn Sie diese Einrichtung verwenden, möchten Sie wahrscheinlich Anfragen vor dem Erreichen von NGINX im Container rate-limiten. Das bedeutet, dass Sie wahrscheinlich unser Rate-Limiting-Template nicht verwenden sollten. Es ist sehr schwierig, NGINX im Container so zu konfigurieren, dass es auf einer umgemappten IP limitiert, und würde komplexe Änderungen am Template erfordern.

Bestehende Beiträge

Wenn Sie dies mit einer bestehenden Site gemacht haben, die sich auf einem Subdomain befand, werden Sie feststellen, dass Ihre Uploads nicht mehr funktionieren. Es gibt ein Tool, das helfen kann, alle Pfade so anzupassen, dass sie den Subfolder enthalten. Gehen Sie zunächst in den Docker-Container und navigieren Sie zum Discourse-Verzeichnis:

cd /var/discourse
./launcher enter app
cd /var/www/discourse

Führen Sie dann den Remap-Befehl aus, nachdem Sie ein Backup erstellt haben:

RAILS_ENV=production bundle exec script/discourse remap '/uploads' '/=SUBFOLDER=/uploads'

Siehe auch: Use a subfolder (path prefix) to serve Discourse with multiple servers sharing a domain für weitere exotische Einrichtungen.

robots.txt

Da Discourse nun in einem Subfolder läuft, kann es seine robots.txt-Datei nicht bereitstellen, um zu steuern, welche Routen von Web-Crawlern durchsucht werden. Die Crawler werden die robots.txt-Datei Ihrer Hauptseite (https://www.example.com/robots.txt) überprüfen. Sie müssen den Inhalt der robots.txt-Datei von Discourse (zu finden unter https://www.example.com/=SUBFOLDER=/robots.txt) kopieren und in die robots.txt-Datei Ihrer Hauptseite einfügen.

35 „Gefällt mir“
How can I change my installation from forum.website.com to www.website.com/forum?
Moving Discourse to subdirectory caused all uploads to break
Uploaded avatars and Gravatar not working with subfolder installation
Is it possible to install discourse inside a directory?
Launch Discourse on www.example.com/meta/ In a web folder type
Subfolder with SSL and nginx reverse proxy
404 errors (assets) on Subfolder installation
Install Discourse into domain.com/forums
Non-standard port breaks uploads
Avatar uploads broken on subfolder installs?
Moving Discourse to subdirectory caused all uploads to break
Image lightbox not working in subfolder install
Problem with discourse in a subfolder
Install Discourse as subfolder within Wordpress website?
Uploaded avatar or gravatar not working
Installation on v-server as a subfolder with other services in subfolders using apache
Is it possible to install Discourse on the same domain of your main website
Subfolder install - external links get changed/redirected to site relative links
Discourse embedded on my WP
Reverse Proxy Assets
Reverse Proxy rewrites domain in external links in posts
Inheriting discourse install - need some assistance
Multisite installation ... in subdirectories?
Generals Subfolder recommendations and tips
Add to route headers?
Sorry, there was an error authorizing your account
Site Logo and Icons Break due to subfolder config
Site Logo and Icons Break due to subfolder config
Site Logo and Icons Break due to subfolder config
Running Discourse at / while serving a custom app at /tickets on the same domain
404 errors (assets) on Subfolder installation
404 errors (assets) on Subfolder installation
Moving Discourse from Subdomain to Subfolder
Blank Page After installing Discourse on Subfolder
Trailing slash and subfolder setup
Install Discourse as a subdirectory with existing Nginx
How to run discourse on subdirectory of external domain?
How to run discourse on subdirectory of external domain?
Domain missing from some requests after migration from subfolder back to subdomain
How to run discourse on subdirectory of external domain?
Digest email issue with 'stable'
Using other ports than 80 and 443 - HowTo?
Add secondary url / embed into Wordpress
Recent Changes Breaking Subfolder Setup?
Issue with FAQ link on edge case subfolder setup
Issue with FAQ link on edge case subfolder setup
Put discourse on a sub url
No subfolder prefixing for some resources
Upgrade failed - could use some help to try and fix using SSH
Install Discourse without docker with an existing Rails app
Docker subfolder install not working due to Ember-CLI proxy error?
Multisite DISCOURSE_RELATIVE_URL_ROOT
How to install discourse into subdirectory instead of subdomain?
Setup wizard emoji wrong in subfolder install
Not find a Gravatar
Installing for production via Docker on existing server with Litespeed?
Use a subfolder (path prefix) to serve Discourse with multiple servers sharing a domain
Configure a Cloudfront reverse proxy for a subfolder install
Run other websites on the same machine as Discourse
Embedding Categories in Existing SPA
Does custom domain support the subpath format like 'example.com/forum'?
To use Discourse completely on shopify
Are separate subdomains required for making a discourse forum?
Problem when updating Discourse Forum
Error when I send a message in chat [downgraded to Stable from 3.1.0beta4]
Error when I send a message in chat [downgraded to Stable from 3.1.0beta4]
How to Change Discourse forum path
How to setup NGINX in the Discourse Docker container
How to setup NGINX in the Discourse Docker container
Possible to update add url path prefix for /t and /c
Implement the discourse forum in the laravel 11 project
Endless loading behind Cloudflare
Publish Discourse under URL
Cloudflare with subfolder setup
How to Set Up Discourse in a Subdirectory for Self-Hosting?
Discourse sign in redirects to root directory instead of subfolder
Setup Discourse with KeyCDN
National Flags
Setup wizard emoji wrong in subfolder install
How to run Discourse in a subfolder?
Handling the "chain of trust" of the end user's real IP
Recent Changes Breaking Subfolder Setup?
Last update breaks permalink for categories
Setup wizard emoji wrong in subfolder install
Ghost & Discourse SSO implementation
Wiki topics look incredibly out of date?
Too many redirects when reverse proxying to Discourse from a different server
Blank main page on one forum (subfolder + multisite install)
Moving Discourse to subdirectory caused all uploads to break
Feasible to reverse proxy using qualifier in URL?
Upgrade doesn't work when installed with subfolder
Message bus does not respect subfolder during update process
Wiki Posts Not Green?
Base_url and base_uri
Embed whole Discourse board into Wordpresspage
Backup upload failing
Redirect to discourse from a route in another domain
Redirect to discourse from a route in another domain
Problem with discourse in a subfolder
Install Discourse as subfolder within Wordpress website?
Looking for a developper
Switching forum from subdomain to sub directory
How to install discourse with nginx as proxy on specific path?
All IPs recorded as 127.0.0.1
How to install discourse with nginx as proxy on specific path?
SetupWizard, blank screen, JS Error "`virtual-dom"
Trouble connecting drupal and discourse
Failed to Bootstrap - launcher rebuild app
Redirect from one server to another server and keep everything after the URL