《图解HTTP》读书笔记--第5章与HTTP协作的Web服务器
寫在前面:本文僅供個人學習使用,如有侵權(quán),請聯(lián)系刪除。文章中所用圖片絕大多數(shù)來源于《圖解HTTP》,請讀者支持原版。
文章目錄
- 5.1 用單臺虛擬主機實現(xiàn)多個域名
- 5.2 通信數(shù)據(jù)轉(zhuǎn)發(fā)程序:代理、網(wǎng)關(guān)、隧道
- 5.2.1 代理
- 5.2.2 網(wǎng)關(guān)
- 5.2.3 隧道
- 5.3 保存資源的緩存
- 5.3.1 緩存的有效期限
- 5.3.2 客戶端的緩存
一臺Web服務器可搭建多個獨立域名的Web網(wǎng)站,也可作為通信路徑上的中轉(zhuǎn)服務器提升傳輸效率。
5.1 用單臺虛擬主機實現(xiàn)多個域名
HTTP/1.1規(guī)范允許一臺HTTP服務器搭建多個Web站點。比如,提供Web托管服務(Web Hosting Service) 的供應商,可以用一臺服務器為多為客戶服務,也可以以每位客戶持有的域名運行各自不同的網(wǎng)站。這是因為利用了虛擬主機(Virtual Host,又稱虛擬服務器) 的功能。
即使物理層面只有一臺服務器,但只要使用虛擬主機功能,則可以假想已具有多臺服務器。
客戶端使用HTTP協(xié)議訪問服務器時,會經(jīng)常采用類似www.hackr.jp這樣的主機名和域名。
在互聯(lián)網(wǎng)上,域名通過DNS服務映射到IP地址(域名解析)之后訪問目標網(wǎng)站。可見,當請求發(fā)送到服務器時,已經(jīng)是以IP地址形式訪問了。
所以,如果一臺服務器內(nèi)托管了www.tricorder.jp和www.hachr.jp這兩個域名,當收到請求時就需要弄清楚究竟要訪問哪個域名。
在相同的IP地址下,由于虛擬主機可以寄存多個不同主機名和域名的Web網(wǎng)站,因此在發(fā)送HTTP請求時,必須在Host首部內(nèi)完整指定主機名或域名的URI。
5.2 通信數(shù)據(jù)轉(zhuǎn)發(fā)程序:代理、網(wǎng)關(guān)、隧道
HTTP通信時,除客戶端和服務器之外,還有一些用于通信數(shù)據(jù)轉(zhuǎn)發(fā)的程序,例如代理、網(wǎng)關(guān)和隧道。它們可以配合服務器工作。
這些應用程序和服務器可以將請求轉(zhuǎn)發(fā)給通信線路上的下一站服務器,并且能接收從那臺服務器發(fā)送的響應再轉(zhuǎn)發(fā)給客戶端。
代理
代理是一種有轉(zhuǎn)發(fā)功能的應用程序,它扮演了位于服務器和客戶端“中間人”的角色,接收由客戶端發(fā)送的請求并轉(zhuǎn)發(fā)給服務器,同時也接收服務器返回的響應并轉(zhuǎn)發(fā)給客戶端。
網(wǎng)關(guān)
網(wǎng)關(guān)是轉(zhuǎn)發(fā)其他服務器通信數(shù)據(jù)的服務器,接收從客戶端發(fā)送來的請求時,它就像自己擁有資源的源服務器一樣對請求進行處理。有時客戶端可能都不會察覺,自己的通信目標是一個網(wǎng)關(guān)。
隧道
隧道是在相隔甚遠的客戶端和服務器兩者之間進行中轉(zhuǎn),并保持雙方通信連接的應用程序。
5.2.1 代理
代理服務器的基本行為就是接收客戶端發(fā)送的請求后轉(zhuǎn)發(fā)給其他服務器。代理不改變請求URI,會直接發(fā)送給前方持有資源的目標服務器。
持有資源實體的服務器被稱為源服務器。從源服務器返回的響應經(jīng)過代理服務器后再傳給客戶端。
在HTTP通信過程中,可級聯(lián)多臺代理服務器。請求和響應的轉(zhuǎn)發(fā)會經(jīng)過數(shù)臺類似鎖鏈一樣連接起來的代理服務器。轉(zhuǎn)發(fā)時,需要附加Via首部字段以標記出經(jīng)過的主機信息。
使用代理服務器的理由有:利用緩存技術(shù)減少網(wǎng)絡(luò)帶寬的流量,組織內(nèi)部針對特定網(wǎng)站的訪問控制,以獲取訪問日志為主要目的,等等。
代理有多種使用方法,按兩種基準分類。一種是是否使用緩存,另一種是是否會修改報文。
緩存代理
代理轉(zhuǎn)發(fā)響應時,緩存代理(Caching Proxy)會預先將資源的副本(緩存)保存在代理服務器上。
當代理再次接收到對相同資源的請求時,就可以不從源服務器那里獲取資源,而是將之前緩存的資源作為響應返回。
透明代理
轉(zhuǎn)發(fā)請求或響應時,不對報文做任何加工的代理類型稱為透明代理(Transparent Proxy)。反之,對報文內(nèi)容進行加工的代理被稱為非透明代理。
5.2.2 網(wǎng)關(guān)
網(wǎng)關(guān)的工作機制和代理十分相似。而網(wǎng)關(guān)能使通信線路上的服務器提供非HTTP協(xié)議服務。
利用網(wǎng)關(guān)能提高通信的安全性,因為可以在客戶端與網(wǎng)關(guān)之間的通信線路上加密以確保連接的安全。比如,網(wǎng)關(guān)可以連接數(shù)據(jù)庫,使用SQL語句查詢數(shù)據(jù)。另外,在Web購物網(wǎng)站上進行信用卡結(jié)算時,網(wǎng)關(guān)可以和信用卡結(jié)算系統(tǒng)聯(lián)動。
5.2.3 隧道
隧道可按要求建立起一條與其他服務器的通信線路,屆時使用SSL等加密手段進行通信。隧道的目的是確??蛻舳伺c服務器進行安全的通信。
隧道本身不會去解析HTTP請求。也就是說,請求保持原樣中轉(zhuǎn)給之后的服務器。隧道會在通信雙方斷開連接時結(jié)束。
5.3 保存資源的緩存
緩存是指代理服務器或客戶端本地磁盤內(nèi)保存的資源副本。利用緩存可減少對源服務器的訪問,因此也就節(jié)省了通信流量和通信時間。
緩存服務器是代理服務器的一種,并歸類在緩存代理類型中。 換句話說,當代理轉(zhuǎn)發(fā)從服務器返回的響應時,代理服務器將會保存一份資源的副本。
緩存服務器的優(yōu)勢在于利用緩存可避免多次從源服務器轉(zhuǎn)發(fā)資源。因此客戶端可就近從緩存服務器上獲取資源,而源服務器也不必多次處理相同的請求了。
5.3.1 緩存的有效期限
即使緩存服務器內(nèi)有緩存,也不能保證每次都會返回對同資源的請求。因為這關(guān)系到被緩存資源的有效性問題。
當遇上源服務器上的資源更新時,若谷偶還是使用不變的緩存,那就演變成返回更新前的“舊”資源了。
即使存在緩存,也會因為客戶端的要求、緩存的有效期等因素,向源服務器確認資源的有效性。若判斷緩存失效,緩存服務器將會再次從源服務器上獲取“新”的資源。
5.3.2 客戶端的緩存
緩存不僅可以存在于緩存服務器內(nèi),還可以存在客戶端瀏覽器中。以Internet Explorer 程序為例,把客戶端緩存稱為臨時網(wǎng)絡(luò)文件(Temporary Internet File)。
瀏覽器緩存如果有效,就不必再向服務器請求相同的資源了,可以直接從本地磁盤內(nèi)讀取。
另外,和緩存服務器相同的一點是,當判定緩存過期后,會向源服務器確認資源的有限性。若判斷瀏覽器緩存失效,瀏覽器會再次請求新資源。
《新程序員》:云原生和全面數(shù)字化實踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的《图解HTTP》读书笔记--第5章与HTTP协作的Web服务器的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: GRE词汇乱序版-夹生的词汇3
- 下一篇: 《图解HTTP》读书笔记--第7章 确保