Я пытаюсь заставить Gmail отправлять электронную почту из моего тщеславного домена - по понятным причинам он хочет использовать SMTP-сервер, настроенный для этого домена. Я пытался настроить postfix в качестве SMTP-сервера для моего личного домена, но в gmail я продолжаю получать ошибки аутентификации. Мой опыт очень похож на Postfix как SMTP-сервер для Gmail. (Параметр Google "Отправить письмо как") Я нашел очень мало другой полезной информации в Интернете по этой конкретной проблеме. Большинство других пользователей, которые, кажется, спрашивают об этой проблеме, получают ответы «вот как использовать gmail в качестве SMTP-сервера», которые явно бесполезны. Gmail не может отправлять сообщения с моего личного домена, поэтому мне (и ему) нужен SMTP-сервер.
Вот мои файлы конфигурации, я использовал host.example.com для полного имени хоста и домена сервера, на котором работает постфикс. - Я использовал vanity.domain в качестве имени домена тщеславия, которое я пытаюсь заставить работать с gmail и user1 и т.д. как разные пользователи.
Я добавил сертификаты Letsencrypt, потому что предполагалось, что Gmail может отклонять самозаверяющие. Я не знаю, правильно ли это, или я сделал это правильно - я использовал certbot --apache на host.domain.com - сертификаты действительно работают в браузере для host.exmaple.com.
кстати, мне еще не удалось заставить postfix использовать порт 587 - поэтому я восстановил: 587, откуда он был [vanity.domain]: 587 в конфигах.
main.cf (он стал очень длинным, со всеми предложениями, которые предлагали добавить разные руководства)
# See /usr/share/postfix/main.cf.dist for a commented, more complete version
# Debian specific: Specifying a file name will cause the first
# line of that file to be used as the name. The Debian default
# is /etc/mailname.
#myorigin = /etc/mailname
smtpd_banner = $myhostname ESMTP $mail_name (Ubuntu)
biff = no
# appending .domain is the MUA's job.
append_dot_mydomain = no
# Uncomment the next line to generate "delayed mail" warnings
#delay_warning_time = 4h
readme_directory = no
# See http://www.postfix.org/COMPATIBILITY_README.html -- default to 2 on
# fresh installs.
compatibility_level = 2
# TLS parameters
smtpd_tls_cert_file=/etc/letsencrypt/live/host.example.com/fullchain.pem
#smtpd_tls_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem
smtpd_tls_key_file=/etc/letsencrypt/live/host.example.com/privkey.pem
#smtpd_tls_key_file=/etc/ssl/private/ssl-cert-snakeoil.key
smtpd_use_tls=yes
smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache
smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache
# See /usr/share/doc/postfix/TLS_README.gz in the postfix-doc package for
# information on enabling SSL in the smtp client.
smtpd_relay_restrictions = permit_mynetworks permit_sasl_authenticated defer_unauth_destination
myhostname = host.example.com
alias_maps = hash:/etc/aliases
alias_database = hash:/etc/aliases
myorigin = /etc/mailname
mydestination = $myhostname, host.example.com, host, localhost.localdomain, localhost
#relayhost =[vanity.domain]:587
mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128
mailbox_size_limit = 0
recipient_delimiter = +
inet_interfaces = all
inet_protocols = all
virtual_alias_domains = vanity.domain
virtual_alias_maps = hash:/etc/postfix/virtual
smtp_sasl_password_maps = hash:/etc/postfix/sasl_passwd
smtp_sasl_security_options = noplaintext,noanonymous
smtp_sasl_tls_security_options = noanonymous
smtp_sasl_auth_enable = yes
smtp_use_tls = yes
smtp_tls_CAfile = /etc/ssl/certs/ca-certificates.crt
#smtp_tls_security_level = may
#smtp_tls_protocols = !SSLv2, !SSLv3
#smtp_tls_mandatory_protocols = !SSLv2, !SSLv3
#smtp_tls_mandatory_ciphers = high
smtpd_sasl_type = dovecot
smtpd_sasl_path = private/auth
smtpd_sasl_local_domain =
smtpd_sasl_security_options = noanonymous
broken_sasl_auth_clients = yes
smtpd_sasl_auth_enable = yes
smtpd_recipient_restrictions = permit_sasl_authenticated,permit_mynetworks,reject_unauth_destination
smtp_tls_security_level = may
smtpd_tls_security_level = may
smtp_tls_note_starttls_offer = yes
smtpd_tls_loglevel = 1
smtpd_tls_received_header = yes
smtp_tls_security_level = may
smtp_tls_protocols = !SSLv2, !SSLv3
smtp_tls_mandatory_protocols = !SSLv2, !SSLv3
smtp_tls_mandatory_ciphers = high
smtp_tls_loglevel = 1
sender_canonical_maps = tcp:127.0.0.1:10001
sender_canonical_classes = envelope_sender
recipient_canonical_maps = tcp:127.0.0.1:10002
recipient_canonical_classes = envelope_recipient
и т.д. / постфикс / виртуальный:
user1@vanity.domain user1@gmail.com
user2@vanity.domain user2@gmail.com
user3@vanity.domain user3@gmail.com
testing@vanity.domain user1@gmail.com
@vanity.domain user1@gmail.com
мой журнал, когда я пытаюсь подключиться (IPS, дата и время удалены):
connect from mail-ua1-f41.google.com
Anonymous TLS connection established from mail-ua1-f41.google.com: TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)
warning: mail-ua1-f41.google.com: SASL PLAIN authentication failed:
lost connection after AUTH from mail-ua1-f41.google.com
disconnect from mail-ua1-f41.google.com ehlo=2 starttls=1 auth=0/1 commands=3/4
sasl_passwd
[vanity.domain] user1:longpassword
Наконец, в настройках SMTP Gmail я заполняю следующее:
smtp server: host.example.com user: user1 (я тоже пробовал user1@vanity.domain и user1@host.example.com - я не уверен, что это должно быть) пароль: longpassword порт: 25 (пробовал 587 и 465 тоже) Безопасность: TLS (пробовал SSL и не защищен)
Я сдался и вместо этого использовал sendgrid