新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 深入淺出計(jì)算機(jī)間通信原理

深入淺出計(jì)算機(jī)間通信原理

作者: 時(shí)間:2016-12-01 來(lái)源:網(wǎng)絡(luò) 收藏

兩臺(tái)主機(jī)之間的數(shù)據(jù)傳輸結(jié)束了,那就要關(guān)閉連接.當(dāng)一方主動(dòng)關(guān)閉連接時(shí),它將會(huì)發(fā)送FIN 數(shù)據(jù)包來(lái)通告對(duì)方.對(duì)方接收FIN 數(shù)據(jù)包后就會(huì)返回FIN_ACK 數(shù)據(jù)包來(lái)確認(rèn).(編者注:凡是已經(jīng)主動(dòng)發(fā)送過(guò)FIN 數(shù)據(jù)包的主機(jī)都不能夠再發(fā)送任何數(shù)據(jù),但可以接收數(shù)據(jù))只有雙方都各自都完成了發(fā)送FIN 數(shù)據(jù)包,那么TCP連接也就關(guān)閉了.這就是TCP 的四次握手過(guò)程.

發(fā)送數(shù)據(jù)和這些差不多,有興趣的讀者可以看看<> 或者給LCatro 留個(gè)言.

4.小總結(jié):

數(shù)據(jù)包的結(jié)構(gòu)搞亂了?請(qǐng)看看下圖吧..




圖十四 網(wǎng)絡(luò)數(shù)據(jù)包結(jié)構(gòu)
由于我們?cè)谝蕴W(wǎng)下利用以太網(wǎng)協(xié)議發(fā)送數(shù)據(jù),所以我們的要發(fā)送到目的主機(jī)的數(shù)據(jù)就包含在以太網(wǎng)數(shù)據(jù)包的數(shù)據(jù)里面.對(duì)于這個(gè)數(shù)據(jù),實(shí)際上是IP 數(shù)據(jù)包,然而IP 數(shù)據(jù)包里面的數(shù)據(jù)其實(shí)是TCP 數(shù)據(jù)包,TCP 數(shù)據(jù)包里面的數(shù)據(jù)就是我們要發(fā)送的信息.所以讀者們結(jié)合上圖來(lái)理解網(wǎng)絡(luò)數(shù)據(jù)包結(jié)構(gòu)(右邊)就容易了..

至于左邊的結(jié)構(gòu)圖的意思是網(wǎng)絡(luò)模型,它代表了哪個(gè)協(xié)議所在哪一個(gè)網(wǎng)絡(luò)模型層的級(jí)別.

四 網(wǎng)絡(luò)適配器(網(wǎng)卡)原理:

1.什么是網(wǎng)絡(luò)適配器:

網(wǎng)絡(luò)適配器的意義在于協(xié)助計(jì)算機(jī)處理器來(lái)實(shí)現(xiàn)數(shù)據(jù)的傳輸.

下面是實(shí)物圖片,這個(gè)網(wǎng)絡(luò)適配器是臺(tái)式計(jì)算機(jī)使用的.



圖十五 網(wǎng)絡(luò)適配器實(shí)物圖
由于現(xiàn)代計(jì)算機(jī)發(fā)展迅速,導(dǎo)致網(wǎng)絡(luò)服務(wù)器數(shù)據(jù)傳輸速度有些時(shí)候并不能滿足日益增長(zhǎng)的需求.為此,雙端口網(wǎng)絡(luò)適配器誕生了,也即是說(shuō)同一個(gè)網(wǎng)絡(luò)適配器可以連接兩條網(wǎng)線.如果讀者想更深入了解請(qǐng)到:http://www.doc88.com/p-374664665354.html(HP CN1000E雙端口聚合網(wǎng)絡(luò)適配器 - 產(chǎn)品簡(jiǎn)介)



圖十六雙端口聚合網(wǎng)絡(luò)適配器
*網(wǎng)絡(luò)適配器的普通模式和混雜模式:

一般情況下,我們都使用網(wǎng)絡(luò)適配器的普通模式.所謂普通模式,其實(shí)是讓網(wǎng)絡(luò)適配器只接收發(fā)送到自己的數(shù)據(jù)包.但混雜模式卻與此相反,凡是網(wǎng)絡(luò)適配器接收到數(shù)據(jù)包就傳遞給處理器,無(wú)論這個(gè)數(shù)據(jù)包是不是發(fā)送該主機(jī)的.

*關(guān)于網(wǎng)絡(luò)適配器的混雜模式

由于數(shù)據(jù)的傳輸都是按照一定的標(biāo)準(zhǔn)的,那么只要有多臺(tái)主機(jī)在同一以太網(wǎng)下,其中一臺(tái)主機(jī)就可以利用混雜模式來(lái)獲取其它計(jì)算機(jī)發(fā)送/接收的數(shù)據(jù)包.(請(qǐng)回顧下:"圖八 總線型數(shù)據(jù)傳輸鏈路",在總線下傳輸?shù)臄?shù)據(jù)各個(gè)主機(jī)都可以接收到)所以這就是局域網(wǎng)下監(jiān)聽(tīng)其它計(jì)算機(jī)的原理.同樣地,我們也可以利用此原理去盜取用戶(hù)帳號(hào)和密碼等敏感信息.但在盜取成功之前還需要一個(gè)前提:數(shù)據(jù)的解密.

五 Windows 驅(qū)動(dòng)層:

1.WinSock 函數(shù)庫(kù):

WinSock 是Windows 自帶的與網(wǎng)絡(luò)交互的運(yùn)行庫(kù).在此,程序員們利用一些相關(guān)的接口就可以實(shí)現(xiàn)端口綁定,TCP 連接,關(guān)閉,發(fā)送,接收數(shù)據(jù)等功能.請(qǐng)注意,WinSock 只是網(wǎng)絡(luò)接口,更準(zhǔn)確地來(lái)講就是DLL 文件(Dynamic Link Library ,動(dòng)態(tài)鏈接庫(kù).它是用來(lái)儲(chǔ)存代碼或者資源數(shù)據(jù)的文件,詳情請(qǐng)看:http://baike.baidu.com/view/887.htm?fromId=4373動(dòng)態(tài)鏈接庫(kù) - 百度百科).所以WinSock 也只是通過(guò)調(diào)用驅(qū)動(dòng)程序(驅(qū)動(dòng)程序的用意是讓處理器控制外圍硬件)的方式來(lái)編寫(xiě)接口.接下來(lái),你將會(huì)看到從網(wǎng)絡(luò)適配器接收的數(shù)據(jù)需要經(jīng)過(guò)多少個(gè)驅(qū)動(dòng)才可以到達(dá)WinSock.DLL .

2.網(wǎng)絡(luò)適配器遞交數(shù)據(jù)需要經(jīng)過(guò)的驅(qū)動(dòng):

在看內(nèi)核網(wǎng)絡(luò)驅(qū)動(dòng)程序結(jié)構(gòu)之前,我們首先要知道:

1.WinSock.DLL 其實(shí)是在TDI(Transport Driver Interface ,傳輸驅(qū)動(dòng)程序接口.它的用意是把從上往下/從下往上 傳遞的驅(qū)動(dòng)程序I/O 請(qǐng)求數(shù)據(jù)結(jié)構(gòu)逐級(jí)搬運(yùn).在數(shù)據(jù)搬運(yùn)的過(guò)程中,中間驅(qū)動(dòng)程序可以對(duì)這些數(shù)據(jù)進(jìn)行過(guò)濾)層上的.

2.Protocol Driver ,協(xié)議驅(qū)動(dòng)程序.每個(gè)協(xié)議驅(qū)動(dòng)程序都代表著不同的網(wǎng)絡(luò)協(xié)議(編者注:Winpcap 和NDISUIO不是網(wǎng)絡(luò)協(xié)議驅(qū)動(dòng)程序.前者是Windows網(wǎng)絡(luò)底層抓包驅(qū)動(dòng)程序.后者是控制NDIS 驅(qū)動(dòng)程序I/O 的驅(qū)動(dòng)程序)

3.HAL 是硬件抽象層(詳細(xì)請(qǐng)見(jiàn):http://baike.baidu.com/view/1166796.htmHAL - 百度百科).當(dāng)驅(qū)動(dòng)程序的I/O 請(qǐng)求數(shù)據(jù)結(jié)構(gòu)傳輸?shù)酱藭r(shí),接下來(lái)就是處理器通過(guò)總線來(lái)控制外圍硬件.




圖十七 Windows 系統(tǒng)內(nèi)核網(wǎng)絡(luò)驅(qū)動(dòng)程序結(jié)構(gòu)
在普通程序調(diào)用WinSock.DLL 發(fā)送TCP 連接請(qǐng)求時(shí),WinSock.DLL 會(huì)自動(dòng)填寫(xiě)好該請(qǐng)求數(shù)據(jù)包的IP 及TCP 數(shù)據(jù)包頭部結(jié)構(gòu).然后向下層驅(qū)動(dòng)程序傳遞,直到TCP/IP 驅(qū)動(dòng)程序.TCP/IP 驅(qū)動(dòng)程序再轉(zhuǎn)發(fā)到NDIS(Network Driver Interface Specification ,網(wǎng)絡(luò)適配器驅(qū)動(dòng)程序),最后通過(guò)HAL 實(shí)現(xiàn)把TCP 連接請(qǐng)求數(shù)據(jù)包從處理器發(fā)送到網(wǎng)絡(luò)適配器.接下來(lái)網(wǎng)絡(luò)適配器會(huì)通過(guò)網(wǎng)線發(fā)送到以太網(wǎng).接收數(shù)據(jù)與此相反,略之.

六 在一次瀏覽www.baidu.com 中系統(tǒng)工作的過(guò)程

至此,相信讀者們已經(jīng)對(duì)于硬件間數(shù)據(jù)傳輸,網(wǎng)絡(luò)協(xié)議,Windows系統(tǒng)內(nèi)核網(wǎng)絡(luò)驅(qū)動(dòng)程序結(jié)構(gòu) 都有了一定的了解.那LCatro 就和大家分析下瀏覽百度首頁(yè)的過(guò)程吧.

假設(shè)我們剛剛把電腦啟動(dòng)完成,然后立即瀏覽百度首頁(yè).(這樣做的用意是提供一個(gè)DNS 緩存表為空的環(huán)境)

本文引用地址:http://2s4d.com/article/201612/324240.htm



圖十八 使用程序?yàn)g覽百度首頁(yè)


在我們輸入www.baidu.com (編者注:www.baidu.com 準(zhǔn)備地來(lái)說(shuō)是網(wǎng)站的域名) 使瀏覽器訪問(wèn)的時(shí)候,它會(huì)先把域名轉(zhuǎn)換到IP 地址(即:解析,用gethostbyname() 函數(shù)實(shí)現(xiàn)) .此時(shí)WinSock 會(huì)從本地的DNS (用于解析域名和IP 地址的協(xié)議)緩存表(在本機(jī)里面的一張專(zhuān)門(mén)存放域名和對(duì)應(yīng)的IP 地址的數(shù)據(jù)塊)中尋找www.baidu.com 的IP 地址.由于主機(jī)是剛剛啟動(dòng)的,所以DNS 緩存表還是一片空白.WinSock 從DNS 緩存表中找不到對(duì)應(yīng)的IP 地址,于是就向DNS 服務(wù)器發(fā)送查詢(xún)域名請(qǐng)求(即:DNS 指針查詢(xún)).DNS 服務(wù)器接收到該請(qǐng)求后會(huì)在本地查詢(xún)?cè)撚蛎?假如該DNS 服務(wù)器沒(méi)有該域名和對(duì)應(yīng)的IP 地址的話,那該DNS 服務(wù)器便會(huì)向比它更高級(jí)的DNS 服務(wù)器提交查詢(xún),一直到查詢(xún)結(jié)果得到為止.成功則返回查詢(xún)成功數(shù)據(jù)包,如果還是查詢(xún)不到的話DNS 服務(wù)器會(huì)返回查詢(xún)失敗數(shù)據(jù)包. [該過(guò)程為域名轉(zhuǎn)換到IP 過(guò)程,用專(zhuān)業(yè)的語(yǔ)言來(lái)說(shuō)就是:域名解析過(guò)程]

有了IP 地址,瀏覽器就向它發(fā)送TCP 連接請(qǐng)求,接下來(lái)就是三次握手過(guò)程.連接成功建立后,瀏覽器會(huì)向百度的服務(wù)器發(fā)送獲取http://www.baidu.com/index.html(編者注:www.baidu.com/index.html 的意思是百度首頁(yè)的index 索引網(wǎng)頁(yè)的.HTML 文件(網(wǎng)頁(yè)代碼文件))的源代碼.隨后,百度服務(wù)器返回索引網(wǎng)頁(yè)的源代碼,并且主動(dòng)關(guān)閉TCP 連接.最后瀏覽器便根據(jù)這里面的源代碼逐一顯示在程序的網(wǎng)頁(yè)瀏覽控件上.

思考題:請(qǐng)你聯(lián)系該文章所講述到的知識(shí)認(rèn)真地想一想系統(tǒng)是怎么樣去一步步實(shí)現(xiàn)的呢?



與主題無(wú)關(guān)的相關(guān)知識(shí):

*程序啟動(dòng)過(guò)程:

在我們雙擊程序時(shí),Explorer.exe 會(huì)調(diào)用CreateProcess()運(yùn)行該程序.CreateProcess() 立即讀取程序文件(即:.EXE 文件) 的PE (PreInstallationEnvironment,預(yù)安裝環(huán)境.這個(gè)是Windows 特有的程序結(jié)構(gòu),它的用意是告訴Windows 系統(tǒng)在運(yùn)行程序之前需要先做哪些東西.詳細(xì)請(qǐng)見(jiàn):http://baike.baidu.com/view/3326.htm?fromId=8358Windows PE 結(jié)構(gòu) - 百度百科) 結(jié)構(gòu),Windows 系統(tǒng)會(huì)根據(jù).EXE 的需求先做一些相關(guān)的工作,比如:程序需要加載到哪一個(gè)內(nèi)存位置?程序代碼的入口點(diǎn)在哪兒?系統(tǒng)加載完成后,就將這個(gè)程序從硬盤(pán)中把程序文件映射到內(nèi)存中 (內(nèi)存映射).接下來(lái)CreateProcess() 會(huì)給該程序分配堆棧,最后再創(chuàng)建線程來(lái)執(zhí)行該程序.假如我們運(yùn)行的是.INK 文件(即:快捷方式),Explorer.exe 會(huì)解析.INK 文件,從中獲取到目的程序的運(yùn)行路徑.

*VB 程序運(yùn)行細(xì)節(jié):

由于VB 程序在設(shè)計(jì)窗口界面的時(shí)候完全使開(kāi)發(fā)者避免怎么樣用代碼把控件一個(gè)個(gè)創(chuàng)建.讀者們可以聯(lián)系下Win32 窗口程序的開(kāi)發(fā).首先,在WinMain() (即:Win32 應(yīng)用程序入口點(diǎn)) 的時(shí)候程序就開(kāi)始注冊(cè)->創(chuàng)建窗口了.在創(chuàng)建窗口完成后(注意,此時(shí)窗口只是空白的!),Windows 系統(tǒng)會(huì)向該窗口發(fā)送WM_PRINT 消息通告窗口開(kāi)始畫(huà)控件.

Q:既然說(shuō)剛剛創(chuàng)建窗口的時(shí)候是空白的,那為什么我們沒(méi)有先看到空白的窗口再看到程序一步步在窗口上面畫(huà)控件呢?
A:因?yàn)樘幚砥鲌?zhí)行代碼的速度太快了,所以它在繪畫(huà)的過(guò)程中只使用了非常短的時(shí)間,以至于人類(lèi)的眼晴不能接收到這些圖像.

*內(nèi)核處理按鍵過(guò)程:

在我們輸入完成網(wǎng)址后按下鍵盤(pán)的Enter 鍵,鍵盤(pán)會(huì)主動(dòng)向處理器引發(fā)中斷事件.由于計(jì)算機(jī)系統(tǒng)中中斷種類(lèi)太多,而且對(duì)于不同的中斷有不同的處理方法,于是人們把各個(gè)不同的中斷處理程序的入口地址儲(chǔ)存在中斷程序入口表.這是鍵盤(pán)所引發(fā)的中斷,那處理器接收到這個(gè)中斷的時(shí)候立即跳出當(dāng)前正在運(yùn)行的程序,轉(zhuǎn)而去運(yùn)行鍵盤(pán)中斷程序,當(dāng)鍵盤(pán)中斷程序執(zhí)行結(jié)束后,處理會(huì)繼續(xù)執(zhí)行原先的暫停運(yùn)行的代碼.

這個(gè)被按下的按鍵在處理器里面是用ASCII 碼來(lái)保存的,并且它也會(huì)從最底層驅(qū)動(dòng)一直上傳到應(yīng)用程序.應(yīng)用程序是通過(guò)系統(tǒng)發(fā)來(lái)的WM_KEYDOWN 消息然后來(lái)獲取按下的鍵值的.


上一頁(yè) 1 2 3 下一頁(yè)

關(guān)鍵詞: 計(jì)算機(jī)間通信原

評(píng)論


技術(shù)專(zhuān)區(qū)

關(guān)閉