到外部邮箱一看,邮件即刻收到了。
From: http://www.2cto.com/os/201306/216215.html
----------------------------------------------------------------------------------
DSN: Service unavailable
自从换了vps,博客的评论邮件提醒功能一直有问题,今天有空,我们来解决它。
无法发送邮件的日志如下:
- Jun 26 07:24:23 MyVPS1976 sendmail[31760]: q5PNOMeP031760: from=<www@MyVPS1976>, size=1393, class=0, nrcpts=1, msgid=<101f67a320c3f53ec88cb43d5c74631f@www.centos.bz>, proto=SMTP, daemon=MTA, relay=MyVPS [127.0.0.1]
- Jun 26 07:24:25 MyVPS1976 sendmail[31762]: q5PNOMeP031760: to=<admin@centos.bz>, ctladdr=<www@MyVPS1976> (501/501), delay=00:00:02, xdelay=00:00:02, mailer=esmtp, pri=121393, relay=mxdomain.qq.com. [64.71.138.90], dsn=5.0.0,stat=Service unavailable
- Jun 26 07:24:25 MyVPS1976 sendmail[31762]: q5PNOMeP031760: q5PNOPeP031762: DSN: Service unavailable
- Jun 26 07:24:25 MyVPS1976 sendmail[31762]: q5PNOPeP031762: to=root, delay=00:00:00, xdelay=00:00:00, mailer=local, pri=32578, dsn=2.0.0, stat=Sent
根据relay=mxdomain.qq.com. [64.71.138.90], dsn=5.0.0,stat=Service unavailable这一段,我们知道邮件已经发送出去,但由于某种原因邮件被拒绝,于是更换hostname,重启sendmail,解决问题。
更换hostname方法:
1、编辑/etc/sysconfig/network,更换文件中的hostnmae。
2、把hostname写入/etc/hosts
3、执行hostname www.centos.bz立即生效
From: https://www.centos.bz/2012/06/dsn-service-unavailable/
----------------------------------------------------------------------------------
linux 下php mail或sendmail发送邮件慢的解决办法
mail慢并超时是由于sendmail慢引起的, 但sendmail慢又如何解决呢?
第一步:当然是查日志:
vim /var/log/maillog
Jul 5 23:26:20 localhost sendmail[1206]: My unqualified host name (localhost) unknown; sleeping for retry
Jul 5 23:27:20 localhost sendmail[1206]: unable to qualify my own domain name (localhost) -- using short name
Jul 5 23:27:20 localhost sendmail[1206]: r65FRKmm001206: from=nobody, size=187, class=0, nrcpts=1, msgid=<201307051527.r65FRKmm001206@localhost>, relay=nobody@localhost
Jul 5 23:27:20 localhost sendmail[1207]: r65FRKBa001207: from=<nobody@localhost>, size=398, class=0, nrcpts=1, msgid=<201307051527.r65FRKmm001206@localhost>, proto=ESMTP, daemon=MTA, relay=localhost [127.0.0.1]
Jul 5 23:27:20 localhost sendmail[1206]: r65FRKmm001206: to=aaa@gmail.com, ctladdr=nobody (99/99), delay=00:00:00, xdelay=00:00:00, mailer=relay, pri=30187, relay=[127.0.0.1] [127.0.0.1], dsn=2.0.0, stat=Sent (r65FRKBa001207 Message accepted for delivery)
Jul 5 23:27:22 localhost sendmail[1209]: STARTTLS=client, relay=gmail-smtp-in.l.google.com., version=TLSv1/SSLv3, verify=FAIL, cipher=RC4-SHA, bits=128/128
Jul 5 23:27:25 localhost sendmail[1209]: r65FRKBa001207: to=<aaa@gmail.com>, ctladdr=<nobody@localhost> (99/99), delay=00:00:05, xdelay=00:00:05, mailer=esmtp, pri=120398, relay=gmail-smtp-in.l.google.com. [74.125.129.26], dsn=2.0.0, stat=Sent (OK 1373038045 qn3si5112247pbc.62 - gsmtp)
Jul 5 23:30:01 localhost sendmail[1212]: My unqualified host name (localhost) unknown; sleeping for retry
第二步:在hosts表添加域名
#hostname
vim /etc/hosts
如下添加
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 你的域名
如果上面办法还是解决不了
检查下php.ini设置是否正确
cat /etc/php.ini | grep sendmail_path
正确的结果应该类似这样
sendmail_path = sendmail -t -i
检查下sendmail是否安装
which sendmail
正常的结果应该类似这样
/usr/sbin/sendmail
如果上面的路径没有找到sendmail
检查下是否安装了包
yum list installed | grep sendmail