Configuration Multisite avec Docker

:warning: Bien que le multisite soit pris en charge dans l’application Discourse, il s’agit d’une configuration d’administrateur système avancée. Si vous ne savez pas ce que vous faites, ne configurez pas le multisite. L’équipe Discourse n’est pas en mesure de fournir un support de configuration multisite.

Si vous souhaitez héberger plusieurs domaines sur une seule configuration Docker, vous aurez besoin d’une configuration multisite. Voici les éléments de base pour en créer une.

Comprendre les hooks

Le multisite est un sujet assez avancé. Avant de tenter une construction multisite, passez du temps à vous familiariser avec eux.

Les modèles Discourse utilisent pups ; ses règles sont simples et puissantes.

Chaque règle que vous exécutez peut définir un hook :

run:
  exec:
    cd: some/path
    hook: my_hook
    cmd:
      - echo 1

Plus tard dans votre conteneur, vous pouvez insérer des règles avant ou après un hook :

hooks:
  before_my_hook:
    - exec: echo "I ran before"
  after_my_hook:
     - exec: echo "I ran after"

Ainsi, dans l’exemple ci-dessus, vous verrez une sortie similaire à ce qui suit :

I ran before
1
I ran after

Vous pouvez parcourir les modèles dans /var/discourse/templates pour voir quels hooks sont disponibles.

Modifier votre conteneur autonome pour provisionner le deuxième site locataire

Remplacez l’intégralité de la section hooks par :

hooks:
  after_postgres:
     - exec: sudo -u postgres createdb b_discourse || exit 0
     - exec:
          stdin: |
            grant all privileges on database b_discourse to discourse;
          cmd: sudo -u postgres psql b_discourse
          raise_on_fail: false

     - exec: /bin/bash -c 'sudo -u postgres psql b_discourse <<< "alter schema public owner to discourse;"'
     - exec: /bin/bash -c 'sudo -u postgres psql b_discourse <<< "create extension if not exists hstore;"'
     - exec: /bin/bash -c 'sudo -u postgres psql b_discourse <<< "create extension if not exists pg_trgm;"'

  after_code:
    - exec:
        cd: $home/plugins
        cmd:
          - mkdir -p plugins
          - git clone https://github.com/discourse/docker_manager.git
  before_bundle_exec:
    - file:
        path: $home/config/multisite.yml
        contents: |
         secondsite:
           adapter: postgresql
           database: b_discourse
           pool: 25
           timeout: 5000
           db_id: 2
           host_names:
             - b.discourse.example.com

  after_bundle_exec:
    - exec: cd /var/www/discourse && sudo -H -E -u discourse bundle exec rake multisite:migrate

Il y a 3 hooks en jeu :

  1. after_postgres garantit qu’après l’installation de postgres, une base de données supplémentaire appelée b_discourse est créée avec les autorisations appropriées.

  2. before_bundle_exec, garantit que docker_manager est en place et que le fichier multisite.yml est en place (ce qui définit où trouver les bases de données)

  3. after_bundle_exec, exécute la tâche de migration de base de données personnalisée rake multisite:migrate ceci garantit que toutes les bases de données sont à jour.

Note sur la configuration

L’exemple ci-dessus peut être divisé en conteneur de données / conteneur d’application si nécessaire. Exécutez simplement le hook after_postgres dans le conteneur data et le reste dans le conteneur web.

L’exemple ci-dessus peut être étendu pour provisionner encore plus de bases de données. Pour ce faire, provisionnez plus de bases de données en dupliquant les appels de création de base de données, etc., et assurez-vous d’ajouter des sites supplémentaires dans multisite.yml.

Assurez-vous de modifier le nœud host_names dans multisite.yml pour qu’il corresponde au nom d’hôte réel que vous souhaitez héberger.

De plus, si vous prévoyez d’exécuter HTTPS, vous aurez besoin d’un proxy devant le site pour le gérer, car la fonctionnalité letsencrypt intégrée ne fonctionnera pas dans un scénario multisite.

69 « J'aime »
How does multisite.yml look?
Multiple Forums in a Single Installation
How to create 1000 subcategories in a scalable way?
Multiple Discourses, multiple containers, one server
Pros and cons of multiple standalone containers vs one for multiple Discourse installs?
Success - New Multisite Install on Dedicated server using ServerPilot, Nginx and Apache
Multisite Installation
Will I need to start over with multisite configuration from standalone version?
Multiple Discourse Installs - Single Server
Starting a second Discourse forum on the same VPS
Pros and cons of a multisite installation
Installation wizard not appearing in multisite installs
Disabling/restricting user search
Sandbox and test discourse on host?
Multisite installation with seperated smtp emails
How do you set up multiple discourse forums on the same server?
Help me setup many websites on one VPS
Second discourse instance on the same server
Discourse multisite installation help with digitalocean
Need proper documentation for multisite discourse with docker
Discourse for 3 different Countrys
Micro Forums: how many could I create?
Remove sites from multisite config with Docker
How could I install another discourse on same server (docker)?
Can I log into multiple instances of discourse simultaneously?
How to setup host mapping on a multi-site discourse instance
Not receiving activation email for admin on multisite installation
Multisite viability - 2 read-only and 1 active
Install Discourse on Plesk / Ubuntu 14 without Docker
Totally Walled-Off Groups
Three sites in one setup
I want to host hundreds of instances of Discourse
Recover to one site from multisite
Publishing multisite
Multisite Config
Multiple communities on discourse?
Adding an instance to multisite without rebuilding the container
Is it possible to totally hide members
Need help with multisite configuration
Multitenat Dockerize Discourse
Installing on Kubernetes
How might we better structure #howto?
How to set redis DB ID in Docker container?
Pull request for Wikis?
How can I host more than 1 Discourse forum on 1 VPS?
Multiple discourse installation on single droplet
Integration with .NET MVC application for a SaaS platform
Setup Multisite Configuration with Let's Encrypt and no Reverse Proxy
Docker image update: Redis 6 and 25% smaller image size
Setup Multisite Configuration with Let's Encrypt and no Reverse Proxy
One server for 2 Discourse communities?
Multiple discourse instances in a single server
Pups::ExecError
Web-only - do I need a separate image for each container?
One server for 2 Discourse communities?
Multisite installation ... in subdirectories?
Stable branch assets won't compile
ActiveRecord::StatementInvalid: PG::UndefinedColumn: ERROR: column categories.search_priority does not exist
[mutlisite installation] pnpm permission error during rebuild
WP SSO + Discourse Multisite
All users are visible in @mentions autocomplete list
Migrate from VPS to a Dedicated
Are there other workarounds to not having category moderation such as multiple instances of the board?
Discourse Multisite – Nginx (Inside Docker) Only Serving Default Site
Stable branch assets won't compile
Two Discourse communities on the same VPS
How can I use different setting value for subdomain?
Will This Configuration Successfully Create a Second Discourse Instance (with Proxy)?
Pups::ExecError
Use CloudPanel to manage multiple sites with Discourse
Best approach for test and production instance of discourse
Two standalone instances on one server?
How can Admin login while Read-only mode is enabled on multisite?
Does discourse hosting use docker for all customer instances?
Tips for setting up a multi-subdomain Discourse instance with shared SSO?
Feature proposal: Customizations based on primary group membership, a.k.a. tenancy 'lite'
Using a launcher built docker image in docker-compose
Move from standalone container to separate web and data containers
Move from standalone container to separate web and data containers
Move from standalone container to separate web and data containers
Guidance on multi-site setup
Running multiple things on the same sever as my Pi (where Discourse is hosted)?
Contabo experience with Plesk, Webmin or other server-admin setup?
App.yml shared volumes for a two website setup
How extensible can I make my installation in terms of sub domains and restricting membership to them?
Discourse instance stops running in every midnight
Multisite for small collection of sites for a family?
Hosting Plan Suggestion for 500 Concurrent Online Users
Add path to cookie
Avatar, Site Logos, and Cert Errors
Database access issues after upgrade v3.5.2 -> v3.6.0.beta2
PAID Require Discourse expert for extreme customization
Move from standalone container to separate web and data containers
Can I have two domains pointing towards the same IP address without redirect?
Move from standalone container to separate web and data containers
Multiple container setup problems

Je me demandais à quoi servait la valeur db_id: 2 dans la configuration suggérée ci-dessus ?

De plus, quelle est la procédure pour ajouter un nouveau site à la configuration multisite existante ? Est-ce simplement :

  • Mettre à jour le yaml
  • ./launcher bootstrap multisite [^1]
  • ./launcher start multisite

Je me demandais s’il existait un moyen d’éviter d’impacter tous les autres sites existants en effectuant un bootstrap ou une reconstruction complète et en ajoutant d’une manière ou d’une autre uniquement la base de données supplémentaire nécessaire ?

[^1] : J’ai d’abord essayé ./launcher rebuild multisite, mais cela semble échouer.

Je pense que l’identifiant de la base de données n’est plus nécessaire.

Vous pouvez simplement modifier le fichier multisite avec le nouveau site et effectuer un

sv restart unicorn

Puis migrer la base de données.

1 « J'aime »

Tu me sauves la vie !

Il me manquait cette commande pour redémarrer (j’avais aussi essayé sv reload unicorn mais d’une manière ou d’une autre, cela n’a pas suffi).

Pour ce qui est de la création de la base de données, existe-t-il déjà un moyen de le faire automatiquement ? Ce serait bien d’avoir rake db:create[mynewdbname]. Sinon, je peux écrire un petit script shell.

Pour le moment, je crée manuellement (création de la db et définition des permissions), puis j’exécute RAILS_DB=newdb rake db:migrate pour la peupler.

Et juste pour vérifier si je fais quelque chose de stupide :

  • Pour le moment, j’édite le fichier multisite dans docker (/var/www/discourse/config/multisite.yml)
  • Je crée la base de données manuellement
  • J’exécute rake db:migrate
  • Je redémarre unicorn avec sv restart
  • Je dois également éditer le fichier yaml en dehors de docker afin que la configuration multisite soit synchronisée en cas de future reconstruction ou de mises à niveau.

Suis-je idiot d’éditer la configuration multisite à 2 endroits différents alors qu’il existe déjà un moyen de l’éditer à un seul endroit et de pousser les changements ?

1 « J'aime »

Serait-il possible de nettoyer un peu cette documentation et d’y ajouter quelques indications supplémentaires ? Je suis complètement novice en Docker, et bien que j’aie de l’expérience avec les serveurs Linux, je ne suis pas un expert. Je suis un ancien adepte des cron jobs et des scripts shell, et vous savez, des choses étranges comme ça avec Apache multi-site, etc. Mais ceci est un peu plus complexe et utilise un langage de programmation différent de celui auquel je suis habitué… Peut-être même une vidéo de démonstration ? Ce serait bien si Discourse était simplement prêt pour le multi-site, et qu’ainsi tout ce que vous auriez à faire serait de modifier quelques fichiers, etc.

2 « J'aime »

Collez simplement cette strophe de texte et modifiez-la selon vos besoins.

Vous aurez ensuite besoin d’un proxy inverse ou de suivre Configurer Let’s Encrypt avec plusieurs domaines / redirections pour obtenir des certificats pour tous les domaines.

Voir aussi Configuration multisite avec Let’s Encrypt et sans proxy inverse. Mais cela doit être mis à jour pour inclure une autre ligne requise que vous pouvez obtenir du lien précédent. J’avais l’intention de le mettre à jour mais je n’ai pas réussi.

1 « J'aime »

Si je fais du multisite, vers où dois-je pointer mon domaine ? La même adresse IP que le serveur (qui héberge un autre forum) ?

Oui, faites pointer tous les domaines vers la même adresse IP de serveur.
Configurez un proxy inverse avec Nginx ou Caddy server.
Caddy est le meilleur car il offre des certificats SSL automatiques gratuits à tous vos domaines.

1 « J'aime »

J’ai suivi ce tutoriel pour configurer avec succès une installation multisite avec Docker. J’ai récemment rencontré une erreur lors de la tentative de mise à jour et je crois que la ligne :

    - exec: cd /var/www/discourse && sudo -E -u discourse bundle exec rake multisite:migrate

Devrait être modifiée en :

    - exec: cd /var/www/discourse && sudo -H -E -u discourse bundle exec rake multisite:migrate

Quelqu’un pourrait-il confirmer/modifier le tutoriel ?

1 « J'aime »

Oui. J’ai aussi rencontré ce problème. Vous voulez faire ce changement sinon votre amorçage échouera.

2 « J'aime »

Je confirme avec enthousiasme également, que cette correction est obligatoire !

sûr modifié, merci !

2 « J'aime »