0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

深入理解Linux I/O系統(tǒng)

jf_BxU6dNQb ? 來(lái)源:CSDN ? 作者:CSDN ? 2022-10-27 12:55 ? 次閱讀
傳統(tǒng)的系統(tǒng)調(diào)用I/OLinux 系統(tǒng)中,傳統(tǒng)的訪問(wèn)方式是通過(guò) write() 和 read() 兩個(gè)系統(tǒng)調(diào)用實(shí)現(xiàn)的,通過(guò) read() 函數(shù)讀取文件到到緩存區(qū)中,然后通過(guò) write() 方法把緩存中的數(shù)據(jù)輸出到網(wǎng)絡(luò)端口
read(file_fd,tmp_buf,len);
write(socket_fd,tmp_buf,len);                             


下圖分別對(duì)應(yīng)傳統(tǒng) I/O 操作的數(shù)據(jù)讀寫(xiě)流程,整個(gè)過(guò)程涉及 2 次 CPU 拷貝、2 次 DMA 拷貝,總共 4 次拷貝,以及 4 次上下文切換。

  • CPU 拷貝:
    由 CPU 直接處理數(shù)據(jù)的傳送,數(shù)據(jù)拷貝時(shí)會(huì)一直占用 CPU 的資源;

  • DMA 拷貝:
    由 CPU 向DMA磁盤(pán)控制器下達(dá)指令,讓 DMA 控制器來(lái)處理數(shù)據(jù)的傳送,數(shù)據(jù)傳送完畢再把信息反饋給 CPU,從而減輕了 CPU 資源的占有率;
  • 上下文切換:
    當(dāng)用戶(hù)程序向內(nèi)核發(fā)起系統(tǒng)調(diào)用時(shí),CPU 將用戶(hù)進(jìn)程從用戶(hù)態(tài)切換到內(nèi)核態(tài);


當(dāng)系統(tǒng)調(diào)用返回時(shí),CPU 將用戶(hù)進(jìn)程從內(nèi)核態(tài)切換回用戶(hù)態(tài)。

讀操作 當(dāng)應(yīng)用程序執(zhí)行 read 系統(tǒng)調(diào)用讀取一塊數(shù)據(jù)的時(shí)候,如果這塊數(shù)據(jù)已經(jīng)存在于用戶(hù)進(jìn)程的頁(yè)內(nèi)存中,就直接從內(nèi)存中讀取數(shù)據(jù)。
如果數(shù)據(jù)不存在,則先將數(shù)據(jù)從磁盤(pán)加載數(shù)據(jù)到內(nèi)核空間的讀緩存(Read Buffer)中,再?gòu)淖x緩存拷貝到用戶(hù)進(jìn)程的頁(yè)內(nèi)存中。e5d7a25e-55b1-11ed-a3b6-dac502259ad0.png

read(file_fd,tmp_buf,len);                          


基于傳統(tǒng)的 I/O 讀取方式,read 系統(tǒng)調(diào)用會(huì)觸發(fā) 2 次上下文切換,1 次 DMA 拷貝和 1 次 CPU 拷貝。

發(fā)起數(shù)據(jù)讀取的流程如下:

  1. 用戶(hù)進(jìn)程通過(guò) read() 函數(shù)向 Kernel 發(fā)起 System Call,上下文從 user space 切換為 kernel space。

  2. CPU 利用 DMA 控制器將數(shù)據(jù)從主存或硬盤(pán)拷貝到 kernel space 的讀緩沖區(qū)(Read Buffer)。

  3. CPU 將讀緩沖區(qū)(Read Buffer)中的數(shù)據(jù)拷貝到 user space 的用戶(hù)緩沖區(qū)(User Buffer)。

  4. 上下文從 kernel space 切換回用戶(hù)態(tài)(User Space),read 調(diào)用執(zhí)行返回。

寫(xiě)操作 當(dāng)應(yīng)用程序準(zhǔn)備好數(shù)據(jù),執(zhí)行 write 系統(tǒng)調(diào)用發(fā)送網(wǎng)絡(luò)數(shù)據(jù)時(shí),先將數(shù)據(jù)從用戶(hù)空間的頁(yè)緩存拷貝到內(nèi)核空間的網(wǎng)絡(luò)緩沖區(qū)(Socket Buffer)中,然后再將寫(xiě)緩存中的數(shù)據(jù)拷貝到網(wǎng)卡設(shè)備完成數(shù)據(jù)發(fā)送。
write(socket_fd,tmp_buf,len);                       


基于傳統(tǒng)的 I/O 寫(xiě)入方式,write() 系統(tǒng)調(diào)用會(huì)觸發(fā) 2 次上下文切換,1 次 CPU 拷貝和 1 次 DMA 拷貝。

用戶(hù)程序發(fā)送網(wǎng)絡(luò)數(shù)據(jù)的流程如下:

  1. 用戶(hù)進(jìn)程通過(guò) write() 函數(shù)向 kernel 發(fā)起 System Call,上下文從 user space 切換為 kernel space。

  2. CPU 將用戶(hù)緩沖區(qū)(User Buffer)中的數(shù)據(jù)拷貝到 kernel space 的網(wǎng)絡(luò)緩沖區(qū)(Socket Buffer)。

  3. CPU 利用 DMA 控制器將數(shù)據(jù)從網(wǎng)絡(luò)緩沖區(qū)(Socket Buffer)拷貝到 NIC 進(jìn)行數(shù)據(jù)傳輸。

  4. 上下文從 kernel space 切換回 user space,write 系統(tǒng)調(diào)用執(zhí)行返回。

網(wǎng)絡(luò) I/O

e644df5e-55b1-11ed-a3b6-dac502259ad0.png

磁盤(pán) I/O

e65ce374-55b1-11ed-a3b6-dac502259ad0.png?

高性能優(yōu)化的 I/O1. 零拷貝技術(shù)。2. 多路復(fù)用技術(shù)。
3. 頁(yè)緩存(PageCache)技術(shù)。


其中,頁(yè)緩存(PageCache)是操作系統(tǒng)對(duì)文件的緩存,用來(lái)減少對(duì)磁盤(pán)的 I/O 操作,以頁(yè)為單位的,內(nèi)容就是磁盤(pán)上的物理塊,頁(yè)緩存能幫助程序?qū)ξ募M(jìn)行順序讀寫(xiě)的速度幾乎接近于內(nèi)存的讀寫(xiě)速度,主要原因就是由于 OS 使用 PageCache 機(jī)制對(duì)讀寫(xiě)訪問(wèn)操作進(jìn)行了性能優(yōu)化。

頁(yè)緩存讀取策略:當(dāng)進(jìn)程發(fā)起一個(gè)讀操作 (比如,進(jìn)程發(fā)起一個(gè) read() 系統(tǒng)調(diào)用),它首先會(huì)檢查需要的數(shù)據(jù)是否在頁(yè)緩存中:
  • 如果在,則放棄訪問(wèn)磁盤(pán),而直接從頁(yè)緩存中讀取。
  • 如果不在,則內(nèi)核調(diào)度塊 I/O 操作從磁盤(pán)去讀取數(shù)據(jù),并讀入緊隨其后的少數(shù)幾個(gè)頁(yè)面(不少于一個(gè)頁(yè)面,通常是三個(gè)頁(yè)面),然后將數(shù)據(jù)放入頁(yè)緩存中。
e681b5be-55b1-11ed-a3b6-dac502259ad0.png


頁(yè)緩存寫(xiě)策略:當(dāng)進(jìn)程發(fā)起 write 系統(tǒng)調(diào)用寫(xiě)數(shù)據(jù)到文件中,先寫(xiě)到頁(yè)緩存,然后方法返回。此時(shí)數(shù)據(jù)還沒(méi)有真正的保存到文件中去,Linux 僅僅將頁(yè)緩存中的這一頁(yè)數(shù)據(jù)標(biāo)記為 “臟”,并且被加入到臟頁(yè)鏈表中。

然后,由 flusher 回寫(xiě)線程周期性將臟頁(yè)鏈表中的頁(yè)寫(xiě)到磁盤(pán),讓磁盤(pán)中的數(shù)據(jù)和內(nèi)存中保持一致,最后清理“”標(biāo)識(shí)。在以下三種情況下,臟頁(yè)會(huì)被寫(xiě)回磁盤(pán):

  1. 空閑內(nèi)存低于一個(gè)特定閾值。

  2. 臟頁(yè)在內(nèi)存中駐留超過(guò)一個(gè)特定的閾值時(shí)。

  3. 當(dāng)用戶(hù)進(jìn)程調(diào)用 sync() 和 fsync() 系統(tǒng)調(diào)用時(shí)。

存儲(chǔ)設(shè)備的 I/O 棧

e694de82-55b1-11ed-a3b6-dac502259ad0.png


由圖可見(jiàn),從系統(tǒng)調(diào)用的接口再往下,Linux 下的 IO 棧致大致有三個(gè)層次:

用:
  1. 文件系統(tǒng)層,以 write 為例,內(nèi)核拷貝了 write 參數(shù)指定的用戶(hù)態(tài)數(shù)據(jù)到文件系統(tǒng) Cache 中,并適時(shí)向下層同步。

  2. 塊層,管理塊設(shè)備的 IO 隊(duì)列,對(duì) IO 請(qǐng)求進(jìn)行合并、排序(還記得操作系統(tǒng)課程學(xué)習(xí)過(guò)的 IO 調(diào)度算法嗎?)。

  3. 設(shè)備層,通過(guò) DMA 與內(nèi)存直接交互,完成數(shù)據(jù)和具體設(shè)備之間的交互。

結(jié)合這個(gè)圖,想想 Linux 系統(tǒng)編程里用到的 Buffered IO、mmap、Direct IO,這些機(jī)制怎么和 Linux I/O 棧聯(lián)系起來(lái)呢?上面的圖有點(diǎn)復(fù)雜,我畫(huà)一幅簡(jiǎn)圖,把這些機(jī)制所在的位置添加進(jìn)去:e7e9b9b0-55b1-11ed-a3b6-dac502259ad0.png

Linux IO系統(tǒng)


這下一目了然了吧?傳統(tǒng)的 Buffered IO 使用 read 讀取文件的過(guò)程什么樣的?

假設(shè)要去讀一個(gè)冷文件(Cache 中不存在),open 打開(kāi)文件內(nèi)核后建立了一系列的數(shù)據(jù)結(jié)構(gòu),接下來(lái)調(diào)用 read,到達(dá)文件系統(tǒng)這一層,發(fā)現(xiàn) Page Cache 中不存在該位置的磁盤(pán)映射,然后創(chuàng)建相應(yīng)的 Page Cache 并和相關(guān)的扇區(qū)關(guān)聯(lián)。

然后請(qǐng)求繼續(xù)到達(dá)塊設(shè)備層,在 IO 隊(duì)列里排隊(duì),接受一系列的調(diào)度后到達(dá)設(shè)備驅(qū)動(dòng)層,此時(shí)一般使用 DMA 方式讀取相應(yīng)的磁盤(pán)扇區(qū)到 Cache 中,然后 read 拷貝數(shù)據(jù)到用戶(hù)提供的用戶(hù)態(tài) buffer 中去(read 的參數(shù)指出的)。


整個(gè)過(guò)程有幾次拷貝?

從磁盤(pán)到 Page Cache 算第一次的話,從 Page Cache 到用戶(hù)態(tài) buffer 就是第二次了。

而 mmap 做了什么?

mmap 直接把 Page Cache 映射到了用戶(hù)態(tài)的地址空間里了,所以 mmap 的方式讀文件是沒(méi)有第二次拷貝過(guò)程的。


那 Direct IO 做了什么?

這個(gè)機(jī)制更狠,直接讓用戶(hù)態(tài)和塊 IO 層對(duì)接,直接放棄 Page Cache,從磁盤(pán)直接和用戶(hù)態(tài)拷貝數(shù)據(jù)。

好處是什么?

寫(xiě)操作直接映射進(jìn)程的buffer到磁盤(pán)扇區(qū),以 DMA 的方式傳輸數(shù)據(jù),減少了原本需要到 Page Cache 層的一次拷貝,提升了寫(xiě)的效率。

對(duì)于讀而言,第一次肯定也是快于傳統(tǒng)的方式的,但是之后的讀就不如傳統(tǒng)方式了(當(dāng)然也可以在用戶(hù)態(tài)自己做 Cache,有些商用數(shù)據(jù)庫(kù)就是這么做的)。


除了傳統(tǒng)的 Buffered IO 可以比較自由的用偏移+長(zhǎng)度的方式讀寫(xiě)文件之外,mmap 和 Direct IO 均有數(shù)據(jù)按頁(yè)對(duì)齊的要求,Direct IO 還限制讀寫(xiě)必須是底層存儲(chǔ)設(shè)備塊大小的整數(shù)倍(甚至 Linux 2.4 還要求是文件系統(tǒng)邏輯塊的整數(shù)倍)。

所以接口越來(lái)越底層,換來(lái)表面上的效率提升的背后,需要在應(yīng)用程序這一層做更多的事情。

所以想用好這些高級(jí)特性,除了深刻理解其背后的機(jī)制之外,也要在系統(tǒng)設(shè)計(jì)上下一番功夫。

I/O Bufferinge87fdfb2-55b1-11ed-a3b6-dac502259ad0.png

如圖,當(dāng)程序調(diào)用各類(lèi)文件操作函數(shù)后,用戶(hù)數(shù)據(jù)(User Data)到達(dá)磁盤(pán)(Disk)的流程如圖所示。

圖中描述了 Linux 下文件操作函數(shù)的層級(jí)關(guān)系和內(nèi)存緩存層的存在位置。中間的黑色實(shí)線是用戶(hù)態(tài)和內(nèi)核態(tài)的分界線。

從上往下分析這張圖:

1. 首先是 C 語(yǔ)言 stdio 庫(kù)定義的相關(guān)文件操作函數(shù),這些都是用戶(hù)態(tài)實(shí)現(xiàn)的跨平臺(tái)封裝函數(shù)。

stdio 中實(shí)現(xiàn)的文件操作函數(shù)有自己的 stdio buffer,這是在用戶(hù)態(tài)實(shí)現(xiàn)的緩存。此處使用緩存的原因很簡(jiǎn)單 — 系統(tǒng)調(diào)用總是昂貴的。如果用戶(hù)代碼以較小的 size 不斷的讀或?qū)懳募脑?,stdio 庫(kù)將多次的讀或者寫(xiě)操作通過(guò) buffer 進(jìn)行聚合是可以提高程序運(yùn)行效率的。stdio 庫(kù)同時(shí)也支持 fflush 函數(shù)來(lái)主動(dòng)的刷新 buffer,主動(dòng)的調(diào)用底層的系統(tǒng)調(diào)用立即更新 buffer 里的數(shù)據(jù)。特別地,setbuf 函數(shù)可以對(duì) stdio 庫(kù)的用戶(hù)態(tài) buffer 進(jìn)行設(shè)置,甚至取消 buffer 的使用。

2. 系統(tǒng)調(diào)用的 read/write 和真實(shí)的磁盤(pán)讀寫(xiě)之間也存在一層 buffer,這里用術(shù)語(yǔ) Kernel buffer cache 來(lái)指代這一層緩存。

在 Linux 下,文件的緩存習(xí)慣性的稱(chēng)之為 Page Cache,而更低一級(jí)的設(shè)備的緩存稱(chēng)之為 Buffer Cache。這兩個(gè)概念很容易混淆,這里簡(jiǎn)單的介紹下概念上的區(qū)別:Page Cache 用于緩存文件的內(nèi)容,和文件系統(tǒng)比較相關(guān)。文件的內(nèi)容需要映射到實(shí)際的物理磁盤(pán),這種映射關(guān)系由文件系統(tǒng)來(lái)完成;Buffer Cache 用于緩存存儲(chǔ)設(shè)備塊(比如磁盤(pán)扇區(qū))的數(shù)據(jù),而不關(guān)心是否有文件系統(tǒng)的存在(文件系統(tǒng)的元數(shù)據(jù)緩存在 Buffer Cache 中)。

審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10898

    瀏覽量

    212557
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11335

    瀏覽量

    210068

原文標(biāo)題:深入理解Linux I/O 系統(tǒng)

文章出處:【微信號(hào):混說(shuō)Linux,微信公眾號(hào):混說(shuō)Linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    深入探討Linux系統(tǒng)中的動(dòng)態(tài)鏈接庫(kù)機(jī)制

    異常或崩潰。為深入理解動(dòng)態(tài)鏈接機(jī)制及其工作原理,我重溫了《程序員的自我修養(yǎng)》,并通過(guò)實(shí)踐演示與反匯編分析,了解了動(dòng)態(tài)鏈接的過(guò)程。 本文將深入探討Linux系統(tǒng)中的動(dòng)態(tài)鏈接庫(kù)機(jī)制,這其中
    的頭像 發(fā)表于 12-18 10:06 ?171次閱讀
    <b class='flag-5'>深入</b>探討<b class='flag-5'>Linux</b><b class='flag-5'>系統(tǒng)</b>中的動(dòng)態(tài)鏈接庫(kù)機(jī)制

    深入理解C語(yǔ)言:循環(huán)語(yǔ)句的應(yīng)用與優(yōu)化技巧

    能讓你的代碼更加簡(jiǎn)潔明了,還能顯著提升程序執(zhí)行效率。本文將詳細(xì)介紹C語(yǔ)言中的三種常見(jiàn)循環(huán)結(jié)構(gòu)——while循環(huán)、for循環(huán)和do...while循環(huán),帶你深入理解
    的頭像 發(fā)表于 12-07 01:11 ?218次閱讀
    <b class='flag-5'>深入理解</b>C語(yǔ)言:循環(huán)語(yǔ)句的應(yīng)用與優(yōu)化技巧

    深入理解 Llama 3 的架構(gòu)設(shè)計(jì)

    在人工智能領(lǐng)域,對(duì)話系統(tǒng)的發(fā)展一直是研究的熱點(diǎn)之一。隨著技術(shù)的進(jìn)步,我們見(jiàn)證了從簡(jiǎn)單的基于規(guī)則的系統(tǒng)到復(fù)雜的基于機(jī)器學(xué)習(xí)的模型的轉(zhuǎn)變。Llama 3,作為一個(gè)假設(shè)的先進(jìn)對(duì)話系統(tǒng),其架構(gòu)設(shè)計(jì)融合了
    的頭像 發(fā)表于 10-27 14:41 ?606次閱讀

    直接I/O庫(kù)

    電子發(fā)燒友網(wǎng)站提供《直接I/O庫(kù).pdf》資料免費(fèi)下載
    發(fā)表于 10-14 10:55 ?0次下載
    直接<b class='flag-5'>I</b>/<b class='flag-5'>O</b>庫(kù)

    物聯(lián)網(wǎng)中常見(jiàn)的I/O擴(kuò)展電路設(shè)計(jì)方案_IIC I/O擴(kuò)展芯片

    物聯(lián)網(wǎng)系統(tǒng)中為什么要使用 IIC I/O擴(kuò)展芯片 ??在物聯(lián)網(wǎng)系統(tǒng)中使用IIC(也稱(chēng)為I2C)I
    的頭像 發(fā)表于 09-24 11:29 ?620次閱讀
    物聯(lián)網(wǎng)中常見(jiàn)的<b class='flag-5'>I</b>/<b class='flag-5'>O</b>擴(kuò)展電路設(shè)計(jì)方案_IIC <b class='flag-5'>I</b>/<b class='flag-5'>O</b>擴(kuò)展芯片

    深入理解FPD-link III ADAS解串器HUB產(chǎn)品

    電子發(fā)燒友網(wǎng)站提供《深入理解FPD-link III ADAS解串器HUB產(chǎn)品.pdf》資料免費(fèi)下載
    發(fā)表于 09-06 09:58 ?1次下載
    <b class='flag-5'>深入理解</b>FPD-link III ADAS解串器HUB產(chǎn)品

    PLC的I/O點(diǎn)數(shù)是什么意思

    在工業(yè)自動(dòng)化領(lǐng)域中,可編程邏輯控制器(PLC)扮演著至關(guān)重要的角色。PLC以其高可靠性、易編程性和強(qiáng)大的控制功能,廣泛應(yīng)用于各種自動(dòng)化系統(tǒng)中。而在PLC的性能參數(shù)中,I/O點(diǎn)數(shù)是一個(gè)不可忽視的重要指標(biāo)。本文將對(duì)PLC的
    的頭像 發(fā)表于 06-27 11:15 ?4876次閱讀

    深入理解Camera的整體五層架構(gòu)

    Linux為視頻采集設(shè)備制定了標(biāo)準(zhǔn)的V4L2接口,并在內(nèi)核中實(shí)現(xiàn)了其基礎(chǔ)框架V4L2 Core。用戶(hù)空間進(jìn)程可以通過(guò)V4L2接口調(diào)用相關(guān)設(shè)備功能,而不用考慮其實(shí)現(xiàn)細(xì)節(jié)。
    的頭像 發(fā)表于 04-25 14:41 ?1728次閱讀
    <b class='flag-5'>深入理解</b>Camera的整體五層架構(gòu)

    深入理解FFmpeg閱讀體驗(yàn)》FFmpeg攝像頭測(cè)試

    FFmpeg錄制視頻使用如下cmd: ffmpeg -f video4linux2 -s 320x240 -i /dev/video8 /tmp/cam_video.avi 看看CPU占用率。 將視頻拷貝出來(lái),因?yàn)殇浿频臅r(shí)候分辨率沒(méi)設(shè)置很高,所以將就看看,能看出是啥電
    發(fā)表于 04-17 19:06

    深入理解FFmpeg閱讀體驗(yàn)》

    : ./configure --host=aarch64-linux --prefix=/home/x264 --enable-shared --disable-asm --enable-static
    發(fā)表于 04-16 22:54

    深入理解 Sora 的技術(shù)原理

    將去除噪音后的結(jié)果數(shù)據(jù),利用視頻解碼器進(jìn)行解碼,將低維潛在空間數(shù)據(jù)還原成原始視頻數(shù)據(jù),這里可以實(shí)現(xiàn)不同分辨率的視頻解碼。
    的頭像 發(fā)表于 04-05 09:19 ?1990次閱讀
    <b class='flag-5'>深入理解</b> Sora 的技術(shù)原理

    深入理解 FPGA 的基礎(chǔ)結(jié)構(gòu)

    轉(zhuǎn)載地址:https://zhuanlan.zhihu.com/p/506828648 文章很詳細(xì)的介紹了FPGA的基礎(chǔ)結(jié)構(gòu),能更直觀的理解內(nèi)部結(jié)構(gòu)原理。對(duì)深入學(xué)習(xí)很有幫助。 以下是正文: 這一段
    發(fā)表于 04-03 17:39

    深入理解Linux網(wǎng)絡(luò)協(xié)議

    網(wǎng)絡(luò)分層解決了網(wǎng)絡(luò)復(fù)雜的問(wèn)題,在網(wǎng)絡(luò)中傳輸數(shù)據(jù)中,我們對(duì)不同設(shè)備之間的傳輸數(shù)據(jù)的格式,需要定義一個(gè)數(shù)據(jù)標(biāo)準(zhǔn),所以就有了網(wǎng)絡(luò)協(xié)議。
    發(fā)表于 04-01 14:20 ?394次閱讀
    <b class='flag-5'>深入理解</b><b class='flag-5'>Linux</b>網(wǎng)絡(luò)協(xié)議

    FANUC外部I/O點(diǎn)數(shù)不夠用了怎么辦?可以擴(kuò)展I/O點(diǎn)數(shù)嗎?

    FANUC外部I/O點(diǎn)數(shù)不夠用了怎么辦?可以擴(kuò)展I/O點(diǎn)數(shù)嗎? 擴(kuò)展FANUC的外部I/O點(diǎn)數(shù)是
    的頭像 發(fā)表于 02-18 15:21 ?2048次閱讀

    恒訊科技帶大家深入理解:WebSocket服務(wù)器的工作原理

    WebSocket是一種在單個(gè)TCP連接上進(jìn)行全雙工通信的通信協(xié)議。它的設(shè)計(jì)目標(biāo)是在Web瀏覽器和服務(wù)器之間提供低延遲、高效的雙向通信。下面是深入理解WebSocket服務(wù)器工作原理的一些關(guān)鍵概念
    的頭像 發(fā)表于 01-29 16:48 ?504次閱讀