Сейчас провожу проверки и изменения в файле app.yml — ранее очистил логи. Попробую отправить письма и сообщу о результатах.
EDIT
Очистка логов и отправка писем на Gmail или на мой собственный домен не показывают ошибок. Письма приходят на Gmail, но не на мой домен.
Логи в MailGun говорят примерно следующее:
{
"recipient": "me@mydomain",
"id": "SCBCSJxDSqupdU9Da29rRw",
"envelope": {
"sender": "postmaster@mg.mydomain",
"targets": "me@mydomain",
"transport": "smtp",
"sending-ip": "192.168.0.1"
},
"timestamp": 1697462206.8430145,
"user-variables": {},
"message": {
"headers": {
"from": "Discourse Test Forum <postmaster@mg.mydomain>",
"message-id": "9d3b190d-bcbd-4378-8eb6-fc90cd57fe35@discourse.mydomain",
"to": "me@mydomain",
"subject": "[Discourse Test Forum] Email Deliverability Test"
},
"attachments": [],
"size": 4546
},
"storage": {
"region": "us-west1",
"key": "BAABAQUOTl3y4PtvsqlN5Z2OvaxXslLlZA",
"env": "production",
"url": "https://storage-us-west1.api.mailgun.net/v3/domains/mg.mydomain/messages/BAABAQUOTl3y4PtvsqlN5Z2OvaxXslLlZA"
},
"reason": "generic",
"delivery-status": {
"enhanced-code": "",
"mx-host": "mydomain",
"description": "",
"certificate-verified": true,
"attempt-no": 1,
"code": 550,
"message": "Verification failed for <bounce+674b6a.be6180c-me=mydomain@mg.mydomain>\nThe mail server does not recognize bounce+674b6a.be6180c-me=mydomain@mg.mydomain as a valid sender.\nSender verify failed",
"session-seconds": 40.878,
"tls": true
},
"campaigns": [],
"severity": "permanent",
"tags": [],
"recipient-domain": "mydomain",
"flags": {
"is-routed": false,
"is-authenticated": true,
"is-test-mode": false,
"is-system-test": false
},
"log-level": "error",
"event": "failed"
}
Это происходит только при попытке отправки на мой собственный домен. Если я пробую любой другой домен — всё работает, независимо от того, бесплатный он или нет.
Текущие настройки в файле app.yml:
## это шаблон контейнера Docker Discourse all-in-one (standalone)
##
## После внесения изменений в этот файл ОБЯЗАТЕЛЬНО выполните пересборку:
## /var/discourse/launcher rebuild app
##
## БУДЬТЕ ОЧЕНЬ ОСТОРОЖНЫ ПРИ РЕДАКТИРОВАНИИ!
## YAML-ФАЙЛЫ ЧРЕЗВЫЧАЙНО ЧУВСТВИТЕЛЬНЫ К ОШИБКАМ В ПРОБЕЛАХ И ВЫРАВНИВАНИИ!
## Для проверки файла используйте http://www.yamllint.com/
templates:
- "templates/postgres.template.yml"
- "templates/redis.template.yml"
- "templates/web.template.yml"
## Раскомментируйте следующую строку, чтобы включить слушатель IPv6
#- "templates/web.ipv6.template.yml"
- "templates/web.ratelimited.template.yml"
## Раскомментируйте эти две строки, если хотите добавить Lets Encrypt (https)
- "templates/web.ssl.template.yml"
- "templates/web.letsencrypt.ssl.template.yml"
## какие TCP/IP порты должен открывать этот контейнер?
## Если вы хотите, чтобы Discourse использовал тот же порт, что и другой веб-сервер (например, Apache или nginx),
## см. https://meta.discourse.org/t/17247 для деталей
expose:
- "80:80" # http
- "443:443" # https
params:
db_default_text_search_config: "pg_catalog.english"
## Установите db_shared_buffers максимум на 25% от общего объёма памяти.
## Значение будет установлено автоматически при загрузке на основе обнаруженной оперативной памяти, либо вы можете переопределить его
db_shared_buffers: "2048MB"
## может улучшить производительность сортировки, но увеличивает потребление памяти на каждое подключение
#db_work_mem: "40MB"
## Какую ревизию Git должен использовать этот контейнер? (по умолчанию: 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
## Сколько одновременных веб-запросов поддерживается? Зависит от объёма памяти и количества ядер CPU.
## Значение будет установлено автоматически при загрузке на основе обнаруженных процессоров, либо вы можете переопределить его
UNICORN_WORKERS: 8
## TODO: Доменное имя, на которое будет реагировать этот экземпляр Discourse
## Обязательно. Discourse не будет работать с чистым IP-адресом.
DISCOURSE_HOSTNAME: mydomain
## Раскомментируйте, если хотите, чтобы контейнер запускался с тем же
## именем хоста (-h опция), что указано выше (по умолчанию "$hostname-$config")
#DOCKER_USE_HOSTNAME: true
## TODO: Список email-адресов через запятую, которые станут администраторами и разработчиками
## при первой регистрации, например 'user1@example.com,user2@example.com'
DISCOURSE_DEVELOPER_EMAILS: 'me@mydomain'
## TODO: SMTP-сервер для проверки новых учётных записей и отправки уведомлений
## SMTP-адрес, имя пользователя и пароль обязательны
## ВНИМАНИЕ: символ '#' в пароле SMTP может вызвать проблемы!
DISCOURSE_SMTP_ADDRESS: smtp.mailgun.org
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: postmaster@mg.mydomain
DISCOURSE_SMTP_PASSWORD: "mailgunpassword"
#DISCOURSE_SMTP_ENABLE_START_TLS: true # (опционально, по умолчанию true)
#DISCOURSE_SMTP_FORCE_TLS: true
DISCOURSE_SMTP_DOMAIN: mydomain
DISCOURSE_NOTIFICATION_EMAIL: postmaster@mg.mydomain
## Если вы добавили шаблон Lets Encrypt, раскомментируйте ниже, чтобы получить бесплатный SSL-сертификат
LETSENCRYPT_ACCOUNT_EMAIL: freemailaccount
## Адрес CDN (http или https) для этого экземпляра Discourse (настроен на получение)
## см. https://meta.discourse.org/t/14857 для деталей
#DISCOURSE_CDN_URL: https://discourse-cdn.example.com
## Ключ лицензии MaxMind для определения местоположения по IP-адресу
## см. https://meta.discourse.org/t/-/137387/23 для деталей
#DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456
## Контейнер Docker не сохраняет состояние; все данные хранятся в /shared
volumes:
- volume:
host: /var/discourse/shared/standalone
guest: /shared
- volume:
host: /var/discourse/shared/standalone/log/var-log
guest: /var/log
## Плагины размещаются здесь
## см. https://meta.discourse.org/t/19157 для деталей
hooks:
after_code:
- exec:
cd: $home/plugins
cmd:
- git clone https://github.com/discourse/docker_manager.git
- git clone https://github.com/discourse/discourse-spoiler-alert.git
- git clone https://github.com/discourse/discourse-solved.git
- git clone https://github.com/discourse/discourse-docs.git
## Любые пользовательские команды для запуска после сборки
run:
- exec: echo "Начало пользовательских команд"
## Если вы хотите установить адрес 'From' для вашей первой регистрации, раскомментируйте и измените:
## После получения первого письма о регистрации снова закомментируйте эту строку. Выполнять нужно только один раз.
#- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
- exec: echo "Конец пользовательских команд"
Действительно, единственные изменения, которые были внесены в этот файл, следующие:
DISCOURSE_SMTP_ADDRESS: smtp.mydomain
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: email@mydomain
DISCOURSE_SMTP_PASSWORD: "mydomainmailpassword"
#DISCOURSE_SMTP_ENABLE_START_TLS: true # (опционально, по умолчанию true)
#DISCOURSE_SMTP_FORCE_TLS: true
DISCOURSE_SMTP_DOMAIN: mydomain
DISCOURSE_NOTIFICATION_EMAIL: email@mydomain
Как только получу ответ от кого-либо, внесу эти изменения, проверю логи и сообщу. Или, может быть, просто сделаю это сейчас — опубликую логи и буду ждать ответа. Не должно занять много времени. Посмотрим.