導(dǎo)航流程:從輸入URL到頁面展示扎拣,這中間發(fā)生了什么赴肚?

那么今天我們就一起來探索下這個流程,下圖是我梳理出的“從輸入 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)入了提交文檔階段伙菊。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末败玉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子镜硕,更是在濱河造成了極大的恐慌运翼,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件兴枯,死亡現(xiàn)場離奇詭異血淌,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)财剖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門悠夯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來癌淮,“玉大人,你說我怎么就攤上這事疗疟「媚” “怎么了瞳氓?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵策彤,是天一觀的道長。 經(jīng)常有香客問我匣摘,道長店诗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任音榜,我火速辦了婚禮庞瘸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘赠叼。我一直安慰自己擦囊,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布嘴办。 她就那樣靜靜地躺著瞬场,像睡著了一般。 火紅的嫁衣襯著肌膚如雪涧郊。 梳的紋絲不亂的頭發(fā)上贯被,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天,我揣著相機(jī)與錄音妆艘,去河邊找鬼彤灶。 笑死,一個胖子當(dāng)著我的面吹牛批旺,可吹牛的內(nèi)容都是我干的幌陕。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼汽煮,長吁一口氣:“原來是場噩夢啊……” “哼搏熄!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起逗物,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤搬卒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后翎卓,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體契邀,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年失暴,在試婚紗的時候發(fā)現(xiàn)自己被綠了坯门。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片微饥。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖古戴,靈堂內(nèi)的尸體忽然破棺而出欠橘,到底是詐尸還是另有隱情,我是刑警寧澤现恼,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布肃续,位于F島的核電站,受9級特大地震影響叉袍,放射性物質(zhì)發(fā)生泄漏始锚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一喳逛、第九天 我趴在偏房一處隱蔽的房頂上張望瞧捌。 院中可真熱鬧,春花似錦润文、人聲如沸姐呐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽曙砂。三九已至,卻和暖如春赠法,著一層夾襖步出監(jiān)牢的瞬間麦轰,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工砖织, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留款侵,地道東北人。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓侧纯,卻偏偏與公主長得像新锈,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子眶熬,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內(nèi)容