精品国产亚洲一区二区三区|亚洲国产精彩中文乱码AV|久久久久亚洲AV综合波多野结衣|漂亮少妇各种调教玩弄在线

<blockquote id="ixlwe"><option id="ixlwe"></option></blockquote>
  • <span id="ixlwe"></span>

  • <abbr id="ixlwe"></abbr>

    環(huán)信CTO:互聯(lián)網(wǎng)高并發(fā)技術(shù)方案選型思考和實(shí)踐

    環(huán)信CTO:互聯(lián)網(wǎng)高并發(fā)技術(shù)方案選型思考和實(shí)踐

    本文試圖通過(guò)漸進(jìn)的技術(shù)分析,和大家分享我們?cè)诨ヂ?lián)網(wǎng)高并發(fā)技術(shù)方案選擇上的一些思考和決策;從技術(shù)選型的高度為架構(gòu)師在面對(duì)高并發(fā)業(yè)務(wù)設(shè)計(jì)時(shí)需要考慮的方方面面做一個(gè)參考。

    Beautiful Concurrency & Pretty Erlang

    前言

    環(huán)信以“連接人與人,連接人與商業(yè)”為使命,旨在為廣大企業(yè)開(kāi)發(fā)者提供最優(yōu)質(zhì)的全球即時(shí)通訊PaaS服務(wù)。如何實(shí)現(xiàn)高并發(fā)場(chǎng)景下,彈性化的保障服務(wù)質(zhì)量是我們一貫的業(yè)務(wù)要求和技術(shù)追求。

    本文試圖通過(guò)漸進(jìn)的技術(shù)分析,和大家分享我們?cè)诨ヂ?lián)網(wǎng)高并發(fā)技術(shù)方案選擇上的一些思考和決策;從技術(shù)選型的高度為架構(gòu)師在面對(duì)高并發(fā)業(yè)務(wù)設(shè)計(jì)時(shí)需要考慮的方方面面做一個(gè)參考。

    接下來(lái),enjoy:

    Beautiful Concurrency – 并發(fā)的必要性

    世界是并發(fā)的,軟件也應(yīng)該是并發(fā)的

    我們生活在其中的世界,就是一個(gè)巨大的并發(fā)系統(tǒng)。每時(shí)每刻,在世界的每一個(gè)角落,人類(lèi)的每一個(gè)個(gè)體都在和這個(gè)世界進(jìn)行著頻繁的能量交互,信息交互也是其中的重要組成部分;當(dāng)我們轉(zhuǎn)換身份,以造物主的視角俯瞰這個(gè)世界里所有的萬(wàn)物(動(dòng)物,植物,海洋,土壤,機(jī)器等等)時(shí),也可以看到它們同樣在和這個(gè)世界進(jìn)行著無(wú)休止的能量/信息交互。

    為了與這個(gè)世界進(jìn)行有效的交互,軟件也應(yīng)該是并發(fā)的。

    世界是分布的,軟件也應(yīng)該是分布的

    地球是圓的,世界是平的,不管怎樣,從宇宙大爆炸的那個(gè)奇點(diǎn)之后,就是分布的宇宙/世界。作為與世界萬(wàn)物(包括人類(lèi)自己)交互的軟件,自然也必須滿(mǎn)足分布式要求。而這種地理分布(Geo. Distribution)特性,也僅是并發(fā)在空間維度下的反映而已。

    世界不可預(yù)測(cè),軟件也應(yīng)該是容錯(cuò)的

    沒(méi)有完美的世界:沖突,災(zāi)難隨時(shí)在發(fā)生,不管在什么樣的維度上。作為軟件,bug,crash也是不可規(guī)避的現(xiàn)實(shí)挑戰(zhàn)。即使存在完美的沒(méi)有bug的程序,運(yùn)行程序的硬件也可能出現(xiàn)故障。為了增強(qiáng)軟件的容錯(cuò)性,代碼的獨(dú)立性(指一個(gè)故障不會(huì)影響到故障任務(wù)以外的其它任務(wù))和故障檢測(cè)以及故障處理是關(guān)鍵:這一切都需要并發(fā),因?yàn)榇谐绦虻娜蒎e(cuò)性遠(yuǎn)遠(yuǎn)不如并發(fā)程序。

    并發(fā)方案概覽

    “七個(gè)模型”來(lái)源于Paul Butcher著的《Seven Concurrency Models in Seven Weeks》,中文譯名《七周七并發(fā)模型》,概覽的介紹了并發(fā)領(lǐng)域的常見(jiàn)方案,希望能給架構(gòu)師提供一個(gè)輪廓化的分類(lèi)描述。本人在其基礎(chǔ)上添加了一些自己的拓展思考(見(jiàn)下文中斜體部分):

    1.線程與鎖:線程與鎖模型有很多眾所周知的不足,但仍是其他模型的技術(shù)基礎(chǔ),也是很多并發(fā)軟件開(kāi)發(fā)的首選。—這個(gè)方案其實(shí)是一個(gè)anti-pattern,在高并發(fā)場(chǎng)景下如履薄冰(bug,dead lock如影隨形),讓開(kāi)發(fā)者和運(yùn)維人員膽戰(zhàn)心驚。Ugly Locks to Ugly Concurrency (丑陋的鎖,丑陋的并發(fā)):locks and condition variables is fundamentally flawed!

    2.函數(shù)式編程:函數(shù)式編程日漸重要的原因之一,是其對(duì)并發(fā)編程和并行編程提供了良好的支持。函數(shù)式編程消除了可變狀態(tài),所以從根本上是線程安全的,而且易于并行執(zhí)行。— 函數(shù)之美,邏輯之美!相信很多從命令式語(yǔ)言(Imperative Programming)轉(zhuǎn)戰(zhàn)到函數(shù)式編程語(yǔ)言(Functional Programminmg)的時(shí)候都會(huì)發(fā)出這樣的感嘆。其實(shí)這一進(jìn)步恰恰體現(xiàn)了人類(lèi)在不斷的進(jìn)化過(guò)程中,對(duì)這個(gè)世界認(rèn)知不斷提煉,思維模式逐步由具象走向抽象的演進(jìn)軌跡。而回到高并發(fā)的話(huà)題上,函數(shù)式編程以不可變狀態(tài)這一簡(jiǎn)易的策略,贏得了完美贊譽(yù),儼然已是君臨天下的明日霸主!

    3.分離標(biāo)識(shí)與狀態(tài):如果一個(gè)線程引用了持久數(shù)據(jù)結(jié)構(gòu),那么其他線程對(duì)數(shù)據(jù)結(jié)構(gòu)的修改對(duì)該線程就是不可見(jiàn)的。因此持久數(shù)據(jù)結(jié)構(gòu)對(duì)并發(fā)編程的意義非比尋 常,其分離了標(biāo)識(shí)(identity)與狀態(tài)(state)。— 這又是一個(gè)很妙的策略,而大家熟知的version control system如git,包括比特幣/區(qū)塊鏈的機(jī)制都是這一思想指導(dǎo)下的具體實(shí)踐,限于篇幅,本文不做進(jìn)一步展開(kāi)。

    4.Actor Model:一種適用性很廣的并發(fā)編程模型,適用于共享內(nèi)存模型和分布式內(nèi)存模型,也適合解決地理分布型問(wèn)題,能提供強(qiáng)大的容錯(cuò)性。— 最開(kāi)始接觸到Actor模型就是通過(guò)Erlang語(yǔ)言,后來(lái)又接觸到Akka(基于Scala)等基于各種語(yǔ)言實(shí)現(xiàn)的框架,也越來(lái)越體會(huì)到這一模型在高并發(fā)場(chǎng)景下的游刃有余。本文后續(xù)部分會(huì)展開(kāi)介紹。另外,做個(gè)招聘小廣告,環(huán)信通訊云研發(fā)團(tuán)隊(duì)正在廣納英才,歡迎懂Erlang,有相關(guān)高并發(fā)開(kāi)發(fā)經(jīng)驗(yàn)的小伙伴加盟,虛位以待!點(diǎn)這里直接聯(lián)系我們喲!

    5.CSP(Communicating Sequential Processes, CSP):表面上看,CSP模型與Actor Model很相似,兩者都基于消息傳遞。不過(guò)CSP模型側(cè)重于傳遞信息的通道,而Actor Model側(cè)重于通道兩端的實(shí)體,使用CSP模型的代碼會(huì)帶有明顯不同的風(fēng)格。— 這里就是channel可以大施拳腳的天地了,go go go!限于篇幅,本文不做進(jìn)一步展開(kāi)。同樣的,歡迎懂Golang,有相關(guān)高并發(fā)開(kāi)發(fā)經(jīng)驗(yàn)的小伙伴加盟,虛位以待!

    6.數(shù)據(jù)級(jí)并行:每個(gè)筆記本電腦里都藏著一臺(tái)超級(jí)計(jì)算機(jī)——GPU。GPU利用了數(shù)據(jù)級(jí)并行,不僅可以快速進(jìn)行圖像處理,也可以用于更 廣闊的領(lǐng)域。如果要進(jìn)行有限元分析、流體力學(xué)計(jì)算或其他的大量數(shù)字計(jì)算,GPU的性能將是不二選擇。— 在過(guò)去的兩年里,華人之光,黃仁勛(Jensen Huang, CEO of Nvidia),從自家的壁爐里一次又一次給大家?guī)?lái)了震撼世界的革新產(chǎn)品,讓之前高不可攀的GPU飛入尋常百姓家,也帶來(lái)了一次又一次的算力之爭(zhēng)。相信在不久的將來(lái),有了GPU算力加持和人工智能算法的普惠使用,會(huì)有無(wú)數(shù)的AI應(yīng)用層出不窮的涌現(xiàn),它們會(huì)從云端落地到邊緣,人類(lèi)可能會(huì)比自己想象的更早的進(jìn)入前途未卜的人機(jī)爭(zhēng)霸時(shí)代。

    7.Lambda架構(gòu):Lambda架構(gòu)綜合了MapReduce和流式處理的特點(diǎn),是一種可以處理多種大數(shù)據(jù)問(wèn)題的架構(gòu)。— Lambda架構(gòu)也是采用了數(shù)據(jù)并行處理技術(shù),但是它把并行算力的微觀場(chǎng)景放大到了一個(gè)更大的尺度:將數(shù)據(jù)和計(jì)算分布到成千上萬(wàn)臺(tái)機(jī)器組成的集群上進(jìn)行,將并發(fā),分布特性整合到一套方案中,通過(guò)兩層(批處理層-Batch Layer,加速層-Speed Layer/Streaming Process)的組合,實(shí)現(xiàn)了高計(jì)算效率和低延遲的“魚(yú)與熊掌兼得”。

    Pretty Erlang

    環(huán)信的全球即時(shí)通訊云的核心網(wǎng)絡(luò)是基于Erlang/OTP開(kāi)發(fā)的,截止目前共服務(wù)了幾十萬(wàn)APP客戶(hù),單集群日消息幾十億量級(jí)并還在不斷挑戰(zhàn)新高。多年的經(jīng)驗(yàn)積累,我們?nèi)栽诓粩嗟膶?duì)系統(tǒng)進(jìn)行優(yōu)化,榨取計(jì)算,網(wǎng)絡(luò)等資源的內(nèi)生價(jià)值,挑戰(zhàn)系統(tǒng)一個(gè)又一個(gè)不斷提升的指標(biāo)要求。感謝Erlang/OTP,有了它,我們像站在了巨人肩膀上的一名揮舞利刃的勇士,能夠從容應(yīng)對(duì)各種“黑云壓城城欲摧”的業(yè)務(wù)壓力和不斷變化,五花八門(mén)的業(yè)務(wù)需求。以下,我們簡(jiǎn)單總結(jié)了Erlang/OTP幾點(diǎn)讓我們“迷醉的特質(zhì)”,給想入坑的小伙伴以參考:

    Let it Crash!

    再一次,讓我們理解了“思維高度決定人生高度”。當(dāng)其它語(yǔ)言或者解決方案防御性的,想方設(shè)法捕獲異常/錯(cuò)誤并盡力挽回“敗局”的時(shí)候,Erlang采納了”Let it crash!”的策略,把重點(diǎn)放在了錯(cuò)誤的檢測(cè)和錯(cuò)誤通知體系上,通過(guò)嚴(yán)謹(jǐn)設(shè)計(jì)的單向,雙向link機(jī)制,OTP基于此設(shè)計(jì)的supervisor behaviour層級(jí)(Hierarchical)管理匯報(bào)機(jī)制,”任其崩潰“的同時(shí)又干凈漂亮的將所有Actor(進(jìn)程)在發(fā)生異常時(shí)的行為進(jìn)行了簡(jiǎn)單但有效的管理,獲得了意想不到的好處:

    代碼簡(jiǎn)潔易懂,僅在需要關(guān)心崩潰處理的層級(jí)存在容錯(cuò)代碼;

    由于Actor Model的設(shè)計(jì),Actor之間相互獨(dú)立,也不共享狀態(tài),因此任何一個(gè)Actor的崩潰并不會(huì)影響其它Actor,遑論它的管理者(Supervisor),因此管理者可以從容的處理被管理Actor的崩潰;

    管理者也可以不處理崩潰,僅記錄相應(yīng)崩潰,繼而通過(guò)查看崩潰通知來(lái)進(jìn)行后續(xù)處理。這個(gè)策略在后續(xù)Pattern Matching時(shí)候還會(huì)見(jiàn)到,我們可以在_Other(所有匹配均未觸發(fā))保護(hù)匹配中記錄相應(yīng)信息,而不必為事先預(yù)估不到的場(chǎng)景絞盡腦汁!

    Actor Model

    Actor Model是Pure OO的設(shè)計(jì)(而Java類(lèi)與方法的設(shè)計(jì)并不是,意不意外?):每一個(gè)Actor封裝了狀態(tài),外界并沒(méi)有任何方法來(lái)操縱(manipulate)對(duì)象,它們唯有通過(guò)發(fā)送消息通知Actor,由Actor自己控制對(duì)消息的處理,這種簡(jiǎn)化同樣為高并發(fā)處理提供了意料之外的強(qiáng)大支持。

    Actor Model適用于共享內(nèi)存模型和分布式內(nèi)存模型,也適合解決地理分布型問(wèn)題,能提供強(qiáng)大的容錯(cuò)性,用了都說(shuō)好!

    我個(gè)人在曾經(jīng)的工作中做過(guò)一個(gè)網(wǎng)絡(luò)安全過(guò)濾的產(chǎn)品,是靠自己團(tuán)隊(duì)設(shè)計(jì)編寫(xiě)的一套消息隊(duì)列處理機(jī)制來(lái)解耦不同業(yè)務(wù)對(duì)相同數(shù)據(jù)的處理,后來(lái)回想起來(lái)才驀然發(fā)現(xiàn)其實(shí)這就是個(gè)簡(jiǎn)陋的Actor Model設(shè)計(jì),只是那個(gè)時(shí)候還不知道Erlang/OTP,要是早用上這把利器,能節(jié)省我生命中多少個(gè)日日夜夜啊!

    Functional Programming

    介紹函數(shù)式編程的書(shū)籍,資料已經(jīng)很多了,本文不做過(guò)多的展開(kāi)。簡(jiǎn)單列舉下個(gè)人的幾點(diǎn)體會(huì):

    程序最終還是要交給機(jī)器處理,因此要盡量按照機(jī)器的思維模式去編寫(xiě)程序(雖然有時(shí)候會(huì)讓程序員頭大),最簡(jiǎn)單的 (a + b) 與 (+ a b):前者對(duì)人類(lèi)友好,而后者對(duì)機(jī)器友好,因而也能帶來(lái)更好的程序一致性,繼而使得系統(tǒng)可以設(shè)計(jì)的更簡(jiǎn)單;

    命令式編程的代碼由一系列改變?nèi)譅顟B(tài)的語(yǔ)句構(gòu)成,而函數(shù)式編程則是將計(jì)算過(guò)程抽象成表達(dá)式求值。這些表達(dá)式由純數(shù)學(xué)函數(shù)構(gòu)成,而這些數(shù)學(xué)函數(shù)是第一類(lèi)對(duì)象(我們可以像操作數(shù)值一樣操作第一類(lèi)對(duì)象)并且沒(méi)有副作用。由于沒(méi)有副作用,函數(shù)式編程可以更容易做到線程安全,因此特別適合于并發(fā)/并行編程。

    函數(shù)之美帶來(lái)美之并發(fā)!原文摘抄:

    For me, a beautiful program is one that is so simple and elegant that itobviously has no mistakes,rather than merely having no obvious mistakes. If we want to write parallel programs that work reliably, we must pay particular attention to beauty.

    Pattern Matching

    又一個(gè)讓你被美折服的設(shè)計(jì):函數(shù)在這種Pattern Matching的語(yǔ)法結(jié)構(gòu)的描摹下,儼然變成了一道道證明題,你只需要描述(并不需要窮舉)你所關(guān)心的場(chǎng)景(Conditon)下自己的想法,剩下的就交給”模式匹配“這個(gè)自動(dòng)化機(jī)器幫你完成。你可能想不到的是,”Pattern Matching“發(fā)揮功效的地方并不只是case/if出現(xiàn)的地方,你的整個(gè)代碼都是在”Pattern Matching“的魔力下散發(fā)它優(yōu)雅的魅力。

    Future Evolution

    對(duì)高并發(fā)的不懈追求將一直是環(huán)信通訊云研發(fā)團(tuán)隊(duì)的目標(biāo),我們也期待在這條崎嶇山路上不斷攀登,厚積薄發(fā),為環(huán)信的客戶(hù)帶來(lái)一貫的極致產(chǎn)品體驗(yàn)!

    (免責(zé)聲明:本網(wǎng)站內(nèi)容主要來(lái)自原創(chuàng)、合作伙伴供稿和第三方自媒體作者投稿,凡在本網(wǎng)站出現(xiàn)的信息,均僅供參考。本網(wǎng)站將盡力確保所提供信息的準(zhǔn)確性及可靠性,但不保證有關(guān)資料的準(zhǔn)確性及可靠性,讀者在使用前請(qǐng)進(jìn)一步核實(shí),并對(duì)任何自主決定的行為負(fù)責(zé)。本網(wǎng)站對(duì)有關(guān)資料所引致的錯(cuò)誤、不確或遺漏,概不負(fù)任何法律責(zé)任。
    任何單位或個(gè)人認(rèn)為本網(wǎng)站中的網(wǎng)頁(yè)或鏈接內(nèi)容可能涉嫌侵犯其知識(shí)產(chǎn)權(quán)或存在不實(shí)內(nèi)容時(shí),應(yīng)及時(shí)向本網(wǎng)站提出書(shū)面權(quán)利通知或不實(shí)情況說(shuō)明,并提供身份證明、權(quán)屬證明及詳細(xì)侵權(quán)或不實(shí)情況證明。本網(wǎng)站在收到上述法律文件后,將會(huì)依法盡快聯(lián)系相關(guān)文章源頭核實(shí),溝通刪除相關(guān)內(nèi)容或斷開(kāi)相關(guān)鏈接。 )