Servir Discourse depuis un sous-dossier (préfixe de chemin) plutôt qu'un sous-domaine

:warning: Déclaration officielle de Discourse concernant la configuration en sous-dossier

Nous proposons des configurations en sous-dossier pour nos clients hébergés à partir du niveau entreprise. En raison de la grande complexité technique de cette mise en place, nous vous recommandons vivement de ne pas utiliser cette configuration à moins d’être très expérimenté dans les configurations en sous-dossier personnalisées.

Il est essentiel d’avoir une compréhension approfondie des éléments suivants :

  • Configuration de NGINX dans le conteneur Docker de Discourse
  • Transfert sécurisé des adresses IP originales à l’aide d’en-têtes personnalisés dans la chaîne de proxy
  • Limitation de débit (rate limiting) sur le serveur proxy frontal

Si tout cela vous semble étrange et incompréhensible, nous vous recommandons vivement d’éviter cette configuration.

Pour servir Discourse depuis un sous-dossier (alias avec un préfixe de chemin) sur votre domaine, comme https://www.example.com/=SUBFOLDER=, voici comment procéder !

Configuration Docker

Dans la section env de votre fichier yml de conteneur Docker, ajoutez le paramètre DISCOURSE_RELATIVE_URL_ROOT avec le sous-dossier que vous souhaitez utiliser. Assurez-vous qu’il ne se termine pas par un /.

La modification de cette valeur mettra à jour l’ensemble du guide.

env:
  ...
  DISCOURSE_RELATIVE_URL_ROOT: /=SUBFOLDER=

La section run nécessite quelques modifications pour rediriger tous les itinéraires Discourse vers l’endroit approprié. Voici une section run complète avec prise en charge des sous-dossiers :

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; # l'adresse IP de votre proxy en amont
    - file:
        path: /etc/nginx/conf.d/outlets/server/real-ip-header.conf
        chmod: 644
        contents: |
          real_ip_header x-forwarded-for;

Pour plus de détails sur la préservation de l’adresse IP de l’utilisateur final, consultez Handling the "chain of trust" of the end user's real IP.

Après avoir apporté ces modifications, initialisez votre conteneur Docker comme d’habitude, ou reconstruisez-le si vous modifiez un conteneur existant.

./launcher bootstrap app

ou

./launcher rebuild app

Ci-joint, un exemple complet de fichier yml pour un conteneur autonome :
subfolder-sample.yml (3,1 Ko)

Préoccupations liées à la limitation de débit

Si vous optez pour cette configuration, vous voudrez probablement limiter le débit des requêtes avant qu’elles n’atteignent NGINX dans le conteneur, ce qui signifie que vous éviterez probablement d’utiliser notre modèle de limitation de débit. Il est très difficile de configurer NGINX dans le conteneur pour limiter sur une IP remappée, et cela nécessiterait des modifications complexes du modèle.

Messages existants

Si vous avez effectué cette opération sur un site existant qui se trouvait sur un sous-domaine, vous constaterez que vos téléchargements sont cassés. Un outil peut aider à corriger tous les chemins d’accès pour inclure le sous-dossier. Entrez d’abord dans le conteneur Docker et naviguez vers le répertoire Discourse :

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

Exécutez ensuite la commande de remappage après avoir effectué une sauvegarde :

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

Voir également : Use a subfolder (path prefix) to serve Discourse with multiple servers sharing a domain pour des configurations plus exotiques.

robots.txt

Maintenant que Discourse fonctionne sur un sous-dossier, il ne peut plus servir son fichier robots.txt pour contrôler quelles routes sont explorées par les robots d’indexation. Les robots consulteront le fichier robots.txt de votre site principal (https://www.example.com/robots.txt). Vous devez copier le contenu du fichier robots.txt de Discourse (trouvé à https://www.example.com/=SUBFOLDER=/robots.txt) et l’ajouter dans le fichier robots.txt de votre site principal.

35 « J'aime »
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