|
導讀網絡技術是從1990年代中期發展起來的新技術,它把互聯網上分散的資源融為有機整體,實現資源的全面共享和有機協作,使人們能夠透明地使用資源的整體能力并按需獲取信息。資源包括高性能計算機、存儲資源、數據... 網絡技術是從1990年代中期發展起來的新技術,它把互聯網上分散的資源融為有機整體,實現資源的全面共享和有機協作,使人們能夠透明地使用資源的整體能力并按需獲取信息。資源包括高性能計算機、存儲資源、數據資源、信息資源、知識資源、專家資源、大型數據庫、網絡、傳感器等。 當前的互聯網只限于信息共享,網絡則被認為是互聯網發展的第三階段。 人們在Internet上最常使用的就是電子郵件,很多企業用戶也經常使用電子郵件系統。在Unix系統中,Sendmail是應用最廣的電子郵件服務器。本文將比較詳細地介紹如何建立一個Sendmail電子郵件服務器,以滿足企業的基本需求。 一. Sendmail的工作模式 Sendmail是最重要的郵件傳輸代理程序。理解電子郵件的工作模式是非常重要的。一般情況下,電子郵件系統可分為用戶代理、傳輸代理和投遞代理幾個部分。用戶代理用來接受用戶的指令,將用戶的信件傳送至信件傳輸代理,如Outlook Express和Foxmail等。而投遞代理則從信件傳輸代理取得信件傳送至最終用戶的郵箱,如Procmail。 當用戶試圖發送一封電子郵件的時候,他并不能直接將信件發送到對方的機器上,用戶代理必須試圖去尋找一個信件傳輸代理,把郵件提交給它。信件傳輸代理得到了郵件后,首先將它保存在自身的緩沖隊列中,然后,根據郵件的目標地址,信件傳輸代理程序將找到應該對這個目標地址負責的郵件傳輸代理服務器,再通過網絡將郵件傳送給它。對方的服務器接收到郵件之后,將其緩沖存儲在本地,直到電子郵件的接收者查看自己的電子信箱。 顯然,郵件傳輸是從服務器到服務器的,而且每個用戶必須擁有服務器上存儲信息的空間(稱為信箱)才能接受郵件(發送郵件不受這個限制)?梢钥吹剑粋郵件傳輸代理的主要工作是監視用戶代理的請求,根據電子郵件的目標地址找出對應的郵件服務器,將信件在服務器之間傳輸并且將接收到的郵件緩沖或者 提交給最終投遞程序。 有許多程序可以作為信件傳輸代理。在Unix系統中,Sendmail是其中應用最廣泛的一個,它是一個免費軟件,可以支持數千甚至更多的用戶,而且占用的系統資源相當少。不過,Sendmail的配置十分復雜,因此,也有人使用另外的一些工具,如Qmail或Postfix等等。 當Sendmail程序得到一封待發送的郵件的時候,它需要根據目標地址確定將信件投遞給對應的服務器,這是通過DNS服務實現的。例如一封郵件的目標地址是ideal@linuxaid.com.cn,那么Sendmail首先確定這個地址是用戶名(ideal)+機器名(linuxaid.com.cn)的格式,然后,通過查詢DNS來確定需要把信件投遞給某個服務器。 DNS數據中,與電子郵件相關的是信件交換(Message eXchange,MX)記錄,例如在linuxaid.com.cn這個域的dns數據文件中有如下設置: IN MX 10 mail IN MX 20 mail1 mail IN A 202.99.11.120 mail1 IN A 202.99.11.121 顯然,在DNS中說明linuxaid.com.cn有2個MX服務器,于是,Sendmail試圖將郵件發送給兩者之一。一般來說,排在前面的MX服務器的優先級別比較高,因此服務器將試圖連接mail.linuxaid.com.cn的25端口,試圖將信件報文轉發給它。如果成功,SMTP服務器的任務就完成了。在這以后的任務,將由mail.linuxaid.com.cn來完成。在一般情況下,MX服務器會自動把信件內容轉交給目標主機。不過,也存在這樣的情況,目標主機(比如linuxaid.com.cn)可能并不存在,或者不執行SMTP服務,而是由其MX服務器來執行信件的管理,這時候,最終的信件將保存在MX機器上,直到用戶來查看它。 如果DNS查詢無法找出對某個地址的MX記錄(通常因為對方沒有信件交換主機),那么Sendmail將試圖直接與來自郵件地址的主機對話并且發送郵件。例如,test@aidgroup.linuxaid.com.cn,DNS中沒有對應的MX記錄,因此Sendmail在確定MX服務器失敗后,將從DNS取得對方的IP地址并直接和對方對話試圖發送郵件。 網絡的神奇作用吸引著越來越多的用戶加入其中,正因如此,網絡的承受能力也面臨著越來越嚴峻的考驗―從硬件上、軟件上、所用標準上......,各項技術都需要適時應勢,對應發展,這正是網絡迅速走向進步的催化劑。 |
溫馨提示:喜歡本站的話,請收藏一下本站!