網(wǎng)絡(luò)分層模式原理分析 為什么要進(jìn)行網(wǎng)絡(luò)層次劃分?
寫在前邊
整個暑假去面試,面試了很多家公司(無論是小廠還是大廠)問到的深度不同,網(wǎng)絡(luò)原理是面試最容易問到的問題,雖然我們在項目中很少去實(shí)踐它,但是了解其原理,會讓我們背后網(wǎng)絡(luò)通信是如果工作的,既能在面試官面前體現(xiàn)出你的基礎(chǔ)是否扎實(shí),也能對以后深入網(wǎng)絡(luò)這部分學(xué)習(xí)有更多的了解。
很多同學(xué)面試在準(zhǔn)備這部分的時候,都會去背,這部分確實(shí)很難掌握,我個人總結(jié)的最好的學(xué)習(xí)網(wǎng)絡(luò)原理的方法就是不用刻意的去記憶而是完全的結(jié)合實(shí)際去講整個原理融會貫通。雖然一開始學(xué)習(xí)起來很吃力,但是稍微用點(diǎn)心,多看幾遍,多問自己為什么,把自己當(dāng)做是開發(fā)網(wǎng)絡(luò)原理的開發(fā)者,面試前的準(zhǔn)備只要理清邏輯就足夠了,而不是去背這部分內(nèi)容。
而且這部分相同的知識點(diǎn)面試官有多種提問方式,但是其中很多都是換湯不換藥。我記得最多的問的是輸入URL,到頁面呈現(xiàn)出來,其中經(jīng)歷了什么?這道面試題的背后,涉及到了很多網(wǎng)絡(luò)原理的知識,我們這篇文章不會全部分享到,而是先把由來和網(wǎng)絡(luò)層次劃分弄清楚,就完成了這篇文章的目的。
No.1.為什么要進(jìn)行網(wǎng)絡(luò)層次劃分?說到網(wǎng)絡(luò)層次劃分并不陌生,我剛剛接觸到網(wǎng)絡(luò)層次的時候一臉懵逼,這么多層,一層不就行了嘛?層與層之間好多協(xié)議,還有各種數(shù)據(jù)包,第一次我放棄了。
當(dāng)我從新拾起網(wǎng)絡(luò)層次的時候,我下定決心從根上理解它。首先弄明白它的原理,那必定要知道它的由來,也就是為什么要進(jìn)行網(wǎng)絡(luò)層次劃分?這個問題問的好。
假如“小鹿”是網(wǎng)絡(luò)的開發(fā)人員,起初認(rèn)為計算機(jī)與計算機(jī)之間的通信只需要一根線就可以完成通信,對沒錯,但是世界那么大,那么多計算機(jī),距離又遠(yuǎn),不但浪費(fèi)線,還沒出現(xiàn)各種線被你偷偷剪斷的情況,毋庸置疑,那計算機(jī)之間通信就不行了。(后邊出來了無線網(wǎng),雖然其中網(wǎng)關(guān)、路由之間也需要連線,但不是讓每臺計算機(jī)兩兩連接,而是一個區(qū)域?yàn)閱挝挥嬎銠C(jī)相互連接通信)
不行,老板說,“小鹿”你給我想法子改,改不出來今晚不能睡覺,“小鹿”仔細(xì)想了想,這還是個技術(shù)活,需要進(jìn)行全面的改進(jìn),也發(fā)現(xiàn)所謂的計算機(jī)之間的連線只能傳送0、1信號,另一臺計算并不知道那么多0、1代表什么,而且“小鹿”又發(fā)現(xiàn)不同廠商的生產(chǎn)的計算機(jī)既然有連線實(shí)現(xiàn)通信也是很麻煩的,干脆定義一套規(guī)則吧,無論“某碩”計算機(jī)還是“某想”計算機(jī),都必須遵守這套規(guī)則,其實(shí)所說的這套規(guī)則就是我們經(jīng)常說的“網(wǎng)絡(luò)協(xié)議”。
不是說網(wǎng)絡(luò)層次的由來嗎,怎么講到網(wǎng)絡(luò)協(xié)議了。咱們繼續(xù),通過上面的問題,那個計算機(jī)之間通過連線傳送0、1信號的問題雖然規(guī)定了通信規(guī)則,但是除了像0、1這種無意義的信號之外,網(wǎng)絡(luò)中還存在著其他各種各樣的問題,兩個計算機(jī)之間怎么進(jìn)行識別?以及怎么才能知道對方的地址?以及不同計算機(jī)應(yīng)用程序怎么知道是給自己傳遞的數(shù)據(jù),還有不同的通信數(shù)據(jù)格式怎么來規(guī)定等等一系列的問題都出來了。
“小鹿”發(fā)現(xiàn),如果各種問題都寫成一套協(xié)議來規(guī)定雙方通信的規(guī)則,但是呢?萬一其中哪些規(guī)則通信中出現(xiàn)問題,影響到了其他規(guī)則,最常見的就是數(shù)據(jù)包,一個數(shù)據(jù)包中如果包含各種各樣的協(xié)議,不就亂套了。
“小鹿”為了能夠把它設(shè)計的更好,決定采用分層劃分的結(jié)構(gòu),既能規(guī)定不同層的完成的功能,又能實(shí)現(xiàn)層與層之間的改動而不相互影響,這就是我們經(jīng)常聽到網(wǎng)絡(luò)劃分層次的好處。
No.2.網(wǎng)絡(luò)分層是如何進(jìn)行分層的?既然我們決定要分層,那么分為幾層才好呢?
起初網(wǎng)絡(luò)分層是標(biāo)準(zhǔn)的七層,也就是我們所說的 OSI 七層模型。
參考模型是國際標(biāo)準(zhǔn)化組織(ISO)制定的一個用于計算機(jī)或通信系統(tǒng)間互聯(lián)的標(biāo)準(zhǔn)體系,一般稱為OSI參考模型或七層模型。
我們所知道的還有 TCP/IP 四層模型和 TCP/IP 五層模型。這又是怎么出來的,其實(shí)所謂的 TCP/IP 四層模型和 TCP/IP 五層模型是以 OSI 七層優(yōu)化而來,把某些層進(jìn)行合并了,其實(shí)本質(zhì)上還是相同的,但是我個人最喜歡用五層來解釋。
No.3.每一層的作用是什么?
這一部分涉及到每一層的很多協(xié)議和知識點(diǎn),但是我們這一節(jié)不具體分享,為什么?我們具體深入之前必須大腦里有個具體的網(wǎng)絡(luò)分層結(jié)構(gòu)圖,先要知道每層是做什么的,層與層之間的關(guān)系,然后下一節(jié)再深入每層中的每個協(xié)議怎么通信的,這樣的好處學(xué)起來條理清晰,而不至于當(dāng)時我學(xué)習(xí)的時候表面還不懂,就深入最后懵逼狀態(tài)。
物理層
物理層,顧名思義,用物理手段將電腦連接起來,就像我們上邊講到的計算機(jī)之間的物理連線。主要用來傳輸0、1信號,上邊也分析過了,0、1信號畢竟沒有任何的現(xiàn)實(shí)意義,所有我們用另一層用來規(guī)定不同0、1組合的意義是什么。
數(shù)據(jù)鏈路層
下層的物理層既然不能規(guī)定不同0、1組合的信號代表什么意義,那么我們在數(shù)據(jù)鏈路層規(guī)定一套協(xié)議,專門的給0、1信號進(jìn)行分組,以及規(guī)定不同的組代表什么意思,從而雙方計算機(jī)都能夠進(jìn)行識別,這個協(xié)議就是“以太網(wǎng)協(xié)議”(具體的以太網(wǎng)協(xié)議內(nèi)容下節(jié)內(nèi)容詳細(xì)講解)。
但是問題又來了,我們要發(fā)送給對方計算機(jī),怎么標(biāo)識對方以及怎么知道對方的地址呢?
1、MAC 地址
我們所說的MAC地址到底的作用是啥?說白了它就是作為網(wǎng)絡(luò)中計算機(jī)設(shè)備的唯一標(biāo)識,從計算機(jī)在廠商生產(chǎn)出來就被十六進(jìn)制的數(shù)標(biāo)識為MAC地址。
既然我們知道了用MAC地址作為標(biāo)識,那么怎么才能知道我們要進(jìn)行通信的計算機(jī)MAC地址呢?
2、廣播
這里廣播詳細(xì)的在下一節(jié)講,這一節(jié)你只需要知道廣播可以幫助我們能夠知道對方的 MAC 地址。那么既然知道了MAC地址就可以通信了?沒有想得那么簡單,廣播中還存在兩種情況,一種是,在同一子網(wǎng)絡(luò)下(同一局域網(wǎng)下)的計算機(jī)是通過 ARP 協(xié)議獲取到對方 MAC地址的。不同自網(wǎng)絡(luò)中(不同局域網(wǎng))中是交給兩個局域網(wǎng)的網(wǎng)關(guān)(路由器)去處理的。這里邊涉及到很多細(xì)節(jié)的知識,都會集中到下一節(jié),但是這一節(jié)你了解怎么進(jìn)行標(biāo)識計算機(jī)和怎么獲取到MAC地址就可以了。
網(wǎng)絡(luò)層
物理層和數(shù)據(jù)鏈路層都有自己的事情要做,也就是我們上邊所講到的這些(里邊很多細(xì)節(jié)不在這節(jié)多說)。上邊兩層在我看來可以完成正常通信了,那么網(wǎng)絡(luò)層出來干啥子?
網(wǎng)絡(luò)層的由來是因?yàn)樵跀?shù)據(jù)鏈路層中我們說說兩臺計算機(jī)之間的通信是分為同一子網(wǎng)絡(luò)和不同子網(wǎng)絡(luò)之間,那么問題就來了,怎么判斷兩臺計算機(jī)是否在同一子網(wǎng)絡(luò)(局域網(wǎng))中?這就是網(wǎng)絡(luò)層要解決的問題。
1、IP 協(xié)議
我們通常用到的 IP 地址,就是網(wǎng)絡(luò)層中的東西,所規(guī)定的的協(xié)議就是 IP 協(xié)議。很多小伙伴問,IP 地址想必也是地址吧,上邊都有唯一標(biāo)識的 MAC 地址了,IP 地址出來是混飯吃的?為了能夠讓大家更方便的理解 IP 地址和 MAC 地址,我們可以將 IP 地址抽象成一種邏輯上的地址,也就是說 MAC 地址是物理上的地址,就是定死了。IP 地址呢,是動態(tài)分配的,不是固定死的。
我們就是通過 IP 地址來判斷兩個計算機(jī)設(shè)備是否在同一子網(wǎng)絡(luò)中的,那么你會問它是怎么判斷的,以及 IP 地址誰給他分配的?又是如何分配的等一些列問題,我們不著急,這里只說一下大體的流程,詳細(xì)會后續(xù)寫一大篇。
既然我們通過 IP 地址來判斷兩個計算機(jī)是否處于同一局域網(wǎng)中,那么首先要知道對方的 IP 地址吧?DNS 解析想必大家都知道,可以將域名解析為 IP 地址。好了,我們知道兩臺計算機(jī)的 IP 地址了,怎么進(jìn)行判斷是否同一局域網(wǎng)中?
2、子網(wǎng)掩碼
嘿嘿,又是一個只聽說過,但是不知道這個什么作用的一個名詞,沒事,等我聊完,你就明白是做什么的了。
子網(wǎng)掩碼就是用來標(biāo)識同一局域網(wǎng)中的 IP 地址的信息的?什么信息?IP 地址是由 32 個二進(jìn)制位組成的,也就是四個十進(jìn)制(如:255.255.255.000)。
子網(wǎng)掩碼也是由 32 個二進(jìn)制位組成的,但是只能用 0 或 1 來表示,如11111111.11111111.11111111.00000000。
到底什么意思呢?有 1 的部分表示網(wǎng)絡(luò)部分,有 0 表示主機(jī)部分,這和判斷兩臺計算機(jī)是否在同一局域網(wǎng)中有什么關(guān)系?沒錯,是有關(guān)系的!兩臺計算機(jī)的 IP 地址分別和子網(wǎng)掩碼進(jìn)行一種運(yùn)算(AND 運(yùn)算),如果結(jié)果相同,兩臺計算機(jī)就在同一局域網(wǎng)中,否則就不在同一局域網(wǎng)中。
AND 是如何進(jìn)行運(yùn)算的,IP 的數(shù)據(jù)包的組成等問題,不在這里多陳述。
傳輸層
好了,如果你認(rèn)為計算機(jī)可以進(jìn)行通信了,那么“小鹿”恭喜你,你已經(jīng)基本知道了以上幾層劃分的作用,但是如果你正在一邊打 LOL,一邊和朋友在 QQ 聊天,突然,游戲中隊友聊天信息出現(xiàn)在了 QQ 窗口中,咦?出現(xiàn)了什么情況?
其實(shí)是以上層級還是不夠,出現(xiàn)上邊的原因就是,兩臺計算機(jī)雖然可以通信了,但是每天計算機(jī)運(yùn)行著好多的程序,誰知道你們傳輸?shù)男畔⑹菍儆谀男┏绦虻模共坏?LOL 的聊天信息跑到了 QQ 窗口中。
想必大家猜到了傳輸層主要用來干啥滴,是的,傳輸層的主要功能就是為了能夠?qū)崿F(xiàn)“端口到端口”的通信。計算機(jī)上運(yùn)行的不同程序都會分配不同的端口,所以才能使得數(shù)據(jù)能夠正確的傳送給不同的應(yīng)用程序。
1、UDP協(xié)議
加入端口號也需要一套規(guī)則,那就是 UDP 協(xié)議,但是 UDP協(xié)議有個缺點(diǎn),一旦進(jìn)行通信,就不知道對方是否接收到數(shù)據(jù)了,我們再定義一套規(guī)則,讓其可以和對方進(jìn)行確認(rèn),那么 TCP 出現(xiàn)了。
2、TCP 協(xié)議
我們通常說 TCP 三次握手和四次揮手,沒錯,這就是傳輸層中完成的,TCP 三次握手涉及到的內(nèi)容賊多,都可以單獨(dú)寫一篇長文,這里不多陳述,知道它是在傳輸層中完成的以及它的作用是什么,能夠認(rèn)識到它就好了。
應(yīng)用層
“喂,你發(fā)給我的是什么破數(shù)據(jù),亂七八糟的,我TM能解析嗎?能不能按照我的規(guī)定給我傳送?“
“好的,下次不敢了”
想必大家已經(jīng)猜到了應(yīng)用層的協(xié)議,應(yīng)用層的功能就是規(guī)定了應(yīng)用程序的數(shù)據(jù)格式。我們經(jīng)常用得到的電子郵件、HTTP協(xié)議、以及FTP數(shù)據(jù)的格式,就是在應(yīng)用層定義的。
那么從最下方的物理層到最上方的應(yīng)用層,看了上邊想必都有一個感性的認(rèn)識了,不需要靠記憶去記了。
文章中可能存在講的不對和不足的地方,還請各位給予改正。由于網(wǎng)絡(luò)原理這部分涉及到的知識點(diǎn)龐大,今天這篇文章要入門了解網(wǎng)絡(luò)分層的模型已經(jīng)足夠了。
來源:一個不甘平凡的碼農(nóng)