Fixing the world 修復(fù)代碼的世界——ZeroMQ的哲學(xué)

譯注:ZeroMQ是一個在2009年末發(fā)布的網(wǎng)絡(luò)編程通信庫。經(jīng)過多年的發(fā)展莺掠,如今的它是一個集套接字通信衫嵌、消息隊列、異步編程的網(wǎng)絡(luò)開發(fā)框架彻秆。

在其官方文檔的第一章楔绞,有這樣一段引人啟發(fā)的的一節(jié)《Fixing the world (Pieter Hintjens)》,這也是筆者在進(jìn)入技術(shù)行業(yè)以來受影響最深的一段文字唇兑。在文中酒朵,作者指出了一種思想,一切代碼都是互相連接的扎附,它們最終連接人類的大腦蔫耽,并提到一些網(wǎng)絡(luò)、異步等的編程難題留夜,都可以通過“連接”來更容易的解決匙铡。筆者經(jīng)過翻譯整理,帶大家感受ZeroMQ作者的構(gòu)想香伴。

在多年以后今天慰枕、邁入人工智能時代的今天,理解作者的這些思路即纲,能帶給我們對人工智能的未來全新的認(rèn)識具帮。


怎樣解釋ZeroMQ是什么?我們可能會說出所有它能展現(xiàn)的美好功能:它就像打了雞血的Socket套接字低斋、就像會路由分發(fā)郵箱蜂厅,它的性能卓越!一些人可能嘗試分享他們愉悅的使用感受:編程變得更簡單了膊畴,復(fù)雜性消失了掘猿,它打開了我們的心靈。一些人會嘗試跟以往作比較:它更小唇跨,更簡單了稠通,但是,又有點(diǎn)似曾相識买猖。就我個人而言改橘,我也希望解釋起我們最初為什么要開發(fā)ZeroMQ,因?yàn)橛窨兀@是身為讀者的你也很想知道的問題飞主。

編程是一門偽裝成藝術(shù)的科學(xué),因?yàn)槲覀冎械拇蠖鄶?shù)壓根不明白軟件的本質(zhì);即使學(xué)過這方面的知識的話碌识,也學(xué)的很少碾篡。
軟件的本質(zhì),不是算法筏餐、數(shù)據(jù)結(jié)構(gòu)开泽、編程語言和抽象形態(tài)。這些只是我們制造的工具胖烛,我們用完就忽略掉的工具眼姐。軟件的真實(shí)本質(zhì)诅迷,其實(shí)就是人類的本質(zhì)——具體來說就是佩番,當(dāng)事情變的復(fù)雜的時候,一個人的能力有限罢杉,我們會通過協(xié)作趟畏,來把大的問題分成小的問題來處理。這才是編程科學(xué):人們將制作好的一塊塊的容易理解滩租、使用的小構(gòu)件赋秀,把它們砌在一起來解決大問題。

我們身處一個互聯(lián)的世界律想,現(xiàn)代軟件必須要暢游這個世界猎莲。因此為未來設(shè)計的的這些超大型軟件里的小構(gòu)件,都是互相連接并且是大規(guī)模并行的技即≈荩“健壯、沉默”的代碼是遠(yuǎn)遠(yuǎn)不夠的而叼。代碼之間必須要會交流身笤。代碼之間必須是善于交際的。代碼的運(yùn)行必須像人類的腦袋一樣葵陵,數(shù)以萬億計的神經(jīng)元互相傳遞消息液荸,一個大規(guī)模并行的去中心化的網(wǎng)絡(luò),沒有單點(diǎn)故障脱篙,還能解決重大困難問題娇钱。毫無疑問,未來的代碼就像人腦一樣绊困,一定程度來說文搂,網(wǎng)絡(luò)發(fā)展的最終連接點(diǎn),就是連接人們的大腦考抄。

如果你做過線程细疚,協(xié)議或者網(wǎng)絡(luò)相關(guān)的工作,你會意識到要做好它們是相當(dāng)不容易的一件事情。即使通過很少的Socket(套接字)去連接少量的程序疯兼,你也要在日常生活工作中面對各種令人厭煩的問題然遏。想連接更多的,數(shù)以億計的程序吧彪? 這個成本根本令人不敢想象——那是一個遙不可及的夢想待侵。連接計算機(jī)是如此的困難,這造就了軟件服務(wù)業(yè)這樣一個數(shù)以幾十億美元的產(chǎn)業(yè)姨裸。

目前我們所在的世界里秧倾,網(wǎng)絡(luò)布線能力比我們能夠使用它的能力更加超前。而在20世紀(jì)80年代傀缩,我們遇到一個軟件危機(jī)那先,F(xiàn)red Brooks等卓越的軟件工程師認(rèn)為再沒有“銀彈”可以讓“任何一項技術(shù)或方法可使軟件工程的生產(chǎn)力在十年內(nèi)提高十倍∩募瑁”

譯注:所謂的沒有銀彈是指沒有任何一項技術(shù)或方法可使軟件工程的生產(chǎn)力在十年內(nèi)提高十倍售淡。

Brooks錯過了免費(fèi)和開源軟件時代,它們解決了這場危機(jī)慷垮,使我們能更加有效的分享知識揖闸。今天我們面臨著另一個軟件危機(jī),一個我們還沒有討論廣泛的問題料身。只有最大最富有的公司才有能力去創(chuàng)建互相連接的應(yīng)用程序汤纸。盡管有云計算的出現(xiàn),但是它是企業(yè)專有的芹血。我們的數(shù)據(jù)贮泞、我們的知識正在從我們的個人電腦里消失,并轉(zhuǎn)移到我們無法訪問和與之抗衡的計算云中祟牲。誰擁有我們的社交網(wǎng)絡(luò)隙畜?這就像大型計算機(jī)革命的反轉(zhuǎn)劇情。

譯注:當(dāng)年計算機(jī)革命说贝,追求個人更大的空間更好的性能议惰,在云計算時代,劇情完全反過來了乡恕,空間言询、性能和越來越多的軟件服務(wù)的已經(jīng)轉(zhuǎn)移到了云上,個人電腦被弱化

這些政治哲學(xué)的東西我們就留給其它書來討論吧傲宜。關(guān)鍵的一點(diǎn)运杭,雖然互聯(lián)網(wǎng)為大規(guī)模代碼連接提供可能性,但現(xiàn)實(shí)是要實(shí)現(xiàn)它函卒,對我們多數(shù)人來說還是遙不可及的辆憔。大量引人關(guān)注的問題(在健康,教育,經(jīng)濟(jì)虱咧,交通等領(lǐng)域)依然沒有解決熊榛,因?yàn)闆]有辦法把代碼連接起來,因?yàn)闆]有辦法連接所有的這些大腦使其可以協(xié)同工作來解決這些問題腕巡。

人們做過很多的嘗試去解決代碼連接連接的問題玄坦。制定過的上千的IETF規(guī)范,每一個都在嘗試解決部分難題绘沉。(譯注:IEFT煎楣,互聯(lián)網(wǎng)工程任務(wù)組,是全球互聯(lián)網(wǎng)最具權(quán)威的技術(shù)標(biāo)準(zhǔn)化組織)對于應(yīng)用開發(fā)者而言车伞,HTTP可能是一個足夠簡單的工作解決方案择懂,但是它也可能使問題更糟糕——因?yàn)樗膭铋_發(fā)者和架構(gòu)師們以超大型服務(wù)器和瘦小愚蠢的客戶端的角度來考慮問題。

所以今天人們?nèi)匀皇褂肬DP帖世、TCP休蟹、專有定制協(xié)議沸枯、HTTP和Websockets來連接應(yīng)用程序日矫。這是痛苦的、低效的绑榴、難以擴(kuò)展的哪轿,并且是中央化的。分布式P2P架構(gòu)主要用于娛樂翔怎,而不是工作窃诉。你有見過應(yīng)用程序使用Skype(P2P 語音通訊軟件)和Bittorrent(P2P下載軟件)來交換數(shù)據(jù)的嗎?

這讓我們重新回歸編程科學(xué)赤套。為了修復(fù)這個世界飘痛,我們需要做兩件事硕旗。一阴绢,解決“怎樣讓任何代碼在任何地方互相連接”這種普遍性問題季率。二颈嚼,封裝盡可能最簡單的構(gòu)件來讓人們理解和簡單的使用立砸。

這聽起來簡單得荒謬为朋,但也許其實(shí)就是這么的簡單积仗。

譯注:ZeroMQ目前是一個應(yīng)用廣泛的網(wǎng)絡(luò)編程庫擅编,常見的應(yīng)用場景用于多個服務(wù)器谈跛、多個進(jìn)程節(jié)點(diǎn)之間的網(wǎng)絡(luò)通信羊苟,也就是作者所倡導(dǎo)的“互相連接的代碼”的應(yīng)用。此外感憾,官方更強(qiáng)調(diào)其是一個可取代多線程異步編程的異步編程框架蜡励。


查看原文:Fixing the World

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子凉倚,更是在濱河造成了極大的恐慌彭则,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件占遥,死亡現(xiàn)場離奇詭異俯抖,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)瓦胎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門芬萍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人搔啊,你說我怎么就攤上這事柬祠。” “怎么了负芋?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵漫蛔,是天一觀的道長。 經(jīng)常有香客問我旧蛾,道長莽龟,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任锨天,我火速辦了婚禮毯盈,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘病袄。我一直安慰自己搂赋,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布益缠。 她就那樣靜靜地躺著脑奠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪幅慌。 梳的紋絲不亂的頭發(fā)上宋欺,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天,我揣著相機(jī)與錄音欠痴,去河邊找鬼迄靠。 笑死,一個胖子當(dāng)著我的面吹牛喇辽,可吹牛的內(nèi)容都是我干的掌挚。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼菩咨,長吁一口氣:“原來是場噩夢啊……” “哼吠式!你這毒婦竟也來了陡厘?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤特占,失蹤者是張志新(化名)和其女友劉穎糙置,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體是目,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡谤饭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了懊纳。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片揉抵。...
    茶點(diǎn)故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖嗤疯,靈堂內(nèi)的尸體忽然破棺而出冤今,到底是詐尸還是另有隱情,我是刑警寧澤茂缚,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布戏罢,位于F島的核電站,受9級特大地震影響脚囊,放射性物質(zhì)發(fā)生泄漏龟糕。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一凑术、第九天 我趴在偏房一處隱蔽的房頂上張望翩蘸。 院中可真熱鬧,春花似錦淮逊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至秧耗,卻和暖如春备籽,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背分井。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工车猬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人尺锚。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓珠闰,卻偏偏與公主長得像,于是被迫代替她去往敵國和親瘫辩。 傳聞我的和親對象是個殘疾皇子伏嗜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,742評論 25 707
  • 拯救世界 略 開始的假設(shè) 我們假設(shè)你使用ZeroMQ 3.2以上的版本坛悉。我們假設(shè)你使用Linux或者類似的操作系統(tǒng)...
    lakerszhy閱讀 11,252評論 1 14
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)承绸,斷路器裸影,智...
    卡卡羅2017閱讀 134,628評論 18 139
  • 至6年前的小夏: 昨天晚上看到劉慈欣寫給女兒的書信,并設(shè)定女兒在200多年后才能看到這封信军熏,他的信里保持著科幻作家...
    如月的溫柔閱讀 225評論 0 1
  • 前面的話 e=e||event;if(e.preventDefault){ e.preventDefault();...
    有誰能比我知道閱讀 252評論 0 0