一.安装sendmail
yum install -y sendmail yum install -y sendmail-cf
二. 安装salauthd
//使用SMTP认证,需要安装saslauthd服务
yum install -y saslauthd (安装可能失败,直接start)
//启动saslauthd服务
service saslauthd start
//设置saslauthd开机自动启动
chkconfig saslauthd on
三. 配置sendmail
//配置saslauthd
vi /etc/mail/sendmail.mc
-
在该配置文件中,将如下两行的注释去掉:将下面两行的dnl去掉。在sendmail文件中,dnl表示该行为注释行。
-
dnl TRUST_AUTH_MECH('EXTERNAL DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl dnl define('confAUTH_MECHANISMS', 'EXTERNAL GSSAPI DIGEST-MD5 CRAM-MD5 LOGIN PLAIN')dnl
作者:TyiMan
链接:http://www.jianshu.com/p/5916b9570844
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 -
-
TRUST_AUTH_MECH的作用是使sendmail不管access文件中如何设置,都能relay那些通过EXTERNAL, LOGIN, PLAIN, CRAM-MD5或DIGEST-MD5等方式验证的邮件,注意这里是对需要relay的邮件进行验证,这点很重要,只有这样通过验证的邮件才会被relay以防止sendmail服务器被滥用。
confAUTH_MECHANISMS的作用是确定系统的认证方式。Outlook Express支持的认证方式是LOGIN。 -
设置Sendmail服务的网络访问权限,如果仅仅是本机使用,就不用配置,如果是允许外部机器访问,可以进行限制。
DAEMON_OPTIONS(`Port=smtp,Addr=127.0.0.1, Name=MTA')dnl
将127.0.0.1改为0.0.0.0,意思是任何主机都可以访问Sendmail服务。如果仅让某一个网段能够访问到Sendmail服务,将127.0.0.1改为形如192.168.1.0/24的一个特定网段地址。
- 进行信息伪装,要不然发过去邮件如root@izGd634der(服务器名称),会被邮件服务器拒收的。具体操作如下:
-
//此句去掉注释,修改为:MASQUERADE_AS('yourdomain.com')dnl dnl MASQUERADE_AS('mydomain.com')dnl //是否对信息作伪装 //去掉注释 dnl FEATURE(masquerade_envelope)dnl //是否对整个域(包括子域)做伪装 //去掉注释 dnl FEATURE(masquerade_entire_domain)dnl //去掉注释 dnl MASQUERADE_DOMAIN(localhost)dnl //对localhost域做伪装 //去掉注释 dnl MASQUERADE_DOMAIN(localhost.localdomain)dnl //将locahost.com域伪装成yourdomain.com
生成配置文件
Sendmail的配置文件由m4来生成,m4工具在sendmail-cf包中。如果系统无法识别m4命令,说明sendmail-cf软件包没有安装。m4 /etc/mail/sendmail.mc > /etc/mail/sendmail.cf
-
四. 启动sendmail
chkconfig sendmail on //开机启动 service sendmail start
五. 测试发送邮件
先创建一个内容文件,然后输入一些内容,最好是英文,要不然汉字会乱码。写完后
wq
保存退出。vim content.txt
发送邮件给你邮箱,命令如下:
mail -s "Here is the subject" receiver_mail_address@qq.com <content.txt
(到qq邮箱的垃圾箱里找)
作者:TyiMan
链接:http://www.jianshu.com/p/5916b9570844
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
-