<thead id="rrjt3"></thead>
      <progress id="rrjt3"><dfn id="rrjt3"></dfn></progress>

      <em id="rrjt3"></em>

        <address id="rrjt3"><ins id="rrjt3"><dfn id="rrjt3"></dfn></ins></address>
          <i id="rrjt3"></i>

        輸入網址后發生了什么(常見經典面試題)

        時間:2021-09-09 09:08:56 類型:web前端
        字號:    

        一次HTTP請求過程或者輸入網址(www.yiingding.com)后發生了什么?

        前言

        一、流程概括

        二、具體流程

        1.DNS解析

        2.三次握手建立連接

        2.1為什么是三次握手,二次不行嗎?

        3.發送HTTP請求

        4.服務器解析請求,并返回數據

        5.瀏覽器解析響應,展示相應的界面

        6.斷開連接(四次揮手)

        6.1為什么是四次揮手?

        前言

        當我們在瀏覽器中輸入一個網址后,瀏覽器給我們返回一個頁面過程中,到底發生了什么?


        一、流程概括

        1.進行DNS解析,找到對應ip地址的服務器

        2.通過TCP協議建立連接(三次握手)

        3.建立連接后,瀏覽器發送HTTP請求

        4.服務器根據HTTP請求返回相應的數據

        5.瀏覽器根據協議解析數據,得到資源

        6.根據得到的資源顯示在頁面上

        7.根據Connection的Keep-Alive屬性可以選擇是否斷開TCP連接(四次揮手)


        二、具體流程

        1.DNS解析

        DNS解析過程就是尋找哪臺機器上有你所要的資源,根據URL得到相應的ip地址去尋找:

        1.先在瀏覽器本地緩存中查找是否相應的記錄,瀏覽器緩存會保存一些訪問過網址的DNS信息,

        2.如果沒有找到,就在本機操作系統緩存中查找是否有當前要訪問的DNS信息,

        3.如果還沒有找到對應的ip地址,就發送到路由器上,路由器根據自身查找當前記錄,路由器本身也會存儲一些DNS信息,

        4.如果沒有找到,這個請求就會發送到運營商上,運營商就是互聯網服務提供商,一般大部分請求的域名都能在這里找到,

        5.如果還沒有找到,就將請求發送給根域名服務器進行搜索,

        6.如果還沒找到,就說明這個域名不存在,或者說域名過期了。


        所以DNS解析過程就是

        瀏覽器->操作系統->路由器->運營商->根路由器


        2.三次握手建立連接

        找到相對應的服務器之后,瀏覽器要和服務器建立相對應的連接,通過三次握手建立連接,保證建立連接無誤。

        為什么要進行三次握手?確保接收雙方發送能力和接收能力是否正常

        三次揮手的過程:

        1.第一次握手,客戶端向服務器發送SYN報文,并指明客戶端的初始化序列號 ISN,首部的同步位SYN=1,初始序號seq=x,

        2.第二次握手,服務器接收到客戶端SYN報文,并將自己的SYN報文作為響應發送,同時把客戶端的ISN+1作為ACK的值,表明自己已經接收到客戶端的SYN

        3.第三次握手,客戶端接收到服務器SYN報文后,同樣把服務器的ISN+1作為ACK的值,表示已經接收到服務器的SYN報文,服務器收到ACK值后,此時雙方建立連接



        2.1為什么是三次握手,二次不行嗎?

        三次握手的目的就是確認客戶端和服務器兩端接收和發送能力正常,通過三次握手來保證的

        1.第一次握手,客戶端發送報文,服務器接收報文

        這樣服務器端就能得到結論:客戶端的發送能力,服務器的接收能力是正常的

        2.第二次握手 服務器發送報文, 客戶端接收報文 ,

        客戶端得到結論 客戶端接收能力,服務器發送能力是正常的,但是此時服務器并不知道,客戶端的接收能力是否正常,就需要第三次握手來確定

        3.第三次握手 客戶端發送報文,客戶端接收報文,

        服務器就得到了 客戶端接收能力正常

        這樣三次握手才能確定雙方的接收能力和發送能力是否正常


        如果是兩次握手:

        有一次連接的時候,客戶端發送的請求丟失了,客戶端等待一段時間后沒有接收到響應,就會重新發送一個請求,第二個請求成功到達后,服務返回響應建立連接,但是第一次請求可能在某些網絡結點長時間滯留了,延誤到連接釋放以后的某個時間才到達服務端,這樣服務器以為是建立了新的連接了,就發送響應,此時客戶端會忽略服務器發送的響應,也不發送數據,而服務器這邊一直等待客戶端發送的數據,造成了資源的浪費。


        3.發送HTTP請求

        通過建立的TCP連接,客戶端向服務器發送HTTP請求,

        1、HTTP請求的格式

        1.首行: 【方法】+【URL】+【版本】

        2.Header(請求報頭):請求的屬性 , 冒號分割鍵值對

        3.空行:Header結束的標志

        4.Body : 空行后面的內容都是Body


        4.服務器解析請求,并返回數據

        服務器根據HTTP協議來解析請求,得到客戶端想要的數據,并發送響應

        HTTP響應格式

        1.首行: 【版本號】+【狀態碼】+【狀態碼解釋】

        2.Header:響應的屬性 , 冒號分割鍵值對

        3.空行:Header結束的標志

        4.Body : 空行后面的內容都是Body


        5.瀏覽器解析響應,展示相應的界面

        瀏覽器通過HTTP協議來解析服務器發送的響應,將響應中的資源展現出來,比如一些HTML界面,文字,圖片信息等


        6.斷開連接(四次揮手)

        當數據完成請求到返回的過程之后,根據Connection的Keep-Alive屬性可以選擇是否斷開TCP連接

        雙方都可以主動斷開連接,斷開連接后主機中的「資源」將被釋放。

        1.客戶端想斷開連接,就會發送一個TCP首部FIN標志為1的報文,也就是FIN報文,之后客戶端進入FIN_wait_1狀態

        2.服務器接收到客戶端發送的報文,就會回復一個ACK應答報文,服務器進入CLOSED_WAIT狀態

        3.客戶端接收到服務器的應答報文,就進去FIN_wait_2狀態

        4.等待服務器端處理完數據后,向客戶端發送一個FIN報文,服務器進如LAST_ACK狀態

        5.客戶端接收到FIN報文后,回復一個ACK報文,客戶端進入TIME_WAIT 狀態

        6.服務器接收到ACK報文后,就進入了CLOSED狀態,自此服務器端已經完成連接的關閉

        7.客戶端等待2個時間段后,自動進入CLOSED狀態,自此客戶端已經完成連接的關閉



        首先客戶端發送FIN報文,就是說明客戶端不再發送數據,但是還會接收數據,服務器接收到FIN時,先發送響應ACK,但是服務器這邊還有未處理完的數據,還要發送數據,當服務器不再發送數據時,才會發送FIN給客戶端,通過現在關閉連接。


        6.1為什么是四次揮手?

        TCP連接時不允許半打開狀態,就單向傳輸數據,所以在三次握手時,服務器就會把SYN和ACK同時發送給客戶端,其中,ACK 用來打開客戶端的發送通道,SYN 用來打開服務器的發送通道。這樣,原本的四次握手就降為三次握手了。

        而當連接處于半關閉狀態時,TCP是允許單向傳輸數據的,當客戶端要關閉連接時,發送FIN但是服務器可能還沒有處理完數據,等服務器處理完數據后才會發送FIN確認關閉數據,即每一方都要接收和發送FIN和ACK報文,所以就是四次揮手了

        黄网站免费 <