Вопрос доставки Dovecot

Я использую вымышленный адрес электронной почты username@domainname.com для этого случая. testuser это локальная учетная запись на моем сервере Ubuntu 14.04.

У меня есть полнофункциональный почтовый сервер, настроенный с использованием postfix и dovecot, следуя этому руководству по ArsTechnica.

У меня проблема с некоторыми локально отправленными сообщениями. Большинство работает (сгенерировано из пользовательского crontab т.е.), но следующее не будет. Они будут зависать в очереди и никогда не будут отправлены из-за следующей ошибки:

Nov 14 10:32:36 mail dovecot: lda(testuser): Error: user testuser: Initialization failed: Namespace '': mkdir(/var/mail/vmail//testuser/mail) failed: Permission denied (euid=1000(testuser) egid=1000(testuser) missing +w perm: /var/mail/vmail/, dir owned by 5000:5000 mode=0755)

Это включает в себя тестовые сообщения, отправленные с sendmail -bv test@domain.com

Очередь выглядит так:

79B4A812E1     2023 Fri Nov 14 10:17:46  MAILER-DAEMON
                                                       (temporary failure)
                                     testuser@domainname.com

У меня есть структура папок /var/mail/vmail/domainname.com/username/mail/

Так что dovecot не использует папку domainname.com, а также не папку username. Я нашел возможное решение онлайн, используя настройки mail_location в /etc/dovecot/conf.d/10-mail.conf, но я беспокоюсь, что это не изящное решение, так как другие локальные процессы действительно отправляют почту на правильный адрес. Это также из идентификатора пользователя 1000 (testuser)

При чтении одного из сообщений в очереди с postqueue -q <MESSAGE_ID>, он отправляет почту на действительный адрес:. Тем не менее, он пытается отправить его с userid 1000, может быть, он должен пытаться передать его пользователю vmail (uid gid 5000)?

Это вывод postconf -n

alias_database = hash:/etc/aliases
alias_maps = hash:/etc/aliases
append_dot_mydomain = no
biff = no
broken_sasl_auth_clients = yes
canonical_maps = hash:/etc/postfix/canonical
config_directory = /etc/postfix
default_destination_concurrency_limit = 5
disable_vrfy_command = yes
dovecot_destination_recipient_limit = 1
home_mailbox = Maildir/
inet_interfaces = all
mailbox_command = /usr/lib/dovecot/deliver -c /etc/dovecot/dovecot.conf -m "${EXTENSION}"
mailbox_size_limit = 0
message_size_limit = 104857600
milter_connect_macros = j {daemon_name} v {if_name} _
milter_default_action = accept
milter_protocol = 2
mydestination = localhost, localhost.localdomain, domainname.com
myhostname = domainname.com
mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128
myorigin = /etc/mailname
non_smtpd_milters = $smtpd_milters
postscreen_access_list = permit_mynetworks
postscreen_dnsbl_action = enforce
postscreen_dnsbl_sites = zen.spamhaus.org, b.barracudacentral.org, bl.spamcop.net
postscreen_greet_action = enforce
readme_directory = no
recipient_delimiter = +
relay_destination_concurrency_limit = 1
relayhost =
smtp_tls_note_starttls_offer = yes
smtp_tls_security_level = may
smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache
smtp_use_tls = yes
smtpd_banner = $myhostname ESMTP
smtpd_helo_required = yes
smtpd_helo_restrictions = permit_sasl_authenticated, permit_mynetworks, reject_non_fqdn_helo_hostname, reject_invalid_helo_hostname, reject_unknown_helo_hostname, permit
smtpd_milters = unix:/spamass/spamass.sock unix:/clamav/clamav-milter.ctl unix:/opendkim/opendkim.sock
smtpd_recipient_restrictions = permit_sasl_authenticated, permit_mynetworks, reject_unknown_client_hostname, reject_unknown_sender_domain, reject_unknown_recipient_domain, reject_unauth_pipelining, reject_unauth_destination, reject_invalid_hostname, reject_non_fqdn_sender
smtpd_relay_restrictions = permit_mynetworks permit_sasl_authenticated defer_unauth_destination
smtpd_sasl_auth_enable = yes
smtpd_sasl_authenticated_header = yes
smtpd_sasl_local_domain = $myhostname
smtpd_sasl_path = private/dovecot-auth
smtpd_sasl_security_options = noanonymous
smtpd_sasl_type = dovecot
smtpd_sender_login_maps = $virtual_mailbox_maps
smtpd_sender_restrictions = reject_unknown_sender_domain, reject_sender_login_mismatch
smtpd_tls_CAfile = /etc/ssl/certs/ca-certificates.crt
smtpd_tls_ask_ccert = yes
smtpd_tls_auth_only = yes
smtpd_tls_cert_file = /etc/ssl/private/ssl-chain-mail-domainname.com.pem
smtpd_tls_ciphers = high
smtpd_tls_key_file = /etc/ssl/private/ssl-key-decrypted-mail-domainname.com.key
smtpd_tls_loglevel = 1
smtpd_tls_mandatory_ciphers = medium
smtpd_tls_mandatory_protocols = SSLv3, TLSv1
smtpd_tls_received_header = yes
smtpd_tls_security_level = may
smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache
smtpd_tls_session_cache_timeout = 3600s
smtpd_use_tls = yes
tls_random_source = dev:/dev/urandom
virtual_alias_maps = hash:/etc/postfix/virtual
virtual_mailbox_domains = hash:/etc/postfix/virtual-mailbox-domains
virtual_mailbox_maps = hash:/etc/postfix/virtual-mailbox-users
virtual_transport = dovecot

1 ответ

Я решил это.

На самом деле это был почтовый почтовый ящик crontab, который не работал, в противоположность тому, что я сказал в своем вопросе. Локальный пользователь testuser не был определен в /etc/aliases с реальным адресом электронной почты, поэтому он будет пытаться отправить только от имени учетной записи "testuser", что недействительно.

правильная запись в /etc/aliases выглядит следующим образом:

testuser: username@domainname.com
Другие вопросы по тегам