OpenSMTPD 在重启时无法工作

OpenSMTPD 在重启时无法工作

我刚刚在我的 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 地址也可以工作。

相关内容