我刚刚在我的 Arch Linux 机器上安装了一个 OpenSMTPD 服务器。当我自己启动它时,它工作正常,但是当我重新启动机器时,它无法启动。
输出如下journalctl -f _SYSTEMD_UNIT=smtpd.service
:
-- Reboot --
Oct 05 15:14:29 campbell-kelly smtpd[260]: info: startup
Oct 05 15:14:29 campbell-kelly smtpd[265]: fatal: smtpd: bind: Cannot assign requested address
Oct 05 15:14:29 campbell-kelly smtpd[260]: warn: lost child: pony express exited abnormally
Oct 05 15:14:29 campbell-kelly smtpd[262]: info: control process exiting
Oct 05 15:14:29 campbell-kelly smtpd[263]: info: lookup agent exiting
Oct 05 15:14:29 campbell-kelly smtpd[266]: warn: ca -> control: pipe closed
Oct 05 15:14:29 campbell-kelly smtpd[264]: warn: scheduler -> control: pipe closed
我不知道问题出在哪里。根据我在互联网上的研究,问题可能出在我的网络接口上。
这是ip link
重启后的输出:
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP mode DEFAULT group default qlen 1000
link/ether fa:16:3e:11:8a:b3 brd ff:ff:ff:ff:ff:ff
这是我的/etc/hosts
:
127.0.0.1 localhost
51.XXX.XXX.159 campbell-kelly.XXX.XX campbell-kelly
感谢您尽力帮助我!
编辑:
我的/etc/smtpd/smtpd.conf
文件:
pki mail.XXX.XX certificate "/etc/smtpd/tls/smtpd.crt"
pki mail.XXX.XX key "/etc/smtpd/tls/smtpd.key"
table creds "/etc/smtpd/creds"
table vdoms "/etc/smtpd/vdoms"
table vusers "/etc/smtpd/vusers"
listen on eth0 tls pki mail.XXX.XX
listen on eth0 port 587 tls-require pki mail.XXX.XX auth <creds>
accept from any for domain <vdoms> virtual <vusers> deliver to mbox
accept for any relay
我的/etc/smtpd/creds
。密码已通过以下方式获取echo test | smtpctl encrypt
:
niols $6$FgkfVn10xLZbDU4O$17y6Wc5YlYMGAzekSxsjZALWnCeLAH3oS4vk8VeUpe5c7l.uGxE3q.27FwXhXA/.EUz/KRVqRedaNX8.AsJw20
我的/etc/smtpd/vdoms
:
XXX.XX
XXX.YY
ZZZ.XX
我的/etc/smtpd/vusers
:
[email protected] niols
[email protected] niols
我的问题实际上只在重启时发生。甚至smtpd -v
当我手动启动时似乎也没有显示任何问题。
答案1
尝试不要监听 eth0,监听 0.0.0.0 可能更好。
listen on 0.0.0.0 port 587 tls-require pki mail.XXX.XX auth <creds>
等等...将另一行相应更改为 eth0。
这样做的好处是可以使用 127.0.0.1 发送邮件,而且即使网络接口还没有任何 IPv4 或 IPv6 地址也可以工作。