sendmail是linux系統中一個郵箱系統,若是咱們在系統中配置好sendmail就能夠直接使用它來發送郵箱。
sendmail的配置文件
/etc/mail/sendmail.cf :Sendmail的主配置文件;
/etc/mail/access :中繼訪問控制;
/etc/mail/domaintable ;域名映射;
/etc/mail/local-host-names ;本地主機別名;
/etc/mail/mailertable :爲特定的域指定特殊的路由規則;
/etc/mail/virtusertable :虛擬域配置。node
中繼的配置
是指一臺服務器接受並傳遞源地址和目的地址都不是本服務器的郵件。
在兩個文件中進行設置:
/etc/mail/relay-domains
/etc/mail/access。linux
廢話很少說了,下面分享下sendmail在linux系統下的安裝部署記錄:vim
1、安裝軟件
[root@slave-node ~]# yum install -y sendmail
[root@slave-node ~]# yum install -y sendmail-cfbash
啓動saslauthd服務進行SMTP驗證(默認是安裝的,若是沒有,就手動安裝)
[root@slave-node ~]# service saslauthd start
Starting saslauthd: [ OK ]服務器
2、郵件服務配置(iptables防火牆關閉)
1)配置Senmail的SMTP認證
將下面兩行內容前面的dnl去掉。在sendmail文件中,dnl表示該行爲註釋行,是無效的,所以經過去除行首的dnl字符串能夠開啓相應的設置行。
[root@slave-node ~]# vim /etc/mail/sendmail.mc
......
TRUST_AUTH_MECH(`EXTERNAL DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl
define(`confAUTH_MECHANISMS', `EXTERNAL GSSAPI DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl網絡
2) 設置Sendmail服務的網絡訪問權限(若是是直接本機調用,能夠不用操做,採用默認的127.0.0.1。不過最後仍是改爲0.0.0.0)
將127.0.0.1改成0.0.0.0,意思是任何主機均可以訪問Sendmail服務。
若是僅讓某一個網段可以訪問到Sendmail服務,將127.0.0.1改成形如192.168.1.0/24的一個特定網段地址。
[root@slave-node ~]# vim /etc/mail/sendmail.mc
......
DAEMON_OPTIONS(`Port=smtp,Addr=0.0.0.0, Name=MTA')dnldom
3)生成配置文件
Sendmail的配置文件由m4來生成,m4工具在sendmail-cf包中。若是系統沒法識別m4命令,說明sendmail-cf軟件包沒有安裝
[root@slave-node ~]# m4 /etc/mail/sendmail.mc > /etc/mail/sendmail.cf工具
4)啓動服務(若是發現sendmail dead but subsys locked,那就執行"service postfix status"查看postfix是否默認開啓了,若是開啓的話,就關閉postfix,而後再啓動或重啓sendmail服務便可。)
[root@slave-node ~]# service sendmail start
Starting sendmail: [ OK ]
Starting sm-client: [ OK ]
[root@slave-node ~]# service saslauthd restart
Stopping saslauthd: [ OK ]
Starting saslauthd: [ OK ]post
將服務加入自啓行列
[root@slave-node ~]# chkconfig sendmail on
[root@slave-node ~]# chkconfig saslauthd on
[root@slave-node ~]# chkconfig --list |grep sendmail
sendmail 0:off 1:off 2:on 3:on 4:on 5:on 6:off
[root@slave-node ~]# chkconfig --list |grep saslauthd
saslauthd 0:off 1:off 2:on 3:on 4:on 5:on 6:off測試
3、測試發送郵箱
(1)第一種方式:安裝sendmail便可使用。
[root@slave-node ~]# yum -y install mailx
建立一個郵件內容文件,而後發郵件(注意-s參數後的郵件標題要用單引號,不能使用雙引號,不然發郵件會失敗!)
[root@slave-node ~]# echo 'This is test mail'>/root/content.txt
[root@slave-node ~]# cat /root/content.txt
This is test mail
[root@slave-node ~]# mail -s 'Test mail' wang_shibo***@163.com < /root/content.txt
查看已收到郵件:
若是不想經過文件發送郵件內容也能夠這麼發送,也可使用管道符直接發送郵件內容,效果同文件發送郵件內容同樣
[root@slave-node ~]# echo "This is test mail" | mail -s '666666' wang_shibo***@163.com
查看已收到郵件:
若是是發送給多個郵件,就使用-c參數,以下:
[root@slave-node ~]# echo "This is test mail" | mail -s 'test' -c wang_shibo***@sina.com wang_shibo***@163.com
如遇下面報錯,解決辦法:
發送郵件: [root@mail-server ~]# echo "This is test mail" | mail -s '666666' wangshibo@kevin.com 發現收不到郵件,查看sendmail日誌,報錯信息以下: [root@mail-server ~]# tail -f /var/log/maillog ....... Feb 12 03:35:13 mail-server sendmail[21905]: My unqualified host name (mail-server) unknown; sleeping for retry Feb 12 03:37:12 mail-server sendmail[22061]: w1BJb8KM022059: to=<wangshibo@kevin.com>, ctladdr=<root@mail-server> (0/0), delay=00:00:03, xdelay=00:00:03, mailer=esmtp, pri=120476, relay=mx1.kevin.com. [128.1.41.15], dsn=4.0.0, stat=Deferred: 450 Requested mail action not taken: Invalid sender 分析緣由: 這是因爲主機名沒有正確解析致使的。 [root@mail-server ~]# cat /etc/hosts 127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4 ::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 192.168.10.202 mail-server [root@mail-server ~]# cat /etc/sysconfig/network NETWORKING=yes HOSTNAME=mail-server 解決辦法: [root@mail-server ~]# cat /etc/hosts 127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4 ::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 192.168.10.202 mail-server.localdomain mail-server [root@mail-server ~]# cat /etc/sysconfig/network NETWORKING=yes HOSTNAME=mail-server [root@mail-server ~]# rm -rf /var/spool/mqueue/* [root@mail-server ~]# /etc/init.d/sendmail restart Shutting down sm-client: [ OK ] Shutting down sendmail: [ OK ] Starting sendmail: [ OK ] Starting sm-client: [ OK ] 再次使用mail發送郵件就正確了! [root@mail-server ~]# echo "This is test mail" | mail -s '666666' wangshibo@kevin.com [root@mail-server ~]# tail -f /var/log/maillog ....... Feb 12 03:42:31 mail-server sendmail[22293]: STARTTLS=client, relay=mx1.kevin.com., version=TLSv1/SSLv3, verify=FAIL, cipher=AES256-GCM-SHA384, bits=256/256 Feb 12 03:42:31 mail-server sendmail[22299]: STARTTLS=client, relay=mx1.kevin.com., version=TLSv1/SSLv3, verify=FAIL, cipher=AES256-GCM-SHA384, bits=256/256 Feb 12 03:42:31 mail-server sendmail[22302]: STARTTLS=client, relay=mx1.kevin.com., version=TLSv1/SSLv3, verify=FAIL, cipher=AES256-GCM-SHA384, bits=256/256 Feb 12 03:42:33 mail-server sendmail[22284]: STARTTLS=client, relay=mx1.kevin.com., version=TLSv1/SSLv3, verify=FAIL, cipher=AES256-GCM-SHA384, bits=256/256 Feb 12 03:42:34 mail-server sendmail[22293]: w1BJgTcF022288: to=<wangshibo@kevin.com>, ctladdr=<root@mail-server.localdomain> (0/0), delay=00:00:05, xdelay=00:00:05, mailer=esmtp, pri=120510, relay=mx1.kevin.com. [116.115.114.9], dsn=2.0.0, stat=Sent (Mail OK queued as AQAAfwB3EaEnDYFaHrpiAA--.12694S3) Feb 12 03:42:35 mail-server sendmail[22302]: w1BJgUPI022300: to=<wangshibo@kevin.com>, ctladdr=<root@mail-server.localdomain> (0/0), delay=00:00:05, xdelay=00:00:05, mailer=esmtp, pri=120510, relay=mx1.kevin.com. [115.123.124.105], dsn=2.0.0, stat=Sent (Mail OK queued as AQAAfwDXQD0oDYFaoMJxAA--.21712S3) Feb 12 03:42:36 mail-server sendmail[22299]: w1BJgToO022294: to=<wangshibo@kevin.com>, ctladdr=<root@mail-server.localdomain> (0/0), delay=00:00:06, xdelay=00:00:06, mailer=esmtp, pri=120510, relay=mx1.kevin.com. [115.123.124.105], dsn=2.0.0, stat=Sent (Mail OK queued as AQAAfwB3HTonDYFancJxAA--.21596S3) Feb 12 03:42:40 mail-server sendmail[22284]: w1BJgSAl022282: to=<wangshibo@kevin.com>, ctladdr=<root@mail-server.localdomain> (0/0), delay=00:00:12, xdelay=00:00:12, mailer=esmtp, pri=120510, relay=mx1.kevin.com. [139.162.158.182], dsn=2.0.0, stat=Sent (Mail OK queued as AQAAfwDHp2QmDYFayl55AA--.6056S3)
(2)第二種方式:利用外部的smpt服務器
上面第一種方式中,/bin/mail命令會默認使用本地sendmail發送郵件,這樣要求本地的機器必須安裝和啓動Sendmail服務,配置很是麻煩,並且會帶來沒必要要的資源佔用。
而經過修改配置文件可使用外部SMTP服務器,能夠達到不使用sendmail而用外部的smtp服務器發送郵件的目的。
修改/etc/mail.rc文件(有的版本叫/etc/nail.rc,添加下面內容:
set from=fromUser@domain.com smtp=smtp.domain.comset smtp-auth-user=username smtp-auth-password=passwordset smtp-auth=login
參數說明:
from是發送的郵件地址
smtp是發生的外部smtp服務器的地址
smtp-auth-user是外部smtp服務器認證的用戶名。注意必定要填寫郵件全稱!!
smtp-auth-password是外部smtp服務器認證的用戶密碼
smtp-auth是郵件認證的方式
配置完成後,就能夠正常發送郵件了,以下
[root@slave-node ~]# vim /etc/mail.rc //在文件底部添加
set from=ops@huanqiu.cn smtp=smtp.huanqiu.cn smtp-auth-user=ops@huanqiu.cn smtp-auth-password=zh@123bj smtp-auth=login
如今開始發郵件:
[root@slave-node ~]# echo "hello world" |mail -s 'test666' wangshibo@huanqiu.cn