Cualquier subdominio aleatorio redirige a www

Redirección de subdominios aleatorios a www

  1. Obtén tu AccessKey de Alibaba Cloud (usaremos Alibaba Cloud como ejemplo; solicita tu propia clave).
AccessKey ID: LTAI5tQCfDcVcghn5
AccessKey Secret: J8ZayXB44MIWa1Mfnj
  1. Instala acme.sh
cd ~
curl https://get.acme.sh | sh
  1. Cambia la CA predeterminada a Let’s Encrypt y solicita nuevamente el certificado:
# Cambiar la CA predeterminada a Let's Encrypt
~/.acme.sh/acme.sh --set-default-ca --server letsencrypt
# Solicitar un certificado comodín (reemplaza discourse.cc con tu dominio)
~/.acme.sh/acme.sh --issue --dns dns_ali -d discourse.cc -d '*.discourse.cc'
  1. Instala el certificado en el directorio SSL de Discourse.
    Copia el certificado al directorio SSL de Discourse

Ejecuta como root (reemplaza discourse.cc con tu dominio):

cp /home/admin/.acme.sh/airsc.cc_ecc/discourse.cc.key /var/discourse/shared/standalone/ssl/discourse.cc.key
cp /home/admin/.acme.sh/discourse.cc_ecc/fullchain.cer /var/discourse/shared/standalone/ssl/discourse.cc.cer
chmod 644 /var/discourse/shared/standalone/ssl/discourse.cc.*

Verifica que los archivos existan:

ls -l /var/discourse/shared/standalone/ssl/

Deberías ver airsc.cc.cer y airsc.cc.key.

  1. Modifica la configuración de Discourse y reconstruye.
DISCOURSE_HOSTNAME: 'www.discourse.cc'
DISCOURSE_HOSTNAME_ALIASES: 'discourse.cc'
DISCOURSE_DISABLE_LETSENCRYPT: 'true'
  1. Configura las reglas de redirección de Nginx (si aún no están configuradas).
server {
    listen 80;
    server_name ~^(?!www\.)(.+)\.discourse\.cc$;
    return 301 https://www.discourse.cc$request_uri;
}
server {
    listen 443 ssl;
    server_name ~^(?!www\.)(.+)\.discourse\.cc$;
    ssl_certificate ...;
    ssl_certificate_key ...;
    return 301 https://www.discourse.cc$request_uri;
}
  1. Reconstruye el contenedor.
cd /var/discourse
sudo ./launcher rebuild app