No se puede enviar correo por el servidor smtp (mailjet)

¡Hola! Tengo una pregunta sobre el envío de correos electrónicos. Agradeceré cualquier ayuda :smiling_face_with_three_hearts:

Estoy usando Mailjet como servidor SMTP. He configurado app.yml haciendo referencia al tema (Howto use Mailjet as a free SMTP service for Discourse) y he validado mi dominio y dirección de correo electrónico en Mailjet. He abierto los puertos 80, 443, 578 y 553.

Pero cuando envío un correo electrónico de prueba, no sucede nada.


Este es mi app.yml:

## esta es la plantilla de contenedor Docker de Discourse todo en uno y autónoma
##
## Después de realizar cambios en este archivo, DEBE reconstruir
## /var/discourse/launcher rebuild app
##
## ¡TENGA MUCHO CUIDADO AL EDITAR!
## ¡LOS ARCHIVOS YAML SON MUY, MUY SENSIBLES A ERRORES EN ESPACIOS EN BLANCO O ALINEACIÓN!
## visite http://www.yamllint.com/ para validar este archivo según sea necesario

templates:
  - "templates/postgres.template.yml"
  - "templates/redis.template.yml"
  - "templates/web.template.yml"
  ## Descomente la siguiente línea para habilitar el oyente IPv6
  #- "templates/web.ipv6.template.yml"
  - "templates/web.ratelimited.template.yml"
  ## Descomente estas dos líneas si desea agregar Lets Encrypt (https)
  - "templates/web.ssl.template.yml"
  - "templates/web.letsencrypt.ssl.template.yml"
  - "templates/web.china.template.yml"

## ¿qué puertos TCP/IP debe exponer este contenedor?
## Si desea que Discourse comparta un puerto con otro servidor web como Apache o nginx,
## consulte https://meta.discourse.org/t/17247 para obtener detalles
expose:
  - "80:80"   # http
  - "443:443" # https
  - "553:553"
  - "587:587"
params:
  db_default_text_search_config: "pg_catalog.english"

  ## Establezca db_shared_buffers en un máximo del 25% de la memoria total.
  ## será establecido automáticamente por bootstrap según la RAM detectada, o puede anularlo
  db_shared_buffers: "128MB"

  ## puede mejorar el rendimiento de la clasificación, pero agrega uso de memoria por conexión
  #db_work_mem: "40MB"

  ## ¿Qué revisión de Git debe usar este contenedor? (predeterminado: 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

  ## ¿Cuántas solicitudes web concurrentes se admiten? Depende de la memoria y los núcleos de CPU.
  ## será establecido automáticamente por bootstrap según las CPU detectadas, o puede anularlo
  UNICORN_WORKERS: 2

  ## TODO: El nombre de dominio al que responderá esta instancia de Discourse
  ## Requerido. Discourse no funcionará con un número IP simple.
  DISCOURSE_HOSTNAME: discuss.whitewater.wang

  ## Descomente si desea que el contenedor se inicie con el mismo
  ## nombre de host (-h option) que se especifica arriba (predeterminado "$hostname-$config")
  #DOCKER_USE_HOSTNAME: true

  ## TODO: Lista de correos electrónicos separados por comas que serán administradores y desarrolladores
  ## en el registro inicial, por ejemplo, 'user1@example.com,user2@example.com'
  DISCOURSE_DEVELOPER_EMAILS: 'whitewatercn@outlook.com'

  ## TODO: El servidor de correo SMTP utilizado para validar nuevas cuentas y enviar notificaciones
  # La DIRECCIÓN, el nombre de usuario y la contraseña SMTP son obligatorios
  # ADVERTENCIA: ¡el carácter '#' en la contraseña SMTP puede causar problemas!
  DISCOURSE_SMTP_ADDRESS: in-v3.mailjet.com
  DISCOURSE_SMTP_PORT: 587
  DISCOURSE_SMTP_USER_NAME: 7b14af9b5034******
  DISCOURSE_SMTP_PASSWORD: "46764f565******"
  #DISCOURSE_SMTP_ENABLE_START_TLS: true           # (opcional, predeterminado true)
  # DISCOURSE_SMTP_DOMAIN: beginner.center
  # DISCOURSE_NOTIFICATION_EMAIL: noreply@discuss.whitewater.wang
  # DISCOURSE_SMTP_AUTHENTICATION: login
  DISCOURSE_SMTP_OPENSSL_VERIFY_MODE: none
  # DISCOURSE_SMTP_ENABLE_START_TLS: true


  ## Si agregó la plantilla Lets Encrypt, descomente a continuación para obtener un certificado SSL gratuito
  LETSENCRYPT_ACCOUNT_EMAIL: me@example.com

  ## La dirección CDN http o https para esta instancia de Discourse (configurada para tirar)
  ## consulte https://meta.discourse.org/t/14857 para obtener detalles
  #DISCOURSE_CDN_URL: https://discourse-cdn.example.com
  
  ## La clave de dirección IP de geolocalización de Maxmind para la búsqueda de direcciones IP
  ## consulte https://meta.discourse.org/t/-/137387/23 para obtener detalles
  #DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456

## El contenedor Docker no tiene estado; todos los datos se almacenan en /shared
volumes:
  - volume:
      host: /var/discourse/shared/standalone
      guest: /shared
  - volume:
      host: /var/discourse/shared/standalone/log/var-log
      guest: /var/log

## Los plugins van aquí
## consulte https://meta.discourse.org/t/19157 para obtener detalles
hooks:
  after_code:
    - exec:
        cd: $home/plugins
        cmd:
          - git clone https://github.com/discourse/docker_manager.git

## Cualquier comando personalizado para ejecutar después de la compilación
run:
  - exec: echo "Beginning of custom commands"
  ## Si desea establecer la dirección de correo electrónico 'De' para su primer registro, descomente y cambie:
  ## Después de recibir el primer correo electrónico de registro, vuelva a comentar la línea. Solo necesita ejecutarse una vez.
  - exec: rails r "SiteSetting.notification_email='noreply@discuss.whitewater.wang'"
  - exec: echo "End of custom commands"

@Lhc_fl ¿Podrías echarle un vistazo?

Esto probablemente demuestra que el problema no está en discourse, sino en mailjet.

Considera ./launcher enter app para entrar en tu contenedor docker, luego rake email:test[example@outlook.com] para probar la disponibilidad del correo electrónico.

2 Me gusta

¡Gracias por la respuesta, gran jefe! Probé el comando de prueba y me dio un tiempo de espera agotado.

root@iZ0jlfiypegsmh5fpig7t4Z-app:/var/www/discourse# rake emails:test[whitewatercn@outlook.com]
Testing sending to whitewatercn@outlook.com using in-v3.mailjet.com:587, username:7b14af9b5034dd6e7639d19587cb7831 with plain auth.
SMTP server connection successful.
Sending to whitewatercn@outlook.com. . . 
Sending mail failed.
JavaScript was terminated (either by timeout or explicitly)

Ya se puede enviar, pero no he recibido el correo electrónico

root@iZ0jlfiypegsmh5fpig7t4Z-app:/var/www/discourse# rake emails:test[whitewatercn@outlook.com]
Testing sending to whitewatercn@outlook.com using in-v3.mailjet.com:587, username:7b14af9b5034dd6e7639d19587cb7831 with plain auth.
SMTP server connection successful.
Sending to whitewatercn@outlook.com. . . 
Mail accepted by SMTP server.
Message-ID: fc301347-746b-4b89-8c07-deeb1ee467a4@discuss.whitewater.wang

If you do not receive the message, check your SPAM folder
or test again using a service like http://www.mail-tester.com/.

If the message is not delivered it is not a problem with Discourse.
Check the SMTP server logs for the above Message ID to see why it
failed to deliver the message.

Cambiado a servidor de correo, ya está disponible :upside_down_face:

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.