Рейтинг:0

Проблемы аутентификации SMTP с Postfix Dovecot

флаг in
Sam

я купил домен пример.com и VPS, и я использовал iRedMail для настройки почтового сервера.

Не желая, чтобы iRedMail портил мой Nginx, я решил установить Nginx и Roundcube самостоятельно. Однако он говорит, что SMTP-сервер не поддерживает аутентификацию. С SMTP все в порядке.

[02-Oct-2021 23:40:16 +0000]: <5gl20r7b> Ошибка PHP: SMTP-сервер не поддерживает аутентификацию (POST /?_task=mail&_unlock=loading1633218016462&_framed=1&_action=send)
[02 октября 2021 23:40:16 +0000]: <5gl20r7b> Ошибка SMTP: ошибка аутентификации: в /var/www/mail/program/lib/Roundcube/rcube.php в строке 1702 (POST /?_task= mail&_unlock=loading1633218016462&_framed=1&_action=отправить)

И вывод postconf -n.

root@mail:~# postconf -n
alias_database = хеш:/etc/postfix/псевдонимы
alias_maps = хеш:/etc/postfix/псевдонимы
allow_min_user = нет
allow_percent_hack = нет
биф = нет
body_checks = pcre:/etc/postfix/body_checks.pcre
каталог_команд = /usr/sbin
уровень_совместимости = 2
content_filter = smtp-amavis:[127.0.0.1]:10024
daemon_directory = /usr/lib/postfix/sbin
data_directory = /var/lib/postfix
debug_peer_level = 2
debugger_command = PATH=/bin:/usr/bin:/usr/local/bin:/usr/X11R6/bin ddd $daemon_directory/$process_name $process_id & sleep 5
disable_vrfy_command = да
dovecot_destination_recipient_limit = 1
enable_long_queue_ids = да
enable_original_recipient = нет
header_checks = pcre:/etc/postfix/header_checks
inet_interfaces = все
inet_protocols = все
lmtp_tls_mandatory_protocols = !SSLv2 !SSLv3
lmtp_tls_protocols = !SSLv2 !SSLv3
mail_owner = постфикс
mailq_path = /usr/bin/mailq
message_size_limit = 15728640
mlmmj_destination_recipient_limit = 1
mydestination = $myhostname, localhost, localhost.localdomain
мой домен = example.com
имя хоста = example.com
мои сети = 127.0.0.1 [::1]
мое происхождение = example.com
newaliases_path = /usr/bin/newaliases
postscreen_access_list = allow_mynetworks cidr:/etc/postfix/postscreen_access.cidr
postscreen_blacklist_action = удалить
postscreen_dnsbl_action = удалить
postscreen_dnsbl_reply_map = texthash:/etc/postfix/postscreen_dnsbl_reply
postscreen_dnsbl_sites = zen.spamhaus.org=127.0.0.[2..11]*3 b.barracudacentral.org=127.0.0.2*2
postscreen_dnsbl_threshold = 2
postscreen_dnsbl_whitelist_threshold = -2
postscreen_greet_action = удалить
proxy_read_maps = $canonical_maps $lmtp_generic_maps $local_recipient_maps $mydestination $mynetworks $recipient_bcc_maps $recipient_canonical_maps $relay_domains $relay_recipient_maps $relocated_maps $sender_bcc_maps $sender_canonical_maps $smtp_generic_maps $smtpd_sender_login_maps $transport_maps $virtual_alias_domains $virtual_alias_maps $virtual_mailbox_domains $virtual_mailbox_maps $smtpd_sender_restrictions $sender_dependent_relayhost_maps
каталог_очередей = /var/spool/postfix
получатель_bcc_maps = прокси: mysql:/etc/postfix/mysql/recipient_bcc_maps_user.cf прокси:mysql:/etc/postfix/mysql/recipient_bcc_maps_domain.cf
получатель_разделитель = +
relay_domains = $mydestination proxy:mysql:/etc/postfix/mysql/relay_domains.cf
sender_bcc_maps = proxy:mysql:/etc/postfix/mysql/sender_bcc_maps_user.cf proxy:mysql:/etc/postfix/mysql/sender_bcc_maps_domain.cf
sender_dependent_relayhost_maps = proxy:mysql:/etc/postfix/mysql/sender_dependent_relayhost_maps.cf
sendmail_path = /usr/sbin/sendmail
setgid_group = постдроп
show_user_unknown_table_name = нет
smtp-amavis_destination_recipient_limit = 1
smtp_tls_CAfile = $smtpd_tls_CAfile
smtp_tls_CApath = /etc/ssl/сертификаты
smtp_tls_loglevel = 1
smtp_tls_mandatory_protocols = !SSLv2 !SSLv3
smtp_tls_note_starttls_offer = да
smtp_tls_protocols = !SSLv2 !SSLv3
smtp_tls_security_level = может
smtpd_command_filter = pcre:/etc/postfix/command_filter.pcre
smtpd_data_restrictions = reject_unauth_pipelining
smtpd_end_of_data_restrictions = check_policy_service inet:127.0.0.1:7777
smtpd_helo_required = да
smtpd_helo_restrictions = Permit_MyNetworks Permit_Sasl_Authenticated check_helo_access pcre:/etc/postfix/helo_access.pcre reject_non_fqdn_helo_hostname reject_unknown_helo_hostname
smtpd_recipient_restrictions = reject_non_fqdn_recipient reject_unlisted_recipient check_policy_service inet:127.0.0.1:7777 allow_mynetworks Permit_sasl_authenticated reject_unauth_destination check_policy_service inet:127.0.0.1:12340
smtpd_reject_unlisted_recipient = да
smtpd_reject_unlisted_sender = да
smtpd_sasl_path = частный/dovecot-аутентификация
smtpd_sasl_type = голубятня
smtpd_sender_login_maps = прокси:mysql:/etc/postfix/mysql/sender_login_maps.cf
smtpd_sender_restrictions = reject_non_fqdn_sender reject_unlisted_sender Permit_myNetworks Allow_sasl_authenticated check_sender_access pcre:/etc/postfix/sender_access.pcre reject_unknown_sender_domain
smtpd_tls_CAfile = /etc/ssl/certs/iRedMail.crt
smtpd_tls_CApath = /etc/ssl/сертификаты
smtpd_tls_cert_file = /etc/ssl/certs/iRedMail.crt
smtpd_tls_dh1024_param_file = /etc/ssl/dh2048_param.pem
smtpd_tls_dh512_param_file = /etc/ssl/dh512_param.pem
smtpd_tls_exclude_ciphers = aNULL, eNULL, EXPORT, DES, RC4, MD5, PSK, aECDH, EDH-DSS-DES-CBC3-SHA, EDH-RSA-DES-CDC3-SHA, KRB5-DE5, CBC3-SHA
smtpd_tls_key_file = /etc/ssl/private/iRedMail.key
smtpd_tls_loglevel = 1
smtpd_tls_mandatory_protocols = !SSLv2 !SSLv3
smtpd_tls_protocols = !SSLv2 !SSLv3
smtpd_tls_security_level = может
swap_bangpath = нет
tls_random_source = dev:/dev/urandom
transport_maps = proxy:mysql:/etc/postfix/mysql/transport_maps_user.cf proxy:mysql:/etc/postfix/mysql/transport_maps_maillist.cf proxy:mysql:/etc/postfix/mysql/transport_maps_domain.cf
unknown_local_recipient_reject_code = 550
виртуальный_алиас_домен =
virtual_alias_maps = proxy:mysql:/etc/postfix/mysql/virtual_alias_maps.cf proxy:mysql:/etc/postfix/mysql/domain_alias_maps.cf proxy:mysql:/etc/postfix/mysql/catchall_maps.cf proxy:mysql:/etc /postfix/mysql/domain_alias_catchall_maps.cf
virtual_gid_maps = статический: 2000
виртуальная_почтовая_база = /var/vmail
виртуальный_почтовый_домен = прокси:mysql:/etc/postfix/mysql/виртуальный_почтовый_домен.cf
virtual_mailbox_maps = proxy:mysql:/etc/postfix/mysql/virtual_mailbox_maps.cf
виртуальный_минимум_uid = 2000
виртуальный_транспорт = голубятня
виртуальные_uid_maps = статические: 2000

РЕДАКТИРОВАТЬ: после некоторых вопросов я включил:

постконф | grep smtp_sasl_auth_enable
smtp_sasl_auth_enable = да

Но с помощью openssl s_client я получил:

503 5.5.1 Ошибка: аутентификация не включена

ОБНОВИТЬ:

После настройки smtpd_sasl_auth_enable = да У меня была возможность ввести свой пароль, но он говорит, что пароль неверен. Я использую менеджер паролей, поэтому пароль должен быть правильным. Кроме того, я могу использовать учетные данные для входа через imap.

535 5.7.8 Ошибка: ошибка аутентификации: UGFzc3dvcmQ6

РЕДАКТИРОВАТЬ: В /var/log/maillog я видел это фатально: указать таблицу паролей через параметр конфигурации `smtp_sasl_password_maps' Поэтому я использовал postconf | grep smtp_sasl_password_maps smtp_sasl_password_maps = Может быть, это то, что не так. Но он не должен быть пустым, так как я использовал iredmail, так какой он должен быть?

anx avatar
флаг fr
anx
Возможно, вы предлагаете зашифрованную и аутентифицированную отправку через порт, отличный от того, на который roundcube пытается отправить почту? Ваша конфигурация и журналы postfix и/или конфигурация roundcube помогут диагностировать это.
anx avatar
флаг fr
anx
Обратите внимание, что довольно странно предлагать и IMAP, и POP3, когда вы собираетесь получать доступ к своей почте через клиент веб-почты. Если это было ошибкой, отключите pop3 в Dovecot.
anx avatar
флаг fr
anx
Вы настраиваете *новый* сервер? Знаете ли вы, что в Ubuntu есть более поздняя версия LTS 20.04, которая теперь почти всегда должна быть предпочтительной версией, поскольку она по-прежнему будет получать стандартную поддержку, когда более старая версия больше не будет?
Sam avatar
флаг in
Sam
Это vps, а «последним» сервером, который они предоставили, был Ubuntu 18.04.
флаг jp
Это проблема между Roundcube и Postfix SMTP.Я удалил вашу конфигурацию Dovecot из вопроса, так как проблема не имеет к ней никакого отношения: Dovecot не является SMTP-сервером.
Nikita Kipriyanov avatar
флаг za
Поскольку `openssl s_client` показывает, что аутентификация не включена, я уверен, что это также не связано с Roundcube. Проблема в постфиксе. Включите отладку для 127.0.0.1, перезапустите его и прочитайте огромные журналы в поисках подсказок. // Я *настоятельно* рекомендую запустить два отдельных экземпляра `smtpd`: один на порту 25 без аутентификации и ретрансляции (только для получения входящей почты с других серверов), а другой на порту 587 "отправки" с аутентификацией и ретрансляцией ( получать почту, отправленную с почтовых клиентов, например, roundcube, и ретранслировать ее на другие серверы). В файле `master.cf` по умолчанию есть для этого условия.
Nikita Kipriyanov avatar
флаг za
Я думаю, что это проблема с библиотекой SASL. Без правильно созданной библиотеки Postfix не включит авторизацию. Но у меня нет абсолютно никакого опыта работы с Dovecot SASL, я всегда использую Cyrus SASL. Если вы можете подумать о переключении на Cyrus SASL (вы все еще можете использовать Dovecot IMAP), я думаю, что смогу помочь.
sebix avatar
флаг ie
Какая у dovecot конфигурация sasl? Регистрирует ли postfix что-нибудь о SASL?
anx avatar
флаг fr
anx
Как правило, вы устанавливаете `smtpd_sasl_auth_enable` (обратите внимание на `d` для *daemon*, в отличие от smtp в роли клиента, например исходящей) внутри вашего файла master.cf - только для определенных служб, не включая службу порта 25. получать почту с других серверов. Ваш вывод `postconf -M` скажет, и если вы процитируете полную командную строку вашего теста s_client, это скажет, какой из них вы тестируете.
Sam avatar
флаг in
Sam
root@mail:~# doveconf | grep sasl imapc_sasl_mechanisms =
Рейтинг:0
флаг in
Sam

Наконец мне удалось настроить свои услуги. Вот несколько моментов, на которые следует обратить внимание, если вы хотите настроить свой.

Включите smtp_sasl_auth_enable и smtpd_sasl_auth_enable. Я не знаю, почему он не включен по умолчанию. Установите smtp_sasl_password_maps, чтобы он знал, где найти пароль. На roundcube установите префикс tls://, а если используете самозаверяющий сертификат, установите в параметрах smtp

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.