自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一分鐘帶你看懂:輸入 URL 到頁(yè)面顯示的完整過(guò)程

網(wǎng)絡(luò) 網(wǎng)絡(luò)管理
我們用簡(jiǎn)單有趣的方式,帶你了解了 從瀏覽器輸入 URL 到頁(yè)面展示 的基本流程,希望能讓你對(duì)網(wǎng)頁(yè)加載背后的機(jī)制有一個(gè)大致的了解。

前言:你真的懂你每天的上網(wǎng)嗎?

想象一下,你餓了,打開(kāi)手機(jī)輸入 “炸雞外賣”,然后一堆美食圖片彈出來(lái),幾分鐘后炸雞就送到你手里了。

但你有沒(méi)有想過(guò),這短短的幾秒鐘,你的請(qǐng)求經(jīng)歷了一場(chǎng)“跨越半個(gè)地球”的神秘旅行

這一切是如何發(fā)生的?你在瀏覽器輸入網(wǎng)址,回車,然后呢?

別擔(dān)心,今天咱們就來(lái)用最通俗易懂的方式,帶你看看 你每次上網(wǎng)背后的魔法!(不需要任何計(jì)算機(jī)基礎(chǔ),保證看完秒懂?。?/span>

第一步:你的瀏覽器要找個(gè)“路”

你打開(kāi)瀏覽器,輸入 www.baidu.com,按下回車——但你的電腦其實(shí)并不知道 "www.baidu.com" 是誰(shuí),它只認(rèn)得 數(shù)字地址(IP 地址)。

所以,它得先問(wèn)問(wèn)“互聯(lián)網(wǎng)的電話簿”——DNS(域名系統(tǒng)):

  • 你的電腦:喂,我要去 www.baidu.com,它的地址是多少?
  • DNS 服務(wù)器:稍等,我查查……找到了!它的 IP 地址是 110.242.68.66
  • 你的電腦:好嘞,我這就出發(fā)!

PS:如果 DNS 解析慢了,你就會(huì)覺(jué)得網(wǎng)頁(yè)加載很慢。)

第二步:數(shù)據(jù)“快遞小哥”上門取件

你的電腦得把請(qǐng)求(HTTP 請(qǐng)求)發(fā)送給百度服務(wù)器,這時(shí)候,快遞小哥——TCP/IP 就上場(chǎng)了。

TCP(傳輸控制協(xié)議)就像一個(gè)嚴(yán)謹(jǐn)?shù)乃拓泦T,它不馬虎,每次傳輸數(shù)據(jù)都會(huì)說(shuō):

  1. “喂,百度,我要給你發(fā)數(shù)據(jù)了,你在嗎?”(SYN)
  2. “我在!你發(fā)吧!”(SYN-ACK)
  3. “好的,我開(kāi)始發(fā)了!”(ACK)

這個(gè)過(guò)程叫 三次握手,用來(lái)保證數(shù)據(jù)傳輸?shù)目煽啃?,就像你網(wǎng)購(gòu)前,和商家確認(rèn):

“你真的有貨嗎?” → “我有貨!” → “行,那我下單了!”

第三步:數(shù)據(jù)打包,快遞發(fā)貨

確定通了之后,你的 HTTP 請(qǐng)求(比如“我要訪問(wèn)百度首頁(yè)”)就會(huì)被打包成多個(gè)小紙條(多個(gè)數(shù)據(jù)包),通過(guò)網(wǎng)線、WiFi、光纖、衛(wèi)星……各種方式傳輸出去。

每個(gè)數(shù)據(jù)包都有自己的“身份證”:

  • 寄件人(你的 IP)
  • 收件人(百度的 IP)
  • 內(nèi)容(我要看首頁(yè))

這些包裹會(huì)經(jīng)過(guò)無(wú)數(shù)個(gè)路由器(快遞中轉(zhuǎn)站),每個(gè)路由器都會(huì)看一下“這個(gè)包該往哪走”,然后幫它轉(zhuǎn)發(fā)到更接近百度的地方。

想象一下,你在北京下單買廣東的荔枝:

  1. 荔枝先從果園送到廣州的倉(cāng)庫(kù)
  2. 再?gòu)膹V州的機(jī)場(chǎng)飛到北京
  3. 最后由快遞小哥送到你手里

數(shù)據(jù)傳輸就是這么一站一站“中轉(zhuǎn)”過(guò)來(lái)的。

第四步:百度服務(wù)器收到請(qǐng)求,開(kāi)始“做飯”

當(dāng)百度的服務(wù)器收到你的 HTTP 請(qǐng)求后,會(huì)進(jìn)行以下步驟:

  1. 確認(rèn)你要啥(解析請(qǐng)求)
  2. 去數(shù)據(jù)庫(kù)找數(shù)據(jù)(比如百度首頁(yè)的數(shù)據(jù))
  3. 把網(wǎng)頁(yè)數(shù)據(jù)打包,發(fā)回給你

百度就像一個(gè)餐廳:

  • 你點(diǎn)了“百度首頁(yè)”這道菜
  • 廚房開(kāi)始炒菜(處理請(qǐng)求)
  • 然后裝盤(打包數(shù)據(jù))
  • 最后快遞員(網(wǎng)絡(luò))把菜送回你家

第五步:數(shù)據(jù)返回,頁(yè)面拼裝

數(shù)據(jù)返回的過(guò)程和發(fā)送時(shí)類似,它會(huì)沿著原路回到你的電腦。

但這個(gè)時(shí)候,網(wǎng)頁(yè)并不是一下子就完整顯示的,而是:

  1. HTML 文件 先回來(lái),告訴你的瀏覽器:頁(yè)面大概結(jié)構(gòu)是什么
  2. CSS 文件 再回來(lái),讓頁(yè)面變好看
  3. JS 文件(如果有)讓頁(yè)面更智能
  4. 圖片、視頻、廣告…… 依次加載

如果你覺(jué)得網(wǎng)頁(yè)加載很慢,可能是:

  • 服務(wù)器太忙了(餐廳爆單了)
  • 網(wǎng)絡(luò)太擁擠(快遞堵車了)
  • 你網(wǎng)速太慢了(WiFi 太擠了)

第六步:你看到完整的網(wǎng)頁(yè)!

所有數(shù)據(jù)傳輸完成后,瀏覽器就能把完整的網(wǎng)頁(yè)展示給你!

你會(huì)覺(jué)得“嗯?好像啥也沒(méi)發(fā)生”,但背后其實(shí)完成了一場(chǎng)網(wǎng)絡(luò)魔法。

總結(jié):從輸入網(wǎng)址到網(wǎng)頁(yè)顯示的全過(guò)程

  1. DNS 解析:找地址(就像查電話號(hào)碼)
  2. TCP 三次握手:建立連接(就像和賣家確認(rèn)有貨)
  3. 數(shù)據(jù)打包:你的請(qǐng)求被拆成小包裹發(fā)出
  4. 網(wǎng)絡(luò)傳輸:數(shù)據(jù)包經(jīng)過(guò)多個(gè)路由器到達(dá)服務(wù)器
  5. 服務(wù)器處理請(qǐng)求:百度服務(wù)器“炒菜做飯”
  6. 數(shù)據(jù)返回:服務(wù)器把數(shù)據(jù)送回你的瀏覽器
  7. 網(wǎng)頁(yè)拼裝:瀏覽器把 HTML、CSS、JS 組合成完整頁(yè)面

實(shí)戰(zhàn)演示:你也可以自己看看數(shù)據(jù)傳輸!

想親眼看看你的網(wǎng)絡(luò)請(qǐng)求長(zhǎng)啥樣?你可以這樣做:

  1. 打開(kāi)你的瀏覽器
  2. 按下 F12(打開(kāi)開(kāi)發(fā)者工具)
  3. 切換到 Network(網(wǎng)絡(luò)) 選項(xiàng)卡
  4. 刷新網(wǎng)頁(yè),你就能看到所有的請(qǐng)求和返回的數(shù)據(jù)!

結(jié)語(yǔ)

下次打開(kāi)網(wǎng)頁(yè)時(shí),別再覺(jué)得它是“憑空出現(xiàn)”的了!每一次加載,都是你的電腦和全球各地的服務(wù)器 聯(lián)手上演的一場(chǎng)神秘互動(dòng)。

今天,我們用簡(jiǎn)單有趣的方式,帶你了解了 從瀏覽器輸入 URL 到頁(yè)面展示 的基本流程,希望能讓你對(duì)網(wǎng)頁(yè)加載背后的機(jī)制有一個(gè)大致的了解。不過(guò),為了講得通俗易懂,我們只講了整體過(guò)程,并沒(méi)有深入到更細(xì)節(jié)的部分,比如 DNS 解析的具體過(guò)程、TCP 三次握手的細(xì)節(jié)、數(shù)據(jù)包是如何分片傳輸?shù)?、網(wǎng)絡(luò)通信是如何分層的,以及瀏覽器如何一步步解析 HTML/CSS/JS 渲染出完整頁(yè)面 等等。

責(zé)任編輯:武曉燕 來(lái)源: 跟著小康學(xué)編程
相關(guān)推薦

2020-05-21 19:46:19

區(qū)塊鏈數(shù)字貨幣比特幣

2016-09-12 17:28:45

云存儲(chǔ)應(yīng)用軟件存儲(chǔ)設(shè)備

2021-08-06 08:50:45

加密貨幣比特幣區(qū)塊鏈

2020-06-11 08:04:12

WDMDWDMMWDM

2022-04-28 08:38:09

TCP協(xié)議解碼器

2023-06-12 07:18:26

CPU主頻高頻率

2020-10-13 14:55:31

云計(jì)算云安全技術(shù)

2017-03-30 19:28:26

HBase分布式數(shù)據(jù)

2022-06-02 08:46:04

網(wǎng)卡網(wǎng)絡(luò)服務(wù)器

2025-03-12 00:44:00

2018-07-31 16:10:51

Redo Undo數(shù)據(jù)庫(kù)數(shù)據(jù)

2017-02-21 13:00:27

LoadAverage負(fù)載Load

2018-06-26 05:23:19

線程安全函數(shù)代碼

2017-07-06 08:12:02

索引查詢SQL

2022-07-18 06:16:07

單點(diǎn)登錄系統(tǒng)

2011-02-21 17:48:35

vsFTPd

2018-08-17 07:19:34

網(wǎng)絡(luò)故障硬件軟件

2018-12-12 22:51:24

Java包裝語(yǔ)言

2020-07-09 07:37:06

數(shù)據(jù)庫(kù)Redis工具

2020-07-17 07:44:25

云計(jì)算邊緣計(jì)算IT
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)