Postfix 启动错误端口 25:地址已被使用

Postfix 启动错误端口 25:地址已被使用

我正在尝试在我的服务器上运行 postfix 但不断收到以下错误/var/log/mail.log

postfix/master[5041]: 致命: 绑定 0.0.0.0 端口 25: 地址已在使用中

我做了一些搜索并发现这个优秀的答案Oli 的回复(关于这个问题)建议我基本上删除服务器上的 sendmail 软件包以避免冲突,然后重新安装 postfix,这将安装其自己的 sendmail。不幸的是,它并没有完全解决问题(请参阅下文了解如何解决)。

我按照说明进行了以下检查,并收到了令人鼓舞的答复:

$ dpkg -S `which sendmail`
postfix: /usr/sbin/sendmail

然而当我再次启动 postfix 时,出现了同样的错误。

按照 Oli 的应急计划,我使用以下命令查找占用 25 端口的进程:

$ sudo netstat -pel | grep smtp
tcp        0      0 localhost.localdom:smtp *:*                     LISTEN      root       
35704126    27626/sendmail: MTA

但这就是令人困惑的地方:然后我寻找该过程27626,但却被告知:

dpkg-query:未找到匹配模式的路径27626 个
连接

我打开 htop 并能够找到与以下命令相关的上述 PID:

sendmail:MTA:接受连接

然后我尝试使用和来终止该进程killall sendmailkillall 27626但仍然得到no process found

问题是(除了显而易见的)我不知道如何解释这些发现。我清除了 sendmail 服务器上的内容,所以我只能假设 postfix 自己的 sendmail 版本劫持了端口?我甚至不知道这是否合理。

无论如何,如果有人能纠正我这个问题或者至少提出一些有趣的诊断问题,我将不胜感激。

万一有用的话, 我在服务器上使用 virtualmin 来管理几个不同的域,并且还在运行 wordpress。

提前谢谢了!

响应请求ps -ef在下面发布了

root@upsmart:~# ps -ef
UID        PID  PPID  C STIME TTY          TIME CMD
root         1     0  0 Jan12 ?        00:00:00 init
root         2     1  0 Jan12 ?        00:00:00 [kthreadd/20017]
root         3     2  0 Jan12 ?        00:00:00 [khelper/20017]
root        68     1  0 Jan12 ?        00:00:00 upstart-udev-bridge --daemon
root        75     1  0 Jan12 ?        00:00:00 /sbin/udevd --daemon
root       110     1  0 Jan12 ?        00:00:00 /usr/sbin/sshd -D
root       130    75  0 Jan12 ?        00:00:00 /sbin/udevd --daemon
root       131    75  0 Jan12 ?        00:00:00 /sbin/udevd --daemon
root       175     1  0 Jan12 ?        00:00:00 upstart-socket-bridge --daemon
116        205     1  0 Jan12 ?        00:00:03 dbus-daemon --system --fork --activation=upstart
root       385     1  0 Jan12 ?        00:00:00 /usr/sbin/dovecot -F -c /etc/dovecot/dovecot.conf
root       386     1  0 Jan12 ?        00:00:04 cron
mysql      410     1  0 Jan12 ?        00:08:06 /usr/sbin/mysqld
dovecot    441   385  0 Jan12 ?        00:00:00 dovecot/anvil
root       442   385  0 Jan12 ?        00:00:00 dovecot/log
root       444   385  0 Jan12 ?        00:00:00 dovecot/config
syslog     445     1  0 Jan12 ?        00:00:08 /sbin/syslogd -u syslog
bind       474     1  0 Jan12 ?        00:00:12 /usr/sbin/named -u bind
clamav     844     1  0 Jan12 ?        00:01:34 /usr/sbin/clamd
clamav     951     1  0 Jan12 ?        00:03:27 /usr/bin/freshclam -d --quiet
list       969     1  0 Jan12 ?        00:00:00 /usr/bin/python /usr/lib/mailman/bin/mailmanctl -s -q start
list       970   969  0 Jan12 ?        00:01:03 /usr/bin/python /var/lib/mailman/bin/qrunner --runner=ArchRunner:0:1 -
list       971   969  0 Jan12 ?        00:01:10 /usr/bin/python /var/lib/mailman/bin/qrunner --runner=BounceRunner:0:1
list       972   969  0 Jan12 ?        00:01:03 /usr/bin/python /var/lib/mailman/bin/qrunner --runner=CommandRunner:0:
list       973   969  0 Jan12 ?        00:01:07 /usr/bin/python /var/lib/mailman/bin/qrunner --runner=IncomingRunner:0
list       974   969  0 Jan12 ?        00:01:01 /usr/bin/python /var/lib/mailman/bin/qrunner --runner=NewsRunner:0:1 -
list       976   969  0 Jan12 ?        00:01:05 /usr/bin/python /var/lib/mailman/bin/qrunner --runner=OutgoingRunner:0
list       978   969  0 Jan12 ?        00:01:06 /usr/bin/python /var/lib/mailman/bin/qrunner --runner=VirginRunner:0:1
list       980   969  0 Jan12 ?        00:00:00 /usr/bin/python /var/lib/mailman/bin/qrunner --runner=RetryRunner:0:1
root      1410     1  0 Jan12 ?        00:00:00 /usr/sbin/saslauthd -a pam -m /var/spool/postfix/var/run/saslauthd -r
root      1413  1410  0 Jan12 ?        00:00:00 /usr/sbin/saslauthd -a pam -m /var/spool/postfix/var/run/saslauthd -r
root      2034     1  0 Jan12 ?        00:00:09 /usr/bin/perl /usr/share/usermin/miniserv.pl /etc/usermin/miniserv.con
proftpd   2054     1  0 Jan12 ?        00:00:07 proftpd: (accepting connections)              
root      2096     1  0 Jan12 ?        00:00:13 /usr/bin/perl /usr/share/webmin/miniserv.pl /etc/webmin/miniserv.conf
root      2173     1  0 Jan12 ?        00:00:15 /usr/sbin/console-kit-daemon --no-daemon
root      2241     1  0 Jan12 ?        00:00:07 /usr/lib/policykit-1/polkitd --no-debug
root      4895     1  0 03:15 ?        00:00:00 /usr/sbin/xinetd -dontfork -pidfile /var/run/xinetd.pid -stayalive -in
www-data  6494 30181  0 03:41 ?        00:00:06 /usr/sbin/apache2 -k start
www-data  6497 30181  0 03:42 ?        00:00:06 /usr/sbin/apache2 -k start
www-data  6499 30181  0 03:42 ?        00:00:06 /usr/sbin/apache2 -k start
www-data  6500 30181  0 03:42 ?        00:00:07 /usr/sbin/apache2 -k start
root      9477 30027  0 05:09 pts/5    00:00:00 sudo ps -ef
root      9478  9477  0 05:09 pts/5    00:00:00 ps -ef
root     27626     1  0 02:44 ?        00:00:00 sendmail: MTA: accepting connections          
root     27902   110  0 02:51 ?        00:00:01 sshd: root@pts/4    
root     27998 27902  0 02:51 pts/4    00:00:01 -bash
root     29931   110  0 02:59 ?        00:00:03 sshd: root@pts/5    
root     30027 29931  0 02:59 pts/5    00:00:00 -bash
root     30181     1  0 03:00 ?        00:00:02 /usr/sbin/apache2 -k start
www-data 30183 30181  0 03:00 ?        00:00:00 /usr/sbin/apache2 -k start
www-data 30636 30181  0 03:06 ?        00:00:13 /usr/sbin/apache2 -k start

答案1

我在 Ubuntu 16.04.01 LTS 上遇到了同样的问题。出现以下日志消息/var/log/mail.log,并且无法发送出站邮件:

postfix/master[5072]: fatal: bind 127.0.0.1 port 25: Address already in use

当我尝试终止 sendmail 时收到以下输出:

$ sudo killall sendmail
sendmail: no process found

以下命令对我有用(无需重新启动服务器):

sudo killall sendmail-mta
sudo service postfix restart

答案2

我遇到了同样的问题,我所做的只是停止发送邮件,重新启动 postfix,然后使用以下命令重新启动 sendmail:

service sendmail stop
service postfix restart
service sendmail start

一切都恢复正常。

答案3

嗯,答案非常不令人满意,但今天花了几个小时研究这个问题后,我重启了服务器,postfix 现在可以运行了。感谢所有提供见解的人。

答案4

对我来说,解决方案是sudo killall sendmail-mta

相关内容