Configuração Multisite com Docker

:warning: Embora o multisite seja suportado na aplicação Discourse, esta é uma configuração avançada de sysadmin. Se você não sabe o que está fazendo, não configure o multisite. A equipe do Discourse não pode fornecer suporte à configuração de multisite.

Se você deseja hospedar vários domínios em uma única configuração Docker, precisará de uma configuração multisite. Aqui estão os blocos de construção básicos para uma.

Entenda os hooks

Multisite é um tópico bastante avançado. Antes de tentar uma construção multisite, dedique algum tempo para aprender sobre eles.

Os templates do Discourse usam pups; suas regras são simples e poderosas.

Cada regra que você executa pode definir um hook:

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

Mais tarde, em seu contêiner, você pode inserir regras antes ou depois de um hook:

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

Portanto, no exemplo acima, você verá uma saída como a seguinte:

I ran before
1
I ran after

Você pode ler os templates em /var/discourse/templates para ver quais hooks você tem disponíveis.

Modifique seu contêiner standalone para provisionar o segundo tenant do site

Substitua a seção inteira de hooks por:

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

Existem 3 hooks em ação:

  1. after_postgres garante que, após a instalação do postgres, um banco de dados adicional chamado b_discourse seja criado com as permissões apropriadas.

  2. before_bundle_exec, garante que docker_manager esteja no lugar e que o arquivo multisite.yml esteja no lugar (que define onde encontrar os bancos de dados)

  3. after_bundle_exec, executa a tarefa de migração de banco de dados personalizada rake multisite:migrate, isso garante que todos os bancos de dados estejam atualizados.

Nota sobre a configuração

O exemplo acima pode ser dividido em contêiner de dados / contêiner de aplicação, se necessário. Basta executar o hook after_postgres no contêiner de dados e o restante no contêiner web.

O exemplo acima pode ser estendido para provisionar ainda mais bancos de dados. Para fazer isso, provisione mais bancos de dados duplicando as chamadas de criação de banco de dados, etc., e certifique-se de adicionar sites adicionais em multisite.yml.

Certifique-se de alterar o nó host_names em multisite.yml para corresponder ao nome de host real que você deseja hospedar.

Além disso, se você planeja executar HTTPS, precisará de um proxy na frente do site para lidar com isso, pois a funcionalidade letsencrypt integrada não funcionará em um cenário multisite.

69 curtidas
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

Eu estava me perguntando o que o valor db_id: 2 na configuração sugerida acima faz?

Além disso, qual é o procedimento para adicionar um novo site à configuração multissite existente? É apenas:

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

Eu estava me perguntando se havia uma maneira de evitar impactar todos os outros sites existentes fazendo um bootstrap ou reconstrução completa e, de alguma forma, apenas adicionar o banco de dados extra necessário?


  1. Eu tentei ./launcher rebuild multisite primeiro, mas isso parece falhar ↩︎

Acho que o ID do banco de dados não é mais necessário.

Você pode apenas editar o arquivo multisite com o novo site e fazer um

sv restart unicorn

E então migrar o banco de dados.

1 curtida

Você é um salva-vidas!

Eu estava sentindo falta deste comando para reiniciar (também tentei sv reload unicorn, mas de alguma forma isso não foi suficiente).

Em termos de criação do banco de dados, já existe uma maneira de fazer isso automaticamente? Seria bom ter rake db:create[mynewdbname]. Caso contrário, posso escrever um pequeno script shell.

No momento, eu crio manualmente (crio o banco de dados e defino as permissões) e depois faço um RAILS_DB=newdb rake db:migrate para popular.

E só para verificar se estou fazendo algo estúpido:

  • No momento, estou editando o arquivo multisite dentro do docker (/var/www/discourse/config/multisite.yml)
  • Criando o db manualmente
  • Executando rake db:migrate
  • sv restart unicorn
  • Eu também tenho que editar o arquivo yaml fora do docker para que a configuração multisite esteja em sincronia em caso de qualquer reconstrução ou atualização futura.

Estou sendo bobo editando a configuração multisite em 2 lugares diferentes quando já existe uma maneira de editar em um lugar e enviar as alterações?

1 curtida

É possível organizar um pouco esta documentação e fornecer mais orientações nela? Sou extremamente novo no Docker, para começar, e embora tenha experiência com servidores Linux, não sou um profissional nisso. Sou da velha guarda, adoro meus cron jobs e scripts shell e coisas estranhas assim com Apache multi site, etc. Mas isso é um pouco mais complexo e usa uma linguagem de programação diferente da que estou acostumado… Talvez até mesmo um vídeo demonstrativo de algum tipo? Seria bom se o Discourse fosse apenas preparado para multi site e, dessa forma, tudo o que você teria que fazer seria editar alguns arquivos, etc.

2 curtidas

Basta colar essa estrofe de texto e editá-la conforme necessário.

Você também precisará de um proxy reverso ou seguir Configurar Let’s Encrypt com vários domínios / redirecionamentos para obter certificados para todos os domínios.

Veja também Configuração de Multisite com Let’s Encrypt e sem Proxy Reverso. Mas isso precisa ser atualizado para ter outra linha necessária que você pode obter do link anterior. Eu estava querendo atualizá-lo, mas ainda não consegui.

1 curtida

Se eu estiver fazendo multisite, para onde devo apontar meu domínio? Para o mesmo IP do servidor (que hospeda outro fórum)?

Sim, aponte todos os domínios para o mesmo IP do servidor.
Configure um proxy reverso com Nginx ou Caddy server.
Caddy é o melhor, pois oferece certificados SSL automáticos gratuitos para todos os seus domínios.

1 curtida

Segui este tutorial para configurar com sucesso uma instalação multissite com Docker. Recentemente, encontrei um erro ao tentar atualizar e acredito que a linha:

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

Deveria ser editada para:

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

Alguém poderia confirmar/editar o tutorial?

1 curtida

Sim. Eu também encontrei isso. Você vai querer fazer essa alteração, caso contrário, seu bootstrap falhará.

2 curtidas

Eu confirmo com entusiasmo também, que esta correção é obrigatória!

certo, editado, obrigado!

2 curtidas