那么今天我們就一起來探索下這個流程,下圖是我梳理出的“從輸入 URL 到頁面展示完整流程示意圖”:
從圖中可以看出二蓝,整個過程需要各個進(jìn)程之間的配合誉券,所以在開始正式流程之前,
我們還是先來快速回顧下瀏覽器進(jìn)程刊愚、渲染進(jìn)程和網(wǎng)絡(luò)進(jìn)程的主要職責(zé)踊跟。
瀏覽器進(jìn)程主要負(fù)責(zé)用戶交互、子進(jìn)程管理和文件儲存等功能鸥诽。
網(wǎng)絡(luò)進(jìn)程是面向渲染進(jìn)程和瀏覽器進(jìn)程等提供網(wǎng)絡(luò)下載功能商玫。
渲染進(jìn)程的主要職責(zé)是把從網(wǎng)絡(luò)下載的 HTML、JavaScript牡借、CSS拳昌、圖片等資源解析為可以顯示和交互的頁面。因為渲染進(jìn)程所有的內(nèi)容都是通過網(wǎng)絡(luò)獲取的钠龙,會存在一些惡意代碼利用瀏覽器漏洞對系統(tǒng)進(jìn)行攻擊炬藤,所以運行在渲染進(jìn)程里面的代碼是不被信任的。這也是為什么 Chrome 會讓渲染進(jìn)程運行在安全沙箱里碴里,就是為了保證系統(tǒng)的安全沈矿。
加入瀏覽器進(jìn)程的,載入url流程:
1并闲,用戶輸入url并回車
2细睡,瀏覽器進(jìn)程檢查url,組裝協(xié)議帝火,構(gòu)成完整的url
3溜徙,瀏覽器進(jìn)程通過進(jìn)程間通信(IPC)把url請求發(fā)送給網(wǎng)絡(luò)進(jìn)程
4,網(wǎng)絡(luò)進(jìn)程接收到url請求后檢查本地緩存是否緩存了該請求資源犀填,如果有則將該資源返回給瀏覽器進(jìn)程
5蠢壹,如果沒有,網(wǎng)絡(luò)進(jìn)程向web服務(wù)器發(fā)起http請求(網(wǎng)絡(luò)請求)九巡,請求流程如下:
5.1 進(jìn)行DNS解析图贸,獲取服務(wù)器ip地址,端口(端口是通過dns解析獲取的嗎冕广?這里有個疑問)
5.2 利用ip地址和服務(wù)器建立tcp連接
5.3 構(gòu)建請求頭信息
5.4 發(fā)送請求頭信息
5.5 服務(wù)器響應(yīng)后疏日,網(wǎng)絡(luò)進(jìn)程接收響應(yīng)頭和響應(yīng)信息,并解析響應(yīng)內(nèi)容
6撒汉,網(wǎng)絡(luò)進(jìn)程解析響應(yīng)流程沟优;
6.1 檢查狀態(tài)碼,如果是301/302睬辐,則需要重定向挠阁,從Location自動中讀取地址,重新進(jìn)行第4步
(301/302跳轉(zhuǎn)也會讀取本地緩存嗎溯饵?這里有個疑問)侵俗,如果是200,則繼續(xù)處理請求丰刊。
6.2 200響應(yīng)處理:
檢查響應(yīng)類型Content-Type隘谣,如果是字節(jié)流類型,則將該請求提交給下載管理器啄巧,該導(dǎo)航流程結(jié)束洪橘,不再進(jìn)行
后續(xù)的渲染,如果是html則通知瀏覽器進(jìn)程準(zhǔn)備渲染進(jìn)程準(zhǔn)備進(jìn)行渲染棵帽。
7熄求,準(zhǔn)備渲染進(jìn)程
7.1 瀏覽器進(jìn)程檢查當(dāng)前url是否和之前打開的渲染進(jìn)程根域名是否相同,如果相同逗概,則復(fù)用原來的進(jìn)程弟晚,如果不同,則開啟新的渲染進(jìn)程
8. 傳輸數(shù)據(jù)逾苫、更新狀態(tài)
8.1 渲染進(jìn)程準(zhǔn)備好后卿城,瀏覽器向渲染進(jìn)程發(fā)起“提交文檔”的消息,渲染進(jìn)程接收到消息和網(wǎng)絡(luò)進(jìn)程建立傳輸數(shù)據(jù)的“管道”
8.2 渲染進(jìn)程接收完數(shù)據(jù)后铅搓,向瀏覽器發(fā)送“確認(rèn)提交”
8.3 瀏覽器進(jìn)程接收到確認(rèn)消息后更新瀏覽器界面狀態(tài):安全瑟押、地址欄url、前進(jìn)后退的歷史狀態(tài)星掰、更新web頁面多望。
- 那什么情況下多個頁面會同時運行在一個渲染進(jìn)程中呢嫩舟?
要解決這個問題,我們就需要先了解下什么是同一站點(same-site)怀偷。具體地講家厌,我們將“同一站點”定義為根域名(例如,geekbang.org)加上協(xié)議(例如椎工,https:// 或者 http://)饭于,還包含了該根域名下的所有子域名和不同的端口,比如下面這三個:https://time.geekbang.org
https://www.geekbang.org
https://www.geekbang.org:8080
它們都是屬于同一站點维蒙,因為它們的協(xié)議都是 HTTPS掰吕,而且根域名也都是 geekbang.org。Chrome 的默認(rèn)策略是颅痊,每個標(biāo)簽對應(yīng)一個渲染進(jìn)程殖熟。但如果從一個頁面打開了另一個新頁面,而新頁面和當(dāng)前頁面屬于同一站點的話八千,那么新頁面會復(fù)用父頁面的渲染進(jìn)程吗讶。官方把這個默認(rèn)策略叫 process-per-site-instance。
總結(jié)來說恋捆,打開一個新頁面采用的渲染進(jìn)程策略就是:通常情況下照皆,打開新的頁面都會使用單獨的渲染進(jìn)程;如果從 A 頁面打開 B 頁面沸停,且 A 和 B 都屬于同一站點的話膜毁,那么 B 頁面復(fù)用 A 頁面的渲染進(jìn)程;如果是其他情況愤钾,瀏覽器進(jìn)程則會為 B 創(chuàng)建一個新的渲染進(jìn)程瘟滨。渲染進(jìn)程準(zhǔn)備好之后,還不能立即進(jìn)入文檔解析狀態(tài)能颁,因為此時的文檔數(shù)據(jù)還在網(wǎng)絡(luò)進(jìn)程中杂瘸,并沒有提交給渲染進(jìn)程,所以下一步就進(jìn)入了提交文檔階段伙菊。