我正在尝试在我的服务器上运行 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 sendmail
,killall 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