После того, как я часами копался в SF / SO и много гуглил, я все еще не могу понять, как / etc / aliases используется postfix.
srv.example.com
/etc/aliases
с правилами, включая root: mymail@gmail.com
newaliases
учесть изменения в /etc/aliases
sudo service postfix restart
echo "something" | mailx -s D"subject" root
отправляет письмо на root@example.com
вместо того mymail@gmail.com
Я проследил это в /var/log/maillog
:
Mar 13 17:21:23 srv postfix/smtpd[14462]: A27B540A87: client=localhost[127.0.0.1]
Mar 13 17:21:23 srv postfix/cleanup[14466]: A27B540A87: message-id=<55031c93.Il7wUJmrkLu/WLNL%srv@example.com>
Mar 13 17:21:23 srv opendkim[2065]: A27B540A87: DKIM-Signature field added (s=prod-key-swf, d=example.com)
Mar 13 17:21:23 srv postfix/qmgr[14458]: A27B540A87: from=<srv@example.com>, size=820, nrcpt=1 (queue active)
Mar 13 17:21:23 srv sendmail[14461]: t2DHLNlC014461: to=root, ctladdr=srv@example.com (serveur srv) (500/500), delay=00:00:00, xdelay=00:00:00, mailer=relay, pri=30309, relay=[127.0.0.1] [127.0.0.1], dsn=2.0.0, stat=Sent (Ok: queued as A27B540A87)
Mar 13 17:21:25 srv postfix/smtp[14467]: A27B540A87: to=<root@srv.example.com>, relay=aspmx.l.google.com[64.233.186.27]:25, delay=2, delays=0.1/0.01/1.4/0.48, dsn=5.1.1, status=bounced (host aspmx.l.google.com[64.233.186.27] said: 550-5.1.1 The email account that you tried to reach does not exist. Please try 550-5.1.1 double-checking the recipient's email address for typos or 550-5.1.1 unnecessary spaces. Learn more at 550 5.1.1 http://support.google.com/mail/bin/answer.py?answer=6596 f78si2479139qkh.47 - gsmtp (in reply to RCPT TO command))
Mar 13 17:21:26 srv postfix/bounce[14468]: A27B540A87: sender non-delivery notification: 2297E40A86
Mar 13 17:21:26 srv postfix/qmgr[14458]: A27B540A87: removed
Мои единственные модификации конфигурации постфикса: (Конфигурация нулевого клиента):
myhostname = srv.example.com
myorigin = $mydomain
relayhost = $mydomain
inet_interfaces = loopback-only
mydestination =
Какой шаг мне не хватает, чтобы операторы / etc / aliases применялись должным образом?
Мой sudo postconf -n
:
alias_database = hash:/etc/aliases
alias_maps = hash:/etc/aliases
command_directory = /usr/sbin
config_directory = /etc/postfix
daemon_directory = /usr/libexec/postfix
data_directory = /var/lib/postfix
debug_peer_level = 2
html_directory = no
inet_interfaces = loopback-only
inet_protocols = all
mail_owner = postfix
mailq_path = /usr/bin/mailq.postfix
manpage_directory = /usr/share/man
milter_default_action = accept
mydestination =
myhostname = srv.example.com
myorigin = $mydomain
newaliases_path = /usr/bin/newaliases.postfix
non_smtpd_milters = $smtpd_milters
queue_directory = /var/spool/postfix
readme_directory = /usr/share/doc/postfix-2.6.6/README_FILES
relayhost = $mydomain
sample_directory = /usr/share/doc/postfix-2.6.6/samples
sendmail_path = /usr/sbin/sendmail.postfix
setgid_group = postdrop
smtpd_milters = inet:127.0.0.1:8891
unknown_local_recipient_reject_code = 550
Поняв, что «нулевой клиент» - это нулевой клиент, Я копаю еще немного, чтобы понять виртуальный домен postfix как.
myorigin
к имени хоста сервераmyorigin also specifies the default domain name that is appended to recipient addresses that have no @domain part
(взято из /et/postfix/main.cf
)./etc/aliases
для маршрутизации моей местной почты как моих писем на root
/ fail2ban
/ me
... будет переписан на root@srv.example.com
/ fail2ban@srv.example.com
...xxx@srv.example.com
к mymail@gmail.com
@srv.example.com mymail@gmail.com
в /etc/postfix/canonical
canonical_maps = hash:/etc/postfix/canonical
в /etc/postfix/main.cf
postmap /etc/postfix/canonical
и перезапустите postfix (sudo service postfix restart
)Я пошел немного дальше, чтобы сохранить информацию об исходном целевом пользователе. Для этого можно использовать регулярное выражение:
/etc/postfix/main.cf
, вместо того canonical_maps = hash:/etc/postfix/canonical
, используйте canonical_maps = regexp:/etc/postfix/canonical
/etc/postfix/canonical
, вместо того @srv.example.com mymail@gmail.com
, Я использовал (.+)@(.+).example.com mymail+$1.$2@gmail.com
получать почту на mymail+fail2ban.srv@gmail.com (позже у меня будут srv2, srv3, srvx ...)Я просил о помощи слишком рано, надеюсь, этот ответ поможет другим решить ту же проблему.