位置: 编程技术 - 正文
推荐整理分享在Linux系统上使用转发服务器处理邮件通信的教程(linux 使用),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:linux 使用,在linux2.4.0版本中,linux如何使用,在linux系统中,在linux系统中,在linux2.4.0版本中,在linux操作系统中,/etc/rc.d/init.d,在linux2.4.0版本中,内容如对您有帮助,希望把文章链接给更多的朋友!
当你启动并运行应用服务器后,你就需要一台好的邮件服务器来为你传递邮件。我为我所有的服务器开通了postfix邮件服务,下面就是我常用的配置。CentOS 6上安装Postfix
复制代码代码如下:yum install postfix
默认安装了Sendmail,所以最好将它停掉并移除。
复制代码代码如下: service sendmail stop yum remove sendmail
Postfix包含了两个配置文件main.cf和master.cf,对于基本的配置,你需要修改main.cf。同时,postfix可以像shell变量一样定义参数,并通过$来调用。这些参数不需要再使用前定义,Postfix只在运行中需要时才会查询某个参数。配置postfix
复制代码代码如下:vim /etc/postfix/main.cf
去掉以下行的注释
复制代码代码如下: # 你的主机名 myhostname = yourhostname.com # 你的发件域 myorigin = $myhostname # 指定用于接收邮件的网络接口,这里指定 localhost 是因为我们只用来接受本地的程序投递 inet_interfaces = localhost # 指定所使用的协议,可以使用“all”来增加 IPv6 支持 inet_protocols = ipv4 # 指定所接受的邮件域 mydestination = $myhostname, localhost.$mydomain, localhost # 仅转发本地主机的邮件,而不是主机所在的网络 mynetworks_style = host
启动postfix
复制代码代码如下: service postfix start
这些基本的postfix配置可以让你的机器发送邮件,你可以通过发送邮件并检查“maillog”日志文件来验证。
复制代码代码如下:echo test mail | mail -s "test" leo@techarena.com && sudo tail -f /var/log/maillog # 输出的日志类似如下 Aug :: vps postfix/smtp[]: E6ADCD: to=, relay=smtp.mailserver.org[...], delay=0.8, delays=0.1/0/0./0., dsn=2.0.0, status=sent ( Great success) Aug :: vps postfix/qmgr[]: E6ADCD: removed
但是,上述配置并不够,因为邮件服务大多数时候都会被垃圾邮件挤满,你需要添加SPF、PTR和DKIM记录。即便如此,你的邮件仍然可能被当作垃圾邮件来投递,因为你的IP地址被列入了黑名单,大多数时候是因为你的vps先前被入侵了。
还有另外一种选择,或者说是更好的方式是使用第三方邮件提供商提供的邮件服务,如Gmail,或者甚至是Mailgun。我使用Mailgun,因为它们提供了每个月封免费电子邮件,而Gmail则提供了每天封左右的邮件。
在“/etc/postfix/main.cf”中,你需要添加“smtp.mailgun.com”作为你的“转发主机”,并启用“SASL”验证,这样postfix就可以连接并验证到远程Mailgun服务器。
添加或取消以下行的注释。
复制代码代码如下: relayhost = [smtp.mailgun.org] smtp_sasl_auth_enable = yes smtp_sasl_password_maps=static:your_username:your_password smtp_sasl_security_options=noanonymous
Postfix本身不会实施“SASL”验证,因此你需要安装“cyrus-sasl-plain”。
复制代码代码如下:sudo yum install cyrus-sasl-plain
如果你不安装此包,那么你就会收到这条错误信息“SASL authentication failed; cannot authenticate to server smtp.mailgun.org[...]: no mechanism available)”
重启postfix
复制代码代码如下:sudo service postfix restart
使用TLS加固Postfix安全
Postfix支持TLS,它是SSL的后继者,允许你使用基于密钥的验证来加密数据。我推荐你阅读 ,以了解TLS是怎么和postfix一起工作的。
为了使用TLS,你需要生成一个私钥和一个由证书授权机构颁发的证书。在本例中,我将使用自颁发的证书。
复制代码代码如下:sudo yum install mod_ssl openssl # 生成私钥 openssl genrsa -out smtp.key # 生成 CSR openssl req -new -key smtp.key -out smtp.csr # 生成自签名的钥匙 openssl x -req -days -in smtp.csr -signkey smtp.key -out smtp.crt # 将文件复制到正确的位置 cp smtp.crt /etc/pki/tls/certs cp smtp.key /etc/pki/tls/private/smtp.key cp smtp.csr /etc/pki/tls/private/smtp.csr
打开postfix配置文件,然后添加以下参数。
复制代码代码如下:sudo vim /etc/postfix/main.cf smtp_tls_security_level = may smtpd_tls_security_level = may smtp_tls_note_starttls_offer = yes smtpd_tls_key_file = /etc/pki/tls/private/smtp.key smtpd_tls_cert_file = /etc/pki/tls/certs smtp_tls_CAfile = /etc/ssl/certs/ca.crt smtp_tls_loglevel = 1
安全级别“may”意味着宣告对远程SMTP客户端上的STARTTLS的支持,但是客户端不需要使用加密。我在这里按照mailgun文档提示使用“may”,但是如果你想要强制使用TLS加密,可以使用“encrypt”。
复制代码代码如下:service postfix restart # 发送一封测试邮件 echo test mail | mail -s "test" test@yourdomain.com && sudo tail -f /var/log/maillog
你应该会看到以下信息
复制代码代码如下:Aug :: vps postfix/smtp[]: setting up TLS connection to smtp.mailgun.org[...]: Aug :: vps postfix/smtp[]: Trusted TLS connection established to smtp.mailgun.org[...]:: TLSv1.2 with cipher AES-GCM-SHA (/ bits)
如果一切正常,你可以注释掉以下参数。
复制代码代码如下:“smtp_tls_loglevel = 1”
在Linux系统上安装数据库监控程序Bugzilla的方法 这里,我们将展示如何在一台Ubuntu.或CentOS6.5/7上安装Bugzilla。Bugzilla是一款基于web,用来记录跟踪缺陷数据库的bug跟踪软件,它同时是一款免费及开源
详细解读Linux系统中ntpq命令的使用 命令ntpq-q输出下面这样的一个表:复制代码代码如下:remoterefidsttwhenpollreachdelayoffsetjitter==============================================================================LOCAL(0)
在Linux的LEMP环境下配置OpenSSL的教程 今天,给大家分享一下解决源码包编译安装LEMP环境下开启OpenSSL功能问题的过程。前几天,在访问页面时,突然报错,要求开启openssl功能。那怎么办呢
标签: linux 使用
本文链接地址:https://www.jiuchutong.com/biancheng/367547.html 转载请保留说明!上一篇:在Linux中使用Smartctl监控磁盘性能的方法(在linux中使用apache发布web服务时默认web站点)
友情链接: 武汉网站建设