Impossibile far funzionare Discourse su porte diverse

Voglio eseguire il mio forum Discourse insieme al mio server WordPress, ma ovviamente entrambi utilizzano nativamente le porte 80 e 443. Per aggirare il problema, ho intenzione di utilizzare un reverse proxy NGINX per tradurre i sottodomini esposti all’esterno nelle mie applicazioni in esecuzione su porte diverse nel back-end. Di seguito sono riportati i passaggi che ho seguito per installare Discourse:

mkdir /var/discourse
git clone https://github.com/discourse/discourse_docker.git /var/discourse
cd /var/discourse

# Crea il file di configurazione
cat <<-"EOF" > /var/discourse/containers/discourse
## questo è il modello del container Docker Discourse all-in-one, standalone
##
## Dopo aver apportato modifiche a questo file, DEVI ricostruire
## /var/discourse/launcher rebuild app
##
## FAI MOLTA ATTENIONE DURANTE LA MODIFICA!
## I FILE YAML SONO MOLTO, MOLTO SENSIBILI A ERRORI NELLO SPAZIATURA O NELL'ALLINEAMENTO!
## visita http://www.yamllint.com/ per convalidare questo file se necessario

templates:
- "templates/postgres.template.yml"
- "templates/redis.template.yml"
- "templates/web.template.yml"
- "templates/web.ratelimited.template.yml"
## Scommenta queste due righe se desideri aggiungere Lets Encrypt (https)
#- "templates/web.ssl.template.yml"
#- "templates/web.letsencrypt.ssl.template.yml"

## quali porte TCP/IP dovrebbe esporre questo container?
## Se vuoi che Discourse condivida una porta con un altro server web come Apache o nginx,
## consulta https://meta.discourse.org/t/17247 per i dettagli
expose:
- "10080:80"   # http
- "10443:443" # https

params:
db_default_text_search_config: "pg_catalog.english"

## Imposta db_shared_buffers al massimo al 25% della memoria totale.
## verrà impostato automaticamente da bootstrap in base alla RAM rilevata, oppure puoi sovrascrivere
#db_shared_buffers: "256MB"

## può migliorare le prestazioni di ordinamento, ma aumenta l'uso di memoria per connessione
#db_work_mem: "40MB"

## Quale revisione Git dovrebbe utilizzare questo container? (predefinito: tests-passed)
#version: tests-passed

env:
LC_ALL: en_GB.UTF-8
LANG: en_GB.UTF-8
LANGUAGE: en_GB.UTF-8
# DISCOURSE_DEFAULT_LOCALE: en

## Quanti richieste web simultanee sono supportate? Dipende dalla memoria e dai core della CPU.
## verrà impostato automaticamente da bootstrap in base alle CPU rilevate, oppure puoi sovrascrivere
#UNICORN_WORKERS: 3

## TODO: Il nome di dominio a cui risponderà questa istanza di Discourse
## Obbligatorio. Discourse non funzionerà con un indirizzo IP grezzo.
DISCOURSE_HOSTNAME: 'forum.example.com'

## Scommenta se desideri che il container venga avviato con lo stesso
## nome di host (-h option) specificato sopra (predefinito "$hostname-$config")
#DOCKER_USE_HOSTNAME: true

## TODO: Elenco di email separate da virgola che diventeranno amministratori e sviluppatori
## al primo esempio di registrazione 'user1@example.com,user2@example.com'
DISCOURSE_DEVELOPER_EMAILS: 'webmaster@example.com'

## TODO: Il server SMTP utilizzato per validare nuovi account e inviare notifiche
## INDIRIZZO SMTP, nome utente e password sono obbligatori
## ATTENZIONE: il carattere '#' nella password SMTP può causare problemi!
DISCOURSE_SMTP_ADDRESS: smtp-relay.example.com
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: info@example.com
DISCOURSE_SMTP_PASSWORD: password
DISCOURSE_SMTP_ENABLE_START_TLS: true           # (opzionale, predefinito true)
#DISCOURSE_SMTP_DOMAIN: discourse.example.com    # (richiesto da alcuni provider)
DISCOURSE_NOTIFICATION_EMAIL: no-reply@example.com    # (indirizzo da cui inviare le notifiche)

## Se hai aggiunto il modello Lets Encrypt, scommenta qui sotto per ottenere un certificato SSL gratuito
LETSENCRYPT_ACCOUNT_EMAIL: webmaster@example.com

## L'indirizzo CDN http o https per questa istanza di Discourse (configurato per il recupero)
## consulta https://meta.discourse.org/t/14857 per i dettagli
#DISCOURSE_CDN_URL: https://discourse-cdn.example.com

## La chiave IP di geolocalizzazione Maxmind per la ricerca degli indirizzi IP
## consulta https://meta.discourse.org/t/-/137387/23 per i dettagli
#DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456

## Il container Docker è senza stato; tutti i dati sono archiviati 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
## consulta https://meta.discourse.org/t/19157 per i dettagli
hooks:
after_code:
	- exec:
		cd: $home/plugins
		cmd:
		- git clone https://github.com/discourse/docker_manager.git

## Qualsiasi comando personalizzato da eseguire dopo la compilazione
run:
- exec: echo "Inizio dei comandi personalizzati"
## Se desideri impostare l'indirizzo email 'Da' per la tua prima registrazione, scommenta e modifica:
## Dopo aver ricevuto la prima email di iscrizione, rimetti il commento alla riga. Deve essere eseguito solo una volta.
#- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
- exec: echo "Fine dei comandi personalizzati"
EOF

# Configura Discourse con il file di configurazione
./launcher bootstrap discourse

Posso confermare che Discourse è in ascolto sulle porte corrette:

root@ubuntu-server:~# netstat -tlnp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:10080           0.0.0.0:*               LISTEN      185948/docker-proxy
tcp        0      0 0.0.0.0:8000            0.0.0.0:*               LISTEN      150667/docker-proxy
tcp        0      0 0.0.0.0:9000            0.0.0.0:*               LISTEN      150655/docker-proxy
tcp        0      0 0.0.0.0:10443           0.0.0.0:*               LISTEN      185937/docker-proxy
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      169991/nginx: maste
tcp        0      0 127.0.0.53:53           0.0.0.0:*               LISTEN      519/systemd-resolve
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      1465/sshd: /usr/sbi
tcp        0      0 0.0.0.0:443             0.0.0.0:*               LISTEN      169991/nginx: maste
tcp6       0      0 :::22                   :::*                    LISTEN      1465/sshd: /usr/sbi

Se eseguo curl sull’URL e sulla porta, ottengo 301 Moved permanently:

root@ubuntu-server:~# curl forum.example.com:10080
<html>
<head><title>301 Moved Permanently</title></head>
<body>
<center><h1>301 Moved Permanently</h1></center>
<hr><center>nginx/1.18.0</center>
</body>
</html>

Probabilmente si tratta della porta HTTP che reindirizza alla porta HTTPS. (Usare il flag -I con curl mostrerà la destinazione del reindirizzamento.)

Eseguire curl forum.example.com:10443 dovrebbe caricare il sito come previsto.

Hai guardato l’esecuzione di altri siti web sulla stessa macchina di Discourse?