網路通訊協議筆記(二)
切換到使用者的角度,看看使用者是如何從上至下,與這些協議互動的。
網路通訊就是交換資料包。電腦A向電腦B傳送一個數據包,後者收到了,回覆一個數據包,從而實現兩臺電腦之間的通訊。
資料包的結構,基本上是下面這樣:
傳送這個包,需要知道兩個地址:
- * 對方的MAC地址;
- * 對方的IP地址。
有了這兩個地址,資料包才能準確送到接收者手中。但是,前面說過,MAC地址有侷限性,如果兩臺電腦不在同一個子網路,就無法知道對方的MAC地址,必須通過閘道器(gateway)轉發。
上圖中,1號電腦要向4號電腦傳送一個數據包。它先判斷4號電腦是否在同一個子網路,結果發現不是,於是就把這個資料包發到閘道器A。閘道器A通過路由協議,發現4號電腦位於子網路B,又把資料包發給閘道器B,閘道器B再轉發到4號電腦。
1號電腦把資料包發到閘道器A,必須知道閘道器A的MAC地址。所以,資料包的目標地址,實際上分成兩種情況:
場景 資料包地址
同一個子網路 對方的MAC地址,對方的IP地址
非同一個子網路 閘道器的MAC地址,對方的IP地址
傳送資料包之前,電腦必須判斷對方是否在同一個子網路,然後選擇相應的MAC地址。接下來,我們就來看,實際使用中,這個過程是怎麼完成的。
使用者的上網設定
靜態IP地址
通常你必須做一些設定。有時,管理員(或者ISP)會告訴你下面四個引數,你把它們填入作業系統,計算機就能連上網了:
- * 本機的IP地址;
- * 子網掩碼;
- * 閘道器的IP地址;
- * DNS的IP地址。
動態IP地址
所謂"動態IP地址",指計算機開機後,會自動分配到一個IP地址,不用人為設定。它使用的協議叫做DHCP協議。
這個協議規定,每一個子網路中,有一臺計算機負責管理本網路的所有IP地址,它叫做"DHCP伺服器"。新的計算機加入網路,必須向"DHCP伺服器"傳送一個"DHCP請求"資料包,申請IP地址和相關的網路引數。
DHCP協議
首先,它是一種應用層協議,建立在UDP協議之上,所以整個資料包是這樣的:
- 1)最前面的"乙太網標頭":設定發出方(本機)的MAC地址和接收方(DHCP伺服器)的MAC地址。前者就是本機網絡卡的MAC地址,後者這時不知道,就填入一個廣播地址:FF-FF-FF-FF-FF-FF。
- 2)後面的"IP標頭":設定發出方的IP地址和接收方的IP地址。這時,對於這兩者,本機都不知道。於是,發出方的IP地址就設為0.0.0.0,接收方的IP地址設為255.255.255.255。
- 3)最後的"UDP標頭":設定發出方的埠和接收方的埠。這一部分是DHCP協議規定好的,發出方是68埠,接收方是67埠。
這個資料包構造完成後,就可以發出了。乙太網是廣播發送,同一個子網路的每臺計算機都收到了這個包。因為接收方的MAC地址是FF-FF-FF-FF-FF-FF,看不出是發給誰的,所以每臺收到這個包的計算機,還必須分析這個包的IP地址,才能確定是不是發給自己的。當看到發出方IP地址是0.0.0.0,接收方是255.255.255.255,於是DHCP伺服器知道"這個包是發給我的",而其他計算機就可以丟棄這個包。
接下來,DHCP伺服器讀出這個包的資料內容,分配好IP地址,傳送回去一個"DHCP響應"資料包。這個響應包的結構也是類似的,乙太網標頭的MAC地址是雙方的網絡卡地址,IP標頭的IP地址是DHCP伺服器的IP地址(發出方)和255.255.255.255(接收方),UDP標頭的埠是67(發出方)和68(接收方),分配給請求端的IP地址和本網路的具體引數則包含在Data部分。
新加入的計算機收到這個響應包,於是就知道了自己的IP地址、子網掩碼、閘道器地址、DNS伺服器等等引數。
不管是"靜態IP地址"還是"動態IP地址",電腦上網的首要步驟,是確定四個引數。
這四個值很重要,值得重複一遍:
- * 本機的IP地址;
- * 子網掩碼;
- * 閘道器的IP地址;
- * DNS的IP地址。
一個例項:訪問網頁
假定使用者設定好了自己的網路引數:
- * 本機的IP地址:192.168.1.100;
- * 子網掩碼:255.255.255.0;
- * 閘道器的IP地址:192.168.1.1;
- * DNS的IP地址:8.8.8.8。
然後他開啟瀏覽器,想要訪問Google,在位址列輸入了網址:www.google.com。
這意味著,瀏覽器要向Google傳送一個網頁請求的資料包。
DNS協議
我們知道,傳送資料包,必須要知道對方的IP地址。但是,現在,我們只知道網址www.google.com,不知道它的IP地址。DNS協議可以幫助我們,將這個網址轉換成IP地址。已知DNS伺服器為8.8.8.8,於是我們向這個地址傳送一個DNS資料包(53埠)。
然後,DNS伺服器做出響應,告訴我們Google的IP地址是172.194.72.105。於是,我們知道了對方的IP地址。
子網掩碼
接下來,我們要判斷,這個IP地址是不是在同一個子網路,這就要用到子網掩碼。
已知子網掩碼是255.255.255.0,本機用它對自己的IP地址192.168.1.100,做一個二進位制的AND運算(兩個數位都為1,結果為1,否則為0),計算結果為192.168.1.0;然後對Google的IP地址172.194.72.105也做一個AND運算,計算結果為172.194.72.0。這兩個結果不相等,所以結論是,Google與本機不在同一個子網路。
因此,我們要向Google傳送資料包,必須通過閘道器192.168.1.1轉發,也就是說,接收方的MAC地址將是閘道器的MAC地址。
應用層協議
瀏覽網頁用的是HTTP協議,它的整個資料包構造是這樣的:
HTTP部分的內容,類似於下面這樣:
1 2 3 4 5 6 7 8 9 |
|
假定這個部分的長度為4960位元組,它會被嵌在TCP資料包之中。
TCP協議
TCP資料包需要設定埠,接收方(Google)的HTTP埠預設是80,傳送方(本機)的埠是一個隨機生成的1024-65535之間的整數,假定為51775。TCP資料包的標頭長度為20位元組,加上嵌入HTTP的資料包,總長度變為4980位元組。
IP協議
然後,TCP資料包再嵌入IP資料包。IP資料包需要設定雙方的IP地址,這是已知的,傳送方是192.168.1.100(本機),接收方是172.194.72.105(Google)。IP資料包的標頭長度為20位元組,加上嵌入的TCP資料包,總長度變為5000位元組。
乙太網協議
最後,IP資料包嵌入乙太網資料包。乙太網資料包需要設定雙方的MAC地址,傳送方為本機的網絡卡MAC地址,接收方為閘道器192.168.1.1的MAC地址(通過ARP協議得到)。
乙太網資料包的資料部分,最大長度為1500位元組,而現在的IP資料包長度為5000位元組。因此,IP資料包必須分割成四個包。因為每個包都有自己的IP標頭(20位元組),所以四個包的IP資料包的長度分別為1500、1500、1500、560。
伺服器端響應
經過多個閘道器的轉發,Google的伺服器172.194.72.105,收到了這四個乙太網資料包。根據IP標頭的序號,Google將四個包拼起來,取出完整的TCP資料包,然後讀出裡面的"HTTP請求",接著做出"HTTP響應",再用TCP協議發回來。
本機收到HTTP響應以後,就可以將網頁顯示出來,完成一次網路通訊。
這個例子大致上反映了網際網路協議的整個通訊過程。
相關推薦
網路通訊協議筆記(二)
切換到使用者的角度,看看使用者是如何從上至下,與這些協議互動的。 網路通訊就是交換資料包。電腦A向電腦B傳送一個數據包,後者收到了,回覆一個數據包,從而實現兩臺電腦之間的通訊。資料包的結構,基本上是下面這樣: 傳送這個包,需要知道兩個地址: * 對方的MAC地址
網路通訊協議筆記(四)
可靠傳輸的工作原理 1.超時重傳: 每次傳送完一個分組,設定一個超時計時器。如果超時計時器到期之前收到對方的確認,就撤銷已設定的超時計時器。 note: 傳送方在傳送完一個分組,必須暫時保留已傳送的分組的副本(為發生超時重傳使用)。只有收到相應確認才清除暫存的分組副本
網路通訊程式設計筆記(二):pcap庫使用
Libpcap是Packet Capture Libray的英文縮寫,即資料包捕獲函式庫。該庫提供的C函式介面用於捕捉經過指定網路介面的資料包,該介面應該是被設為混雜模式。這個在原始套接子中有提到。 著名的軟體TCPDUMP就是在Libpcap的基礎上開發而成的。L
網路基礎二:網路通訊協議簡要(下)
我們已經知道,網路通訊就是交換資料包。電腦A向電腦B傳送一個數據包,後者收到了,回覆一個數據包,從而實現兩臺電腦之間的通訊。資料包的結構,基本上是下面這樣: 傳送這個包,需要知道兩個地址:* 對方的MAC地址;* 對方的IP地址。有了這兩個地址,資料包才能準確送到接收者手中。
XMPP即時通訊協議使用(二)——基於Smack相關操作
package com.test; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; import java.util.List; import java.
計算機網路-網路層學習筆記(二)
地址解析協議ARP 主要作用:已知IP的情況下,找到硬體地址。 RARP:知道硬體地址找IP。現已包含在DHCP中。 IP地址32位;硬體地址48位。 地址解析協議ARP在ARP快取記憶體中存放一個從IP地址到硬體地址的對映表。並時常動態更新。以銜接IP地址與硬體地址。 每個主機都有
802.11協議筆記(二)——PHY物理層的幀格式(802.11b)
該文內容主要取自http://blog.chinaunix.net/uid-26611973-id-3431390.html,用於整理個人學習記錄。 這篇文章主要介紹layer1物理層802.11b的內容。 IEEE802.11b是一個工作在2.4GHz ISM頻段、物理層
網路通訊協議基礎(ISIS)——入門
今天是這個系列部落格的開始,第一次寫部落格,希望這些年自己所學到東西能夠幫助更多的人。但是轉載的時候還是請註明下是轉載的,謝謝啦,嘿嘿。 網路通訊協議是一個挺窄的方向。相對於Android、ios、JavaScript、python等等方向,網路通訊協議知道的人很少。本文也
網路程式設計 筆記(二) 基於 Windows簡單通訊
windows套接字程式設計 1、設定庫Alt+F7 ->“配置屬性”-> “聯結器” -> “輸入” -> “附加依賴項” -> “ws2_32.lib” 2、標頭檔案:#include <winsock2.h>
HTTP筆記(二)HTTP協議的通訊
客戶端和伺服器之間的通訊 HTTP協議和TCP/IP協議族內的其他眾多的協議相同,用於客戶端和伺服器之間的通訊。 客戶端:請求訪問文字或影象等資源的一端稱為客戶端。 服務端:提供資源響應的一端。 請求和響應 HTTP協議規定,請求有客戶端發出,最後
分布式筆記(二)一致性協議
分析 text 如何 更多 區別 accept 進行 當前 分布式系統 一致性協議 一、2PC與3PC 請自行回憶2PC與3PC的過程,及在正式提交階段的處理單點問題的區別。分析各自的優缺點。 二、Paxos算法 一)Paxos算法解決的問題:分布式系統中如何對一個問題
Javaweb學習筆記(二):servlet初體驗、HTTP協議
目錄 1.Servlet體驗 1.1servlet的繼承體系 1.2手動開發動態web資源 1.3工具開發動態資源 2.HTTP協議 2.1概念 2.2請求資訊 2.2.1請求行 2.2.2請求頭 2.2.3空行與實體內容 2.3HttpServlet
HTTP協議學習筆記(二)
HTTP協議學習筆記(二) 1.HTTP報文 HTTP報文:用於HTTP協議互動的資訊。請求報文:請求端(客戶端)的HTTP報文叫做請求報文。響應報文:響應端(服務端)的HTTP報文叫做響應報文。 HTTP報文大致可分為報文首部和報文主體兩塊。兩者最初由空行(CR+LF)來劃
【Python】搭建你的第一個簡單的神經網路_準備篇_NN&DL學習筆記(二)
前言 本文為《Neural Network and Deep Learning》學習筆記(二),可以轉載但請標明原文地址。 本人剛剛入門、筆記簡陋不足、多有謬誤,而原書精妙易懂、不長篇幅常有柳暗花明之處,故推薦閱讀原書。 《Neural Network and Deep Learning
計算機網路之IP路由(二)---RIP協議
RIP 基本原理 RIP是基於貝爾曼-福特演算法的一種內部閘道器路徑向量協議。RIP基於UDP封裝路由資訊,在520號埠上偵聽並接收來自遠端路由器傳送的路由更新資訊,並對本地路由器中的路由表做相應的修改在廣播給
讀書筆記(二)-計算機網路體系結構
計算機網路體系結構 計算機網路的各層及其協議的集合。換種說法,就是這個計算機網路及其構件所應完成的功能的精確定義。 一、網路協議 為進行網路中的資料交換而建立的規則、標準或約定。這些規則明確規定了所交換的資料的格式以及有關的同步(時序)問題。 三要素 (1)語法,資料
深度學習入門筆記(二)————線性神經網路解決異或問題(程式碼)
首先梳理一下思路 輸入為1,0。00異或為0,01異或為1,10異或為1,11異或為0.所以輸出為2類如下圖可知,需要兩條線劃分。 Madaline用間接地辦法解決。多個線性函式進行劃分,然後對各個神經元的輸出做邏輯運算。如圖,用兩條直線實現了異或的劃分。 線
STM32開發筆記48:STM32F4+DP83848乙太網通訊指南系列(二):系統時鐘
本章為系列指南第二章,主要是介紹一下STM32F4的時鐘配置。時鐘是一個嵌入式產品從零開始開發的基石,一切邏輯都在時鐘的節奏中安靜地彈奏著,時鐘為整個電路帶來了歡快的「心跳」。開發者如果對時鐘沒有控制能力,就會把脈不準整個旋律的節奏,從而導致諸如通訊波特率、通訊時序、延時操作等關鍵功能全都紊亂,系統
Tensorflow 學習筆記(二): 深層神經網路
Tensorflow 學習筆記(二): 深層神經網路 前言 本文是閱讀《TensorFlow:實戰Google深度學習框架》第四章提煉出來的筆記。 同時我在github找到這本書作者提供的配套原始碼,發現和書相比多了一些例子(code),推薦結合書一起使用! 深度學習與深層神
cs231n斯坦福基於卷積神經網路的CV學習筆記(二)神經網路訓練細節
五,神經網路 注意點part1 例項:邏輯迴歸二層神經網路訓練函式 使用權重w和偏差值biase計算出第一個隱含層h,然後計算損失,評分,進行反向傳播回去 多種常用啟用函式(一般預設max(0,x)),如sigmoid函式具有飽和區梯度0,非零點中心,計算x複