Я указал virtual_alias_maps = mysql:/etc/postfix/mysql-virtual-alias-maps.cf
, но все же у меня есть такие ошибки, как
предупреждение: хеш: / etc / postfix / virtual недоступен. открыть базу данных /etc/postfix/virtual.db: нет такого файла или каталога
Если я создам файлы virtual и virtual.db, все будет работать нормально, но я хочу, чтобы моя учетная запись виртуального пользователя хранилась в БД, а не в файле.
Почему postfix использует файл virtual.db вместо таблицы db?
postconf -n
:
alias_maps = hash:/etc/aliases
broken_sasl_auth_clients = yes
config_directory = /etc/postfix
dovecot_destination_recipient_limit = 1
inet_interfaces = all
inet_protocols = ipv4
milter_default_action = accept
milter_protocol = 2
mydestination = localhost
non_smtpd_milters = unix:/var/run/opendkim/opendkim.sock
smtp_tls_note_starttls_offer = yes
smtpd_milters = unix:/var/run/opendkim/opendkim.sock
smtpd_recipient_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination
smtpd_sasl_auth_enable = yes
smtpd_sasl_local_domain = example.tst
smtpd_sasl_path = private/auth
smtpd_sasl_security_options = noanonymous
smtpd_sasl_type = dovecot
smtpd_tls_auth_only = no
smtpd_tls_cert_file = /etc/dovecot/dovecot.pem
smtpd_tls_key_file = /etc/dovecot/private/dovecot.pem
smtpd_tls_loglevel = 1
smtpd_tls_received_header = yes
smtpd_tls_security_level = may
smtpd_tls_session_cache_timeout = 3600s
smtpd_use_tls = yes
virtual_alias_maps = mysql:/etc/postfix/mysql-virtual-alias-maps.cf
virtual_mailbox_domains = mysql:/etc/postfix/mysql-virtual-mailbox-domains.cf
virtual_mailbox_maps = mysql:/etc/postfix/mysql-virtual-mailbox-maps.cf
virtual_transport = dovecot
На самом деле у меня есть / etc / postfix / virtual в master.cf:
submission inet n - - - - smtpd
-o smtpd_tls_security_level=encrypt
-o smtpd_sasl_auth_enable=yes
-o smtpd_sasl_type=dovecot
-o smtpd_sasl_path=private/auth
-o smtpd_sasl_security_options=noanonymous
-o smtpd_sasl_local_domain=$myhostname
-o smtpd_client_restrictions=permit_sasl_authenticated,reject
-o smtpd_sender_login_maps=hash:/etc/postfix/virtual
-o smtpd_sender_restrictions=reject_sender_login_mismatch
-o smtpd_recipient_restrictions=reject_non_fqdn_recipient,reject_unknown_recipient_domain,permit_sasl_authenticated,reject
Проблема была в линии -o smtpd_sender_login_maps=hash:/etc/postfix/virtual
в master.cf. Я забыл посмотреть туда, потому что эта точная конфигурация месяцами работала нормально на другом моем сервере.
Я решил это, изменив строку в etc/postfix/main.cf
:
virtual_alias_maps = hash:/etc/postfix/virtual
к
virtual_alias_maps = hash:/etc/aliases
(или в качестве альтернативы просто создайте etc/postfix/virtual
файл с содержимым):
your_linux_username: your_email@gmail.com
затем перезапустите постфикс: sudo systemctl restart postfix
а затем были отправлены письма.