Configuración multisitio con Docker

:warning: Aunque la aplicación Discourse admite la configuración multisitio, esta es una configuración avanzada para administradores de sistemas. Si no sabe lo que está haciendo, no configure multisitio. El equipo de Discourse no puede proporcionar soporte para la configuración multisitio.

Si desea alojar varios dominios en una única configuración de Docker, necesitará una configuración multisitio. Aquí están los componentes básicos para una.

Entender los hooks

La configuración multisitio es un tema bastante avanzado. Antes de intentar una configuración multisitio, dedique algo de tiempo a aprender sobre ellos.

Las plantillas de Discourse utilizan pups; sus reglas son sencillas y potentes.

Cada regla que ejecute puede definir un hook:

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

Más adelante, en su contenedor, puede insertar reglas antes o después de un hook:

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

Así que en el ejemplo anterior verá una salida como la siguiente:

I ran before
1
I ran after

Puede leer las plantillas en /var/discourse/templates para ver qué hooks tiene disponibles.

Modificar su contenedor independiente para aprovisionar el segundo sitio (tenant)

Reemplace la sección completa de hooks con:

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

Hay 3 hooks en juego:

  1. after_postgres asegura que después de que se instale postgres se cree una base de datos adicional llamada b_discourse con los permisos apropiados.

  2. before_bundle_exec, asegura que docker_manager esté en su lugar y que el archivo multisite.yml esté en su lugar (que define dónde encontrar las bases de datos).

  3. after_bundle_exec, ejecuta la tarea de migración de base de datos personalizada rake multisite:migrate, esto asegura que todas las bases de datos estén actualizadas.

Nota sobre la configuración

El ejemplo anterior se puede dividir en contenedor de datos / contenedor de aplicaciones si es necesario. Simplemente ejecute el hook after_postgres en el contenedor de datos y el resto en el contenedor web.

El ejemplo anterior se puede extender para aprovisionar aún más bases de datos. Para hacerlo, aprovisione más bases de datos duplicando las llamadas de creación de base de datos, etc., y asegúrese de agregar sitios adicionales en multisite.yml.

Asegúrese de modificar el nodo host_names en multisite.yml para que coincida con el nombre de host real que desea alojar.

Además, si planea ejecutar HTTPS, necesitará un proxy delante del sitio para manejarlo, ya que la funcionalidad integrada de letsencrypt no funcionará en un escenario multisitio.

69 Me gusta
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

Me preguntaba qué hace el valor db_id: 2 en la configuración sugerida anteriormente.

Además, ¿cuál es el procedimiento para añadir un nuevo sitio a la configuración multisitio existente? ¿Es solo:

  • Actualizar yaml
  • ./launcher bootstrap multisite [1]
  • ./launcher start multisite

Me preguntaba si había alguna forma de evitar afectar a todos los demás sitios existentes al hacer un bootstrap o reconstrucción completa y de alguna manera solo añadir la base de datos adicional necesaria.


  1. Intenté ./launcher rebuild multisite primero, pero parece fallar. ↩︎

Creo que el id de la base de datos ya no es necesario.

Puedes editar el archivo multisite con el nuevo sitio y hacer un

sv restart unicorn

Y luego migrar la base de datos.

1 me gusta

¡Eres un salvavidas!

Me faltaba este comando para reiniciar (también probé sv reload unicorn pero de alguna manera no fue suficiente).

En cuanto a la creación de la base de datos, ¿ya existe una forma de hacerlo automáticamente? Sería bueno tener rake db:create[mynewdbname]. De lo contrario, puedo escribir un script corto.

En este momento, creo manualmente (creo la base de datos y establezco los permisos) y luego hago un RAILS_DB=newdb rake db:migrate para poblarla.

Y solo para comprobar si estoy haciendo algo estúpido:

  • Por el momento, estoy editando el archivo multisite dentro de docker (/var/www/discourse/config/multisite.yml)
  • Creando la base de datos manualmente
  • Ejecutando rake db:migrate
  • sv restart unicorn
  • Luego también tengo que editar el archivo yaml fuera de docker para que la configuración multisite esté sincronizada en caso de cualquier reconstrucción o actualización futura.

¿Estoy siendo tonto al editar la configuración multisite en 2 lugares diferentes cuando ya existe una forma de editar en un solo lugar y aplicar los cambios?

1 me gusta

¿Es posible limpiar un poco esta documentación y proporcionar más indicaciones en ella? Soy extremadamente nuevo en Docker, y aunque tengo experiencia en servidores Linux, no soy un profesional en ello. Soy de la vieja escuela, me encantan mis cron jobs y scripts de shell y cosas raras como esas con Apache multisite, etc. Pero esto es un poco más complejo y utiliza un lenguaje de programación diferente al que estoy acostumbrado… ¿Quizás incluso un video de demostración de algún tipo? Sería bueno si Discourse estuviera listo para multisite y de esa manera solo tendrías que editar algunos archivos, etc.

2 Me gusta

Simplemente pega esa estrofa de texto y edítala según sea necesario.

También necesitarás un proxy inverso o seguir Configurar Let’s Encrypt con múltiples dominios / redirecciones para obtener certificados para todos los dominios.

Consulta también Configuración de multisitio con Let’s Encrypt y sin proxy inverso. Pero esa necesita ser actualizada para tener otra línea requerida que puedes obtener del enlace anterior. He estado queriendo actualizarla pero no he podido.

1 me gusta

Si estoy haciendo multisitio, ¿a dónde debo apuntar mi dominio? ¿A la misma IP que el servidor (que aloja otro foro)?

Sí, apunta todos los dominios a la misma IP del servidor.
Configura un proxy inverso con el servidor Nginx o Caddy.
Caddy es el mejor, ya que proporciona certificados SSL automáticos gratuitos para todos tus dominios.

1 me gusta

Seguí este tutorial para configurar con éxito una instalación multisitio con Docker. Recientemente me encontré con un error al intentar actualizar y creo que la línea:

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

Debería editarse a:

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

¿Alguien podría confirmar/editar el tutorial?

1 me gusta

Sí. Yo también me encontré con esto. Querrás hacer ese cambio de lo contrario, tu arranque fallará.

2 Me gusta

¡Confirmo con entusiasmo también, que esta corrección es obligatoria!

seguro editado, ¡gracias!

2 Me gusta