溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在Linux系統(tǒng)上使用轉(zhuǎn)發(fā)服務(wù)器處理郵件通信

發(fā)布時(shí)間:2021-08-03 09:27:39 來(lái)源:億速云 閱讀:126 作者:chen 欄目:系統(tǒng)運(yùn)維

這篇文章主要介紹“如何在Linux系統(tǒng)上使用轉(zhuǎn)發(fā)服務(wù)器處理郵件通信”,在日常操作中,相信很多人在如何在Linux系統(tǒng)上使用轉(zhuǎn)發(fā)服務(wù)器處理郵件通信問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”如何在Linux系統(tǒng)上使用轉(zhuǎn)發(fā)服務(wù)器處理郵件通信”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

當(dāng)你啟動(dòng)并運(yùn)行應(yīng)用服務(wù)器后,你就需要一臺(tái)好的郵件服務(wù)器來(lái)為你傳遞郵件。我為我所有的服務(wù)器開(kāi)通了postfix郵件服務(wù),下面就是我常用的配置。
CentOS 6上安裝Postfix

   

代碼如下:

yum install postfix

默認(rèn)安裝了Sendmail,所以最好將它停掉并移除。

   

代碼如下:

service sendmail stop
   yum remove sendmail

Postfix包含了兩個(gè)配置文件main.cf和master.cf,對(duì)于基本的配置,你需要修改main.cf。同時(shí),postfix可以像shell變量一樣定義參數(shù),并通過(guò)$來(lái)調(diào)用。這些參數(shù)不需要再使用前定義,Postfix只在運(yùn)行中需要時(shí)才會(huì)查詢某個(gè)參數(shù)。
配置postfix

   

代碼如下:

vim /etc/postfix/main.cf

去掉以下行的注釋

   

代碼如下:

# 你的主機(jī)名
   myhostname = yourhostname.com
   
   # 你的發(fā)件域
   myorigin = $myhostname
   
   # 指定用于接收郵件的網(wǎng)絡(luò)接口,這里指定 localhost 是因?yàn)槲覀冎挥脕?lái)接受本地的程序投遞
   inet_interfaces = localhost
   
   # 指定所使用的協(xié)議,可以使用“all”來(lái)增加 IPv6 支持
   inet_protocols = ipv4
   
   
   # 指定所接受的郵件域    
   mydestination = $myhostname, localhost.$mydomain, localhost
   
   # 僅轉(zhuǎn)發(fā)本地主機(jī)的郵件,而不是主機(jī)所在的網(wǎng)絡(luò)
   mynetworks_style = host

啟動(dòng)postfix

   

代碼如下:

service postfix start

這些基本的postfix配置可以讓你的機(jī)器發(fā)送郵件,你可以通過(guò)發(fā)送郵件并檢查“maillog”日志文件來(lái)驗(yàn)證。

   

代碼如下:

echo test mail | mail -s "test"  leo@techarena51.com && sudo tail -f /var/log/maillog
   
   # 輸出的日志類似如下
   Aug 25 14:16:21 vps postfix/smtp[32622]: E6A372DC065D: to=, relay=smtp.mailserver.org[50.56.21.176], delay=0.8, delays=0.1/0/0.43/0.27, dsn=2.0.0, status=sent (250 Great success)
   Aug 25 14:16:21 vps postfix/qmgr[5355]: E6A372DC065D: removed

但是,上述配置并不夠,因?yàn)猷]件服務(wù)大多數(shù)時(shí)候都會(huì)被垃圾郵件擠滿,你需要添加SPF、PTR和DKIM記錄。即便如此,你的郵件仍然可能被當(dāng)作垃圾郵件來(lái)投遞,因?yàn)槟愕腎P地址被列入了黑名單,大多數(shù)時(shí)候是因?yàn)槟愕膙ps先前被入侵了。

還有另外一種選擇,或者說(shuō)是更好的方式是使用第三方郵件提供商提供的郵件服務(wù),如Gmail,或者甚至是Mailgun。我使用Mailgun,因?yàn)樗鼈兲峁┝嗣總€(gè)月10000封免費(fèi)電子郵件,而Gmail則提供了每天100封左右的郵件。

在“/etc/postfix/main.cf”中,你需要添加“smtp.mailgun.com”作為你的“轉(zhuǎn)發(fā)主機(jī)”,并啟用“SASL”驗(yàn)證,這樣postfix就可以連接并驗(yàn)證到遠(yuǎn)程Mailgun服務(wù)器。

添加或取消以下行的注釋。

   

代碼如下:

relayhost = [smtp.mailgun.org]
   smtp_sasl_auth_enable = yes
   smtp_sasl_password_maps=static:your_username:your_password
   smtp_sasl_security_options=noanonymous

Postfix本身不會(huì)實(shí)施“SASL”驗(yàn)證,因此你需要安裝“cyrus-sasl-plain”。

   

代碼如下:

sudo yum install cyrus-sasl-plain

如果你不安裝此包,那么你就會(huì)收到這條錯(cuò)誤信息“SASL authentication failed; cannot authenticate to server smtp.mailgun.org[50.56.21.176]: no mechanism available)”

重啟postfix

   

代碼如下:

sudo service postfix restart

使用TLS加固Postfix安全

Postfix支持TLS,它是SSL的后繼者,允許你使用基于密鑰的驗(yàn)證來(lái)加密數(shù)據(jù)。我推薦你閱讀 http://www.postfix.org/TLS_README.html ,以了解TLS是怎么和postfix一起工作的。

為了使用TLS,你需要生成一個(gè)私鑰和一個(gè)由證書(shū)授權(quán)機(jī)構(gòu)頒發(fā)的證書(shū)。在本例中,我將使用自頒發(fā)的證書(shū)。

   

代碼如下:

sudo yum install mod_ssl openssl
   # 生成私鑰
   openssl genrsa -out smtp.key 2048
   
   # 生成 CSR
   openssl req -new -key smtp.key -out smtp.csr
   
   # 生成自簽名的鑰匙
   openssl x509 -req -days 365 -in smtp.csr -signkey smtp.key -out smtp.crt
   
   # 將文件復(fù)制到正確的位置
   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

打開(kāi)postfix配置文件,然后添加以下參數(shù)。

   

代碼如下:

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

安全級(jí)別“may”意味著宣告對(duì)遠(yuǎn)程SMTP客戶端上的STARTTLS的支持,但是客戶端不需要使用加密。我在這里按照mailgun文檔提示使用“may”,但是如果你想要強(qiáng)制使用TLS加密,可以使用“encrypt”。

   

代碼如下:

service postfix restart
   # 發(fā)送一封測(cè)試郵件
   echo test mail | mail -s "test"  test@yourdomain.com && sudo tail -f /var/log/maillog

你應(yīng)該會(huì)看到以下信息

   

代碼如下:

Aug 21 00:00:06 vps postfix/smtp[4997]: setting up TLS connection to smtp.mailgun.org[50.56.21.176]:587
   Aug 21 00:00:06 vps postfix/smtp[4997]: Trusted TLS connection established to smtp.mailgun.org[50.56.21.176]:587: TLSv1.2 with cipher AES256-GCM-SHA384 (256/256 bits)

如果一切正常,你可以注釋掉以下參數(shù)。

代碼如下:

“smtp_tls_loglevel = 1”

到此,關(guān)于“如何在Linux系統(tǒng)上使用轉(zhuǎn)發(fā)服務(wù)器處理郵件通信”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI