在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

總線和共享內存的區別

Linux愛好者 ? 來源:Linux愛好者 ? 作者:Linux愛好者 ? 2022-10-10 14:55 ? 次閱讀

題目是一句golang編程箴言,對它的理解可大可小。

1508e322-485a-11ed-a3b6-dac502259ad0.png

往小了說,golang建議使用channel來共享信息而不是使用共享內存,這是一種優雅的方式,避免了數據同步帶來的繁瑣和低效。

往大了說,本質上還是讓資源去調度請求,而不是讓請求去調度資源

有些時候,思維的轉變,問題的視角,會帶來意想不到的收獲

資源就那么多,所有請求有序使用資源的方式就是通信的方式,反過來,為每個請求虛擬出它獨占資源的假象,那就是共享的方式。兩種截然不同的方式,差異體現在仲裁成本,這個成本決定了它們承載并發的能力。

一個一個說。

電路交換 vs 分組交換

151775c2-485a-11ed-a3b6-dac502259ad0.png

電路交換試圖占有整條電路(其實是最后一公里),若不成功,必須等到成功。

分組交換將長信息分割成若干小數據包,小數據包統計復用鏈路。

批處理系統 vs 分時系統

批處理用戶一旦使用系統,則會獨占系統到任務完成,其它用戶等待。

分時系統將時間分片,多用戶被調度復用時間片。

CSMA/CD vs 交換式以太網

CSMA/CD主機試圖獨占總線發送數據包,若不成功便退避直到成功。

交換式以太網數據包在交換機有序排隊,復用buffer。

Apache vs Nginx

Apache為每一個請求生成一個task,該task一旦獲得CPU,其它task將等待。

Nginx采用異步模型,所有請求分時復用固定數量task的CPU時間。

共享內存 vs erlang/go channel

共享內存對寫寫以及讀寫是互斥,每次只允許一個操作,其它不得不等待,重試。

erlang/go channel將內容拆解為事務消息,依靠消息的有序傳遞共享信息。

...

我們來看上述兩兩比較的共性。

可將上述所有的二者抽象為爭搶模式和有序模式:

對于爭搶模式,本質上需要對沖突進行仲裁。

對于有序模式,本質上需要對并發進行調度。

所謂對沖突進行仲裁,意思就是發生沖突后怎么辦。無論是退避重試,還是等待,此期間均是什么都做不了,且仲裁本身需要昂貴的成本。

并發調度就會好太多,有序化便無沖突,也就沒有仲裁成本了,沒有了仲裁,也就無需重試,等待,便可以干別的了,處理完全異步化。

我們再來對比之前技術優劣:

電路交換 vs 分組交換

電路交換一旦占線,你需要自己不斷重試。

分組交換你只管發數據包,交換節點會自動調度這些數據包到達目的地后重組。

批處理系統 vs 分時系統

批處理系統一旦系統被占,你就要排隊等待或者待會兒再來。

分時系統你只需要下發任務,任務調度系統會讓所有用戶的任務分時復用時間片。

CSMA/CD vs 交換式以太網

CSMA/CD網卡需要不斷監聽沖突并重試。

交換式以太網卡只需要發包,交換機會排隊調度來不及轉發的數據包。

Apache vs Nginx

Apache線程/進程若沒被調度到CPU,就需要等待直到被調度切換至CPU。

Nginx只需將事件通知到,工作進程便會輪詢處理完所有請求。

共享內存 vs erlang/go channel

共享內存訪問需要加鎖,若持鎖失敗,要么忙等重試,要么待會兒再來。

erlang/go channel以消息傳遞通信,消息發出后就不用管了,除非它希望得到回饋,完全異步。

可見,這又是一個殊途同歸。同類的還有:

PCI vs PCIe,從總線到交換。

宏內核 vs 微內核,從共享數據結構到消息傳遞。

1541f784-485a-11ed-a3b6-dac502259ad0.jpg

Spin/RW Lock vs RCU Lock,從爭搶鎖到操作副本原子更新。

154e4eee-485a-11ed-a3b6-dac502259ad0.png

RCU原理

為什么沖突仲裁的爭搶模式無法承載大并發,因為過載的沖突仲裁開銷會將資源淹沒,若要承載大并發,必然要采用調度的方式。要理解這一要素,需要換一個視角。

我們看操作的是信息的本身,還是信息的副本

回到本文題目,“以通信方式共享內存”操作信息的副本, 而“以共享內存方式通信”則操作信息本身。

操作信息副本可以保證同時有且只有一個實體操作該副本,如果有兩個實體需要操作該副本,那就再復制一個副本,這就保證了無沖突,業務流是可控無阻塞的。

RCU可做到業務無阻塞并發,無論是spinlock還是rwlock,都做不到。spinlock/rwlock鎖臨界區,造成臨界區串行化,而RCU沒臨界區,它將本屬于臨界區的邏輯作為副本操作,擇機原子更新,這便可做到無阻塞并發。

操作副本是無阻塞并發的甘泉,如果把并發看作是時間擴展性,那么將信息共享到遠方則是空間擴展性,完成這件事的是網絡,目前它是TCP/IP網絡。TCP/IP網絡采用了“以通信方式共享內存”的方式,它無疑是正確的。

我不懂erlang,但大致知道它的意思,erlang沒有變量,只操作副本,它是通信網絡在編程語言上的映射,對于golang,大概也是如此,使用go channel可以像網絡收發一樣來處理信息。

我們看socket接口,它實屬用通信的方式共享內存的古老方式。

socket接口一開始是進程間通信機制,與之通信的進程可在本機,也可在遠處,可在世界任意地方。“以通信方式共享內存“,是最原始的編程模式,一直到現在依然正確。

共享內存是一種本地優化,僅有編程意義,卻沒有擴展性,無論是無阻塞并發的時間擴展性,還是將信息傳遞給遠方的空間擴展性。

共享內存是一種本地優化,優化的是指令操作延時,與其將信息封裝成消息并傳遞,不如直接操作信息本身,它編程更簡單,代碼指令更少,執行延時更低。但高并發并不care指令延時,高并發care同時執行的有效指令數,而spin,switch不屬于有效指令,故共享內存天生不與高并發配對。

此外,還是那個觀點,網絡編程場景,普遍毫秒級的單流通信延時,共享內存相比消息傳遞節省個微妙甚至納秒級的操作延時,并無太大意義。要怪就怪光速吧。

從云原生開始

云原生是面向微服務的架構,而消息傳遞是微服務交互的媒介,每個工人都接觸過關于消息隊列的概念,正是消息支撐了云原生微服務。

消息并不封裝狀態,消息本身無狀態,狀態通過消息之間的交互來體現。消息交互可自由組合,這是分布式的源泉,而云原生本身就是面向分布式的設計。

一個部署云原生應用的IDC機房就是縮小版的全球TCP/IP互聯網,無狀態的消息在分布式的微服務之間傳遞,狀態僅由微服務的交互定義和維護。

甚至一臺物理主機內部板卡也成了微型版的全球TCP/IP互聯網,無狀態的消息在分布式的模塊之間傳遞,狀態僅由模塊之間的交互定義和維護。

共享內存類似總線,大家擁有平等訪問權,但寫訪問時要獨占。我們可以從總線和消息交換的關系看共享內存的處境。

曾經,主機主板上很多總線,很多模塊都要先爭搶獲得總線控制權才能與CPU或別的模塊通信,但后來PCIe將總線改成了由Hub互聯的交換網絡,采用消息交換替換了總線仲裁。

以太網在此之前已經走過了同樣的軌跡。

近來年被工人們提倡的微內核思想,大致也是這么回事,將對共享數據結構的操作換成了消息傳遞。

為什么這些都和全球TCP/IP互聯網類比呢?因為TCP/IP的基礎就是異步的,無狀態的,分布式的,消息傳遞的分組交換網

156b04bc-485a-11ed-a3b6-dac502259ad0.png

總線簡單樸素,隨著系統規模的擴大,總線爭搶帶來的時間損耗指數級上升,人們發現總線無法支持高并發及無法物理擴展時,消息傳遞便替換了總線。大規模系統,消息操作帶來的額外延時是可以忽略不計的。

無論內部板卡,局域網,PCI,操作系統都是從局域范圍開始的,它們一開始從總線開始便不足為奇。然而互聯網一開始就是連接分布式廣域端的,一開始就不適合采用總線結構,這反過來說明總線在分布式場景的不適用。

我一向贊美TCP/IP端到端原則,正是它無狀態的IP細腰讓互聯網規模得以任意擴大而不引入額外開銷,而細腰也是無狀態消息交換的核心,只在發送端和接收端之間定義和維護狀態,而不是所有端一起維護共享總線或內存的狀態。

因此,消息傳遞也遵循端到端原則,可以自由擴展規模,總線和共享內存則相反。

以上從局域擴而大之的視角,我們看到了消息傳遞替換總線的趨勢。

反過來,從廣域向內縮,規模在漸小,傳輸延時在漸短,越來越不分布式,無狀態消息傳遞帶來的可擴展優勢越發無用武之地,其額外封裝帶來的額外延時逐漸承擔了端到端延時的大頭。

除去額外的消息封裝和傳輸操作,所有不多的實體直接操作信息所在的內存,最小化端到端延時便成了可觀的收益,因此,總線和共享內存便是微縮版系統的極致了。

總結

這就兩邊都說得通了,從小規模到大規模,總線和共享內存被消息傳遞替代,從大規模到小規模,總線和共享內存則是消息傳遞的優化

就像廣義相對論,牛頓力學,量子力學一樣,不同的規模尺度有不同的哲學。

審核編輯:彭靜
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 以太網
    +關注

    關注

    40

    文章

    5452

    瀏覽量

    172187
  • 內存
    +關注

    關注

    8

    文章

    3042

    瀏覽量

    74177
  • 總線
    +關注

    關注

    10

    文章

    2894

    瀏覽量

    88225

原文標題:深刻理解 | 以通信方式共享內存,不要以共享內存方式通信

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    內存共享原理解析

    內存共享是一種在多個進程之間共享數據的機制,它允許不同的進程直接訪問同一塊內存區域,從而實現數據的快速傳遞和通信。
    的頭像 發表于 02-19 15:11 ?1348次閱讀
    <b class='flag-5'>內存</b><b class='flag-5'>共享</b>原理解析

    關于共享內存的函數shmget()

    Linux進程間通信源碼剖析,共享內存(shmget函數詳解)標簽: linuxstruct數據結構存儲systemobject2010-12-22 23:18 8567人閱讀 評論(1
    發表于 09-24 15:47

    linux如何共享內存實驗

    更多技術文章地址:http://www.hqyj.com/news/emb211.htm?lcg-opendv  1.實驗目的  通過編寫共享內存實驗,進一步了解使用共享內存的具體步驟
    發表于 06-08 07:47

    linux中的共享內存是指什么?共享內存有哪些優缺點

    什么是進程?進程有哪幾種狀態?共享內存是指什么?共享內存有哪些優缺點?
    發表于 02-28 09:32

    理解并使用共享內存

    上一個專欄討論了執行模型和內核啟動執行配置如何影響寄存器數量以及本地多處理器資源(比如共享內存,share memo~)。現在我們繼續討論內存的性能以及共享
    發表于 09-25 16:30 ?33次下載

    基于共享內存多核數據結構研究

    不可預期的結果,因而我們面臨著嚴峻挑戰.針對基于共享內存多核時代數據結構的相關研究進行綜述.首先,對比了并發與并行的區別,歸納了基于演進條件(progress condition)的多核數據結構分類,對近年來學術界對各種類型并發
    發表于 01-15 11:34 ?0次下載

    共享內存IPC原理,Linux進程間如何共享內存

    共享內存是在內存中單獨開辟的一段內存空間,這段內存空間有自己特有的數據結構,包括訪問權限、大小和最近訪問的時間等。該數據結構定義如下
    的頭像 發表于 07-16 13:43 ?8656次閱讀
    <b class='flag-5'>共享</b><b class='flag-5'>內存</b>IPC原理,Linux進程間如何<b class='flag-5'>共享</b><b class='flag-5'>內存</b>?

    深入剖析Linux共享內存原理

    不同進程之間進行通信,需要讓不同進程共享相同的物理內存,Linux通過? 共享內存 ?來實現這個功能。下面先來介紹一下Linux系統的共享
    的頭像 發表于 10-30 09:52 ?2309次閱讀
    深入剖析Linux<b class='flag-5'>共享</b><b class='flag-5'>內存</b>原理

    通過使用CUDA GPU共享內存

    共享內存是編寫優化良好的 CUDA 代碼的一個強大功能。共享內存的訪問比全局內存訪問快得多,因為它位于芯片上。
    的頭像 發表于 04-11 10:03 ?7447次閱讀

    Linux系統的共享內存的使用

    但有時候為了讓不同進程之間進行通信,需要讓不同進程共享相同的物理內存,Linux通過 共享內存 來實現這個功能。下面先來介紹一下Linux系統的共享
    的頭像 發表于 11-14 11:55 ?1343次閱讀

    CUDA編程共享內存

    共享內存是使用__shared__內存空間說明符分配的。
    的頭像 發表于 05-19 15:32 ?1170次閱讀
    CUDA編程<b class='flag-5'>共享</b><b class='flag-5'>內存</b>

    Linux進程間如何實現共享內存通信

    在上面的例程中,我們首先使用ftok()函數生成一個key值作為共享內存的標識符。然后使用shmget()函數創建共享內存區域,shmaddr指向
    發表于 06-19 09:55 ?648次閱讀

    內存溢出與內存泄漏:定義、區別與解決方案

    內存溢出與內存泄漏:定義、區別與解決方案? 內存溢出和內存泄漏是計算機科學中常見的問題,在開發和調試過程中經常會遇到。本文將詳細介紹
    的頭像 發表于 12-19 14:10 ?2926次閱讀

    前端總線頻率與外頻的區別

    前端總線頻率與外頻是計算機系統中兩個重要的概念,它們之間存在明顯的區別。以下是對這兩個概念對比: 一、定義與功能 前端總線頻率 : 定義 :前端總線頻率是指在電子設備中用于傳輸數據的數
    的頭像 發表于 10-10 17:02 ?582次閱讀

    前端總線內存頻率怎么配

    前端總線(FSB)與內存頻率的配合是確保計算機系統穩定運行并發揮最佳性能的關鍵因素之一。以下是對前端總線內存頻率配合關系的介紹: 一、前端總線
    的頭像 發表于 10-12 09:10 ?334次閱讀
    主站蜘蛛池模板: 99久久99久久精品免费看子伦| 国产精品久久久久久久久免费hd| 永久免费的啪啪免费的网址| 欧美午夜寂寞影院安卓列表| 男人的午夜影院| 美女扒开尿口给男人捅| 国语对白一区二区三区| 中国毛茸茸bbxx| 五月婷婷综合激情网| 四虎最新免费观看网址| 日韩毛片免费视频| 毛片一区| 国产精品九九久久一区hh| 成人国产精品一级毛片视频| 在线天堂中文在线网| 天堂w| 免费簧片视频| 中国业余老太性视频| 诱人的老师bd高清日本在线观看 | 狠狠色影院| 亚洲第一视频在线播放| 色惰网站| aa国产| 午夜影视在线观看| 天天插天天干| 在线h网站| 国产三级观看久久| 天堂网www最新版在线资源| 青草视频在线观看国产| 九色视频播放| 一级特黄aaa大片免费看| 天堂最新版中文网| 成人在线黄色| 日本免费不卡视频一区二区三区| 亚洲成熟| 免费一级欧美片片线观看| 福利片欧美| 精品亚洲综合在线第一区| 67xxxxxx日本| 午夜美女写真福利写视频| 欧美18videosex性欧美69|