Некоторый контекст: Emails have stopped sending - end of file reached
Примерно неделю назад (13 января 2021 года) отправка писем через сервер Google smtp-relay.gmail.com начала завершаться ошибкой (это разрешённый и intended способ использования для пользователей Google Apps).
Sidekiq сообщал об ошибках с EOFErrors:
Jobs::HandledExceptionWrapper: Wrapped EOFError: end of file reached
А в логах (/logs) также отображались неудачные задачи:
Job exception: end of file reached
Стек вызовов доступен в другом посте.
===================
Расследование показало, что актуальные установки Discourse подключаются к SMTP-ретрансляторам с использованием команды ‘EHLO localhost’, и Google начал отклонять такие запросы примерно неделю назад.
По данным tcpdump на продакшн-инстансе:
0x0030: d10f f8e4 4548 4c4f 206c 6f63 616c 686f ....EHLO.localho
0x0040: 7374 0d0a st..
...
0x0030: de62 f0c3 3432 3120 342e 372e 3020 5472 .b..421.4.7.0.Tr
0x0040: 7920 6167 6169 6e20 6c61 7465 722c 2063 y.again.later,.c
0x0050: 6c6f 7369 6e67 2063 6f6e 6e65 6374 696f losing.connectio
0x0060: 6e2e 2028 4548 4c4f 2920 6a31 3673 6d34 n..(EHLO).j16sm4
0x0070: 3831 3932 3976 736d 2e31 202d 2067 736d 81929vsm.1.-.gsm
0x0080: 7470 0d0a tp..
Повторение теста через telnet дало тот же результат:
root@conversation:~# telnet smtp-relay.gmail.com 587
Trying 74.125.137.28...
Connected to smtp-relay.gmail.com.
Escape character is '^]'.
220 smtp-relay.gmail.com ESMTP ls8sm507258pjb.6 - gsmtp
ehlo localhost.localdomain
421 4.7.0 Try again later, closing connection. (EHLO) ls8sm507258pjb.6 - gsmtp
Connection closed by foreign host.
Однако использование домен-специфичного EHLO работает корректно:
root@conversation:~# telnet smtp-relay.gmail.com 587
Trying 74.125.137.28...
Connected to smtp-relay.gmail.com.
Escape character is '^]'.
220 smtp-relay.gmail.com ESMTP p10sm668563uaw.3 - gsmtp
ehlo conversation.sevarg.net
250-smtp-relay.gmail.com at your service, [64.227.96.27]
250-SIZE 157286400
250-8BITMIME
250-STARTTLS
250-ENHANCEDSTATUSCODES
250-PIPELINING
250-CHUNKING
250 SMTPUTF8
======
На основе логов я определил файл, который нужно изменить для проверки исправления (в образе Docker):
/var/www/discourse/vendor/bundle/ruby/2.7.0/gems/mail-2.7.1/lib/mail/network/delivery_methods/smtp.rb
Изменение
DEFAULTS = {
:address => 'localhost',
:port => 25,
:domain => 'localhost.localdomain',
на
DEFAULTS = {
:address => 'conversation.sevarg.net',
:port => 25,
:domain => 'conversation.sevarg.net',
решило проблему (после перезапуска инстанса). Теперь команда EHLO отправляется с доменным именем, и письма корректно отправляются с моего инстанса.
================
Желаемое поведение: при отправке писем стандартная установка Discourse должна использовать настроенное доменное имя для начального подключения к SMTP-серверу. Альтернативно, должна существовать конфигурационная опция для переопределения отправляемого домена. Если такая опция существует, я не смог найти её через поиск.