Ciao a tutti!
Sto lavorando all’impostazione di un’istanza Discourse multisito e, sebbene abbia fatto alcuni progressi, mi sto imbattendo in alcuni ostacoli e avrei davvero bisogno della guida di qualcuno. Ho seguito la guida Configurazione multisito con Docker, ma ho ancora alcune domande:
- Dove posso trovare il file “multisite.yml” menzionato? Non lo vedo nella mia cartella
discourse/templates. - Devo configurare gli hook per
after_postgresanche se sto solo usando il volume standard e non un database dedicato? - Esiste un semplice template
app.ymlper una configurazione multisito di base? Non ho intenzione di aggiungere plugin o altro di complicato, solo qualcosa di semplice per iniziare.
Come contesto, attualmente sto eseguendo un’istanza Discourse standard su una VM GCP, accessibile tramite mamacares. Il mio app.yml è praticamente quello predefinito, senza plugin o database dedicato. Se qualcuno ha esperienza con questo o conosce una guida rapida per l’impostazione di una configurazione multisito, apprezzerei molto l’aiuto!
Questo è il mio attuale app.yml come riferimento (ho rimosso i dati sensibili)
## questo è il template del container Docker Discourse standalone all-in-one
##
## Dopo aver apportato modifiche a questo file, DEVI ricostruire
## /var/discourse/launcher rebuild app
##
## FAI MOLTA ATTENZIONE QUANDO MODIFICHI!
## I FILE YAML SONO ESTREMAMENTE SENSIBILI A ERRORI DI SPAZIATURA O ALLINEAMENTO!
## visita http://www.yamllint.com/ per validare questo file se necessario
templates:
- "templates/postgres.template.yml"
- "templates/redis.template.yml"
- "templates/web.template.yml"
## Decommenta la riga successiva per abilitare il listener IPv6
#- "templates/web.ipv6.template.yml"
- "templates/web.ratelimited.template.yml"
## Decommenta queste due righe se desideri aggiungere Lets Encrypt (https)
#- "templates/web.ssl.template.yml"
#- "templates/web.letsencrypt.ssl.template.yml"
## quali porte TCP/IP deve esporre questo container?
## Se vuoi che Discourse condivida una porta con un altro webserver come Apache o nginx,
## vedi https://meta.discourse.org/t/17247 per i dettagli
expose:
- "80:80" # http
- "443:443" # https
params:
db_default_text_search_config: "pg_catalog.english"
## Imposta db_shared_buffers a un massimo del 25% della memoria totale.
## verrà impostato automaticamente da bootstrap in base alla RAM rilevata, o puoi sovrascriverlo
db_shared_buffers: "256MB"
## può migliorare le prestazioni di ordinamento, ma aumenta l'utilizzo della memoria per connessione
#db_work_mem: "40MB"
## Quale revisione Git deve utilizzare questo container? (default: tests-passed)
#version: tests-passed
env:
LC_ALL: en_US.UTF-8
LANG: en_US.UTF-8
LANGUAGE: en_US.UTF-8
# DISCOURSE_DEFAULT_LOCALE: en
## Quante richieste web concorrenti sono supportate? Dipende dalla memoria e dai core della CPU.
## verrà impostato automaticamente da bootstrap in base alle CPU rilevate, o puoi sovrascriverlo
UNICORN_WORKERS: 4
## TODO: Il nome di dominio a cui risponderà questa istanza Discourse
## Obbligatorio. Discourse non funzionerà con un semplice numero IP.
DISCOURSE_HOSTNAME: 'www.mamacares.com'
## Decommenta se vuoi che il container venga avviato con lo stesso
## hostname (-h option) specificato sopra (default "$hostname-$config")
#DOCKER_USE_HOSTNAME: true
## TODO: Elenco di email separate da virgole che diventeranno amministratori e sviluppatori
## alla prima registrazione, esempio 'user1@example.com,user2@example.com'
DISCOURSE_DEVELOPER_EMAILS: '---------'
## TODO: Il server di posta SMTP utilizzato per convalidare i nuovi account e inviare notifiche
# L'INDIRIZZO SMTP, il nome utente e la password sono obbligatori
# ATTENZIONE il carattere '#' nella password SMTP può causare problemi!
DISCOURSE_SMTP_ADDRESS: ----------
#DISCOURSE_SMTP_PORT: --------
DISCOURSE_SMTP_USER_NAME: ----------
DISCOURSE_SMTP_PASSWORD: ------------
#DISCOURSE_SMTP_ENABLE_START_TLS: true # (opzionale, default true)
#DISCOURSE_SMTP_DOMAIN: discourse.example.com # (richiesto da alcuni provider)
#DISCOURSE_NOTIFICATION_EMAIL: noreply@discourse.example.com # (indirizzo da cui inviare le notifiche)
## Se hai aggiunto il template Lets Encrypt, decommenta sotto per ottenere un certificato SSL gratuito
#LETSENCRYPT_ACCOUNT_EMAIL: me@example.com
## L'indirizzo CDN http o https per questa istanza Discourse (configurato per il pull)
## vedi https://meta.discourse.org/t/14857 per i dettagli
#DISCOURSE_CDN_URL: https://discourse-cdn.example.com
## L'ID account e la chiave di licenza Maxmind per la geolocalizzazione degli indirizzi IP
## vedi https://meta.discourse.org/t/-/173941 per i dettagli
#DISCOURSE_MAXMIND_ACCOUNT_ID: 123456
#DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456
## Il container Docker è stateless; tutti i dati sono memorizzati in /shared
volumes:
- volume:
host: /var/discourse/shared/standalone
guest: /shared
- volume:
host: /var/discourse/shared/standalone/log/var-log
guest: /var/log
## I plugin vanno qui
## vedi https://meta.discourse.org/t/19157 per i dettagli
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:
#- www.mamacares.com
- www.vet.community
after_bundle_exec:
- exec: cd /var/www/discourse && sudo -E -u discourse bundle exec rake multisite:migrate
## Qualsiasi comando personalizzato da eseguire dopo la build
run:
- exec: echo "Inizio comandi personalizzati"
## Se vuoi impostare l'indirizzo email 'Da' per la tua prima registrazione, decommenta e modifica:
## Dopo aver ricevuto la prima email di registrazione, ricommenta la riga. Deve essere eseguita solo una volta.
#- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
- exec: echo "Fine comandi personalizzati"
Grazie mille e attendo con ansia qualsiasi consiglio possiate condividere!