不知道大家有沒有注意最近的 LineDevDay(下方影片) ? 該影片中介紹 Line 是如何使用 ArgoCD 作為 GitOps 的解決方案,並且從中獲得了哪些好處。 Line 作為台灣一個非常知名的軟體公司,想必這樣的使用經驗也能夠給大家帶來一點 GitOps 的信心加持
因此今天這篇文章就來跟大家介紹 GitOps 的範例文章,該文章使用 CircleCI + ArgoCD 來搭建一個
GitOps 的操作流程,文章也介紹了 Repo 本身的管理,到底應用程式的原始碼與相關的設定檔案(Yaml) 要放一起還是要分開? 實際是這個問題的答案沒有絕對,不同情境都會有不同的用法,甚至還有所謂的 umbrella chart 這種概念來管理多個 Helm Chart。
有興趣的我建議先看看 Line 的介紹,接者再看看別人如何實作。當然如果對於 GitOps 不熟悉的話,也歡迎看看我部落格內全部的 GitOps 相關文章
Reference:
1. https://linedevday.linecorp.com/2020/en/sessions/9156
2. https://www.hwchiu.com/tags/GitOps/
https://medium.com/dev-genius/kubernetes-ci-cd-with-circleci-and-argocd-6473b0acdc1a
同時也有1部Youtube影片,追蹤數超過11萬的網紅部長,也在其Youtube影片中提到,全新電影直播節目即將開播 每週五的晚間 20:00 - 21:30 將與太空小姐一起主持!想要節目有哪些內容呢? 影片中介紹的遊戲為 PS4『ONE PIECE 海賊無雙4』來這邊看看~ https://store.playstation.com/zh-hant-tw/product/HP0700...
中介軟體有哪些 在 台灣物聯網實驗室 IOT Labs Facebook 的最佳解答
5G來臨 帶動AIoT需求起飛 企業轉型正式啟動
【作者: 籃貫銘、王岫晨】 2020年04月01日 星期三
5G的商轉,將會帶動AIoT的需求。
2020年起,將會有更多國家加入5G商轉,
預計將帶動不同終端裝置對AIoT應用的需求。
在AIoT的應用中,大規模的連接性能是必備的需求,而5G的落實,恰可完全填補這個空缺,也因此市場對於5G的布建與商轉,充滿了高度期待。
依據工研院IEK Consulting的報告,全球整體5G市場規模,將從2019年的43億美元,成長至2023年的2,303億美元,年複合成長率(CAGR)高達171%,顯見其發展潛力。
工研院產科國際所所長蘇孟宗也特別指出,5G的商轉,將會帶動AIoT的需求。他認為,自2020年起將會有更多國家加入5G商轉,預計將創造新的物聯網應用,同時也有機會帶動不同終端裝置對AIoT應用的需求,例如車用、穿載、智慧家電、工業自動化、AI軟體等,朝高附加價值和新產品應用布局。
5G時代 垂直應用是AIoT的主要場域
且有別於過往3G與4G以消費性為主的應用,到了5G時代,重心則轉往工業領域的垂直應用,而在諸多應用之中,「製造、醫療、能源」將會是最主要的市場,而這也是AIoT架構的最主要應用場域。
在5G三大技術特色「高頻寬」、「低延遲」與「大連結」之中,低延遲和大連結是對工業領域影響最大的兩項。前者對於實現智慧城市、智慧製造與智慧運輸有極大的幫助;後者則是建構物聯網的關鍵技術。
由於垂直領域的智慧應用非常重視通訊信號的即時性與穩定性,才能充分發揮各項控制功能的性能,特別是在工業與運輸的應用裡,訊號的即時性更對於安全性有著關鍵的影響,也因此,5G的低延遲特性就成為實踐AIoT應用不可或缺的技術之一。
以車聯網V2X為例,大量的媒體資訊和數據傳輸是其基本的運作需求,但因交通涉及使用者的生命安全,因此控制訊號的即時性也十分的敏感,對於低延遲又有更高等級的要求。
而在工業控制領域也同樣如此,製造現場經常存在危及生命安全或者造成龐大資產損失的風險,因此對於自動化控制的等級要求十分的高,幾乎不容許有訊號丟失或者過多延遲的狀況,所以在導入AIoT應用時,落實低延遲的性能也成為業者關注的項目。
至於5G的大連結技術,則完美的實現了物聯網時代對於大範圍低功耗連結的想像,也就是帶來所謂的低功耗廣域無線網路(LPWAN),而目前市場上常見的NB-IoT規範,正是5G的前段工程,意味著5G的到來將是物聯網廣域傳輸的實現。
也因此,基於上述這些需求,5G的問世,就等同於把智慧應用的引擎完全打開,它一方面承接了AIoT相關技術的推動,一方面也讓智慧生活的想像得以落實。稱它為連接次世代生活的橋梁也不為過。
而5G的來臨,受惠的不只是終端與工業應用,相關的產業鏈,諸如元件、材料與設備都會迎來新一波的成長。台灣的資策會MIC就指出,隨著全球5G的逐步發展,相關的終端、材料與零組件都會有新的商業契機。
資策會MIC表示,5G將會帶來四大商機。首先,為大量5G模組/終端產品出現;第二,則是2020年開始的5G智慧手機換機潮;第三,為5G元件與設備的材料。由於高頻與能耗需求,將會促進新的材料的研發,包含:氮化鎵、碳化矽、PCB的PPE混合樹脂等。第四,為5G新應用帶動關鍵零組件市場,例如自駕車的光達(Lidar)、毫米波雷達、光學攝影機等。
5G帶動的數位轉型
數位轉型的時代已經來臨。特別是隨著5G通訊的起飛,更牽動著企業數位轉型的每一根神經。企業追求更快速度的同時,數位化的程度也必須更加全面。只不過,在轉型的過程往往遇到許多讓客戶難以掌握的狀況。事實上,數位轉型並非就只單純將資料數位化而已,最核心的問題,還是在於企業整體的數位發展策略與方向。因此,當企業在考量數位轉型的時候,必須仔細思考下列幾個關鍵問題。
一、產品與服務:讓產品與服務在數位轉型的過程中,產生更多綜效。
二、供應鏈管理:透過數位化的管理,讓供應鏈提升效率。
三、生產面優化:找出能夠讓生產更優化的模式。
四、客戶關係提升:與客戶之間的關係,透過數位轉型做得更加全面。
五、讓資料更有價值:數位轉型的過程中,讓手上的數據資料有機會轉變成為商機。根據客戶的經營型態,找出更有價值的資料,並讓這些資料可以帶來新的機會。
六、組織文化改造:透過數位轉型,讓企業組織文化與互動模式可以重新調整。
Juniper台灣區總經理林蒲英指出,找出這些方向之後,下一個問題就是數位轉型該怎麼進行。最重要的是先確定出可行的商業模式,另外也必須重新定義中介角色,調整企業的組織,讓企業的解決方案能夠透過合作夥伴,推廣給更多客戶。此外,提供更加值的服務、並建置可行的服務方式,就能夠在這個中介角色的扮演上,透過數位轉型來進行得更順利、更透明,也更有效率。
X as a service
X as a service亦即一切即服務。從其產品的平台到其架構,都可以作為是服務的提供。X as a service最好的例證就是智慧手機,智慧手機已經可以將其視為一個平台,所有日常的娛樂、通訊、學習與支付,都可以透過這個平台來進行,完全改變了既有的產業生態。X as a service指越來越多地透過物聯網來提供的服務,而不僅僅指本地端或現場的服務。雲端運算的本質,正是X as a service。
而現在,透過數位轉型的契機,也將有機會重新改變產業生態。透過中介角色來進行連結,可以將合作夥伴與不同領域客戶進一步結合,讓合作夥伴的解決方案可以擴大應用範圍,也能將客戶的數據資訊的價值更為彰顯。
幫客戶開出快又安全的路
林蒲英認為,隨著5G的來臨,企業更應該要明白數位轉型到底要做什麼,以及應該怎麼做。企業必須找到他在市場上的位置,想走的方向,再將既有資源透過數位化的方式提高效率,並與客戶保持更密切的關係,改變產業營運模式,甚至進一步調整公司內部的文化。對於Juniper來說,我們的工作就是開路。但客戶的路,會有鄉村小路,會有高速公路。因此要先理解路從哪裡來,要到哪裡去,再幫客戶蓋出一條又快又安全的道路。
在過去,講到數位化,好像只要有主機、有電腦,就是數位化了。但是現階段企業的數位化,除了必須提高效率之外,還面對了更多的挑戰,因為市場競爭正在快速改變。我們端看X as a service這件事情,其實已經把傳統手機產業完全都顛覆了。而這也就是透過數位轉型,改變整個產業競爭模式的最好案例,我們可以發現服務模式改變了、供應鏈模式改變了、客戶互動模式也改變了。
因此,數位轉型固然重要,但企業仍要清楚其核心價值,以及要走的方向。而方法,則是最為重要的一環。企業必須清楚在數位轉型當中,哪些價值可以透過數位化,重新定義上中下游、重新定義客戶關係、重新定義公司內部組織,然後產生更多綜效。
結語
在未來的5G環境中,龐大的數據資料必須隨時與外界進行互動。因此,資料必須具備開放性、整合性、以及安全性。因為要與外界的應用整合,一定要夠開放,而介面也必須要能與外界互連互動。而網路層的開放性,也與介接直接相關。畢竟現有的通訊架構一直在快速演變,例如5G的來臨,當應用環境改變的時候,必須要能夠快速應變,去介接不同的環境,不能有所限制。介接必須要從終端的角度去思考,包括所有面向,例如從終端到雲端、從公有雲到私有雲,這些不同端點之間的介接,多樣性與開放性都必須要具備。更必須兼顧其安全性。
[技術線上] X as a service
雲服務正在取得爆炸式的增長,以「-aaS」為尾碼的雲服務正在以令人目眩的速度成長,這種服務稱為XaaS,是對所有與雲相關的服務的概括。XaaS用來描述任何能讓人想起可重覆使用的、無縫的軟體公司服務,這些軟體公司分佈在一個虛擬化的雲網路中。XaaS最常見的例子就是軟體即服務、基礎設施即服務和平台即服務。
以下列出的僅是雲服務領域中的一部分:
●存儲即服務(storage as a service)
●安全即服務(SECaaS)
●資料庫即服務(DaaS)
●監控/管理即服務(MaaS)
●通信、內容和計算即服務(CaaS)
●身份即服務(IDaaS)
●備份即服務(BaaS)
●桌面即服務(DaaS)
附圖:圖一 : 在5G三大技術特色「高頻寬」、「低延遲」與「大連結」之中,低延遲和大連結是對工業領域影響最大的兩項。
圖二 : 5G產業鏈發展與機會
資料來源:http://www.ctimes.com.tw/DispArt/tw/5G/AIoT/%E4%BC%81%E6%A5%AD%E8%BD%89%E5%9E%8B/2004011037QG.shtml
中介軟體有哪些 在 Taipei Ethereum Meetup Facebook 的最佳貼文
📜 [專欄新文章] 隱私、區塊鏈與洋蔥路由
✍️ Juin Chiu
📥 歡迎投稿: https://medium.com/taipei-ethereum-meetup #徵技術分享文 #使用心得 #教學文 #medium
隱私為何重要?區塊鏈是匿名的嗎?洋蔥路由如何改進區塊鏈?
前言
自2008年區塊鏈以比特幣的面貌問世後,它便被視為 Web 3.0,並被期許能夠進一步為人類帶來金融與治理上的大躍進。區塊鏈或許會成為如同全球資訊網一般的基礎建設,如果我們已經開始注重個人於網路上的隱私,那麼我們更應該關心這項全新的技術是否能更好地保護它。
筆者將於本文中闡述隱私的重要性,接著進一步分析區塊鏈是否能夠保護用戶隱私,最後再簡介一個知名的匿名技術 — 洋蔥路由,並列舉幾個其用於改進區塊鏈(特別是以太坊)的相關提案。
特別感謝以太坊研究員 Chih-Cheng Liang 與民間高手敖烏協助校閱並給予回饋。
隱私的重要
網際網路(Internet)無疑是 20 世紀末最偉大的發明,它催生了全新的商業模式,也使得資訊能以位元的形式進行光速傳播,更使人類得以進行前所未有的大規模協作。而自從 1990 年全球資訊網(World Wide Web)的問世以來,網路已和現代文明生活密不可分。經過近 30 年的發展,人類在網路上製造了巨量的資料,這些資料會揭露使用者的隱私。透過一個人的資料,企業或者政府能夠比你自己更了解你。這促使用戶對隱私的愈發重視 — 正如同你不會允許第三者監聽你的電話,你也不希望有第三者監看你的瀏覽器搜尋歷史。
然而,如今的網路是徹底的中心化,中心化也意謂著過大的權力,有種種跡象顯示:網路正在成為政府當局監控人民的工具。例如:中國的淨網衛士[1]、美國的稜鏡計劃[2]等。那麼,政府應該監控人民嗎?其中一派的人認為平日不做虧心事,半夜不怕鬼敲門,這也就是常見的無所隱瞞論[3]:
我不在乎隱私權,因為我沒什麼好隱瞞的。
不過持有這類論點的人通常會被下面的說法反駁:
既然沒什麼好隱瞞的,那請把你的 Email 帳號密碼給我,讓我揭露其中我認為有趣的部分。
大多數正常人應該都不會接受這個提議。
隱私應當與言論自由一樣,是公民的基本權利。事實上,隱私是一個既廣且深的題目,它涉及了心理學、社會學、倫理學、人類學、資訊科學、密碼學等領域,這裡[4]有更多關於關於隱私的討論以及網路隱私工具的整理。
隱私與區塊鏈
有了網際網路後,接下來人類或許可以透過區塊鏈來建構出一個免除人性且完全仰賴自然法則(數學)運行的去中心化系統。在中心化世界中,我們需要免於政府監控的隱私;在去中心化世界中,我們仍然需要隱私以享有真正的平等。
正如同本文的前言所述:區塊鏈也許會成為如同全球資訊網一般的基礎建設,如果我們已經開始注重網路隱私,那麼我們更應該關心區塊鏈是否能更好地保護它。
隱私與匿名
Privacy vs Anonymity [5]
當我們論及隱私時,我們通常是指廣義的隱私:別人不知道你是誰,也不知道你在做什麼。事實上,隱私包含兩個概念:狹義的隱私(Privacy)與匿名(Anonymity)。狹義的隱私就是:別人知道你是誰,但不知道你在做什麼;匿名則是:別人知道你在做什麼,但不知道你是誰。
隱私與匿名對於隱私權來說都很重要,也可以透過不同的方法達成,接下來本文將聚焦於匿名的討論。另外,筆者在接下來的文章中所提及的隱私,指的皆是狹義的隱私。
網路的匿名
以當今的網路架構(TCP/IP 協定組)來說,匿名就是請求端(Requester)向響應端(Responder)請求資源時藏匿其本身的 IP 位址 — 響應端知道請求端在做什麼(索取的資源),但不知道是誰(IP 位置)在做。
IP 位置會揭露個人資訊。在台灣,只需透過 TWNIC 資料庫就可向台灣的網路服務供應商(Internet Service Provider, ISP),例如中華電信,取得某 IP 的註冊者身份及姓名/電話/地址之類的個資。
ISP 是網路基礎建設的部署者與營運者,理論上它能知道關於你在使用網路的所有資訊,只是這些資訊被法律保護起來,並透過公權力保證:政府只在必要時能夠取得這些資訊。萬一政府本身就是資訊的監控者呢?因此,我們需要有在 ISP 能窺知一切的情形下仍能維持匿名的方法。
區塊鏈能保護隱私、維持匿名嗎?
區塊鏈除了其本身運作的上層應用協定之外,還包含了下層網路協定。因此,這個問題可以分為應用層與網路層兩個部分來看 。
應用層
應用層負責實作狀態機複製(State Machine Replication),每個節點收到由共識背書的交易後,便可將交易內容作為轉換函數(Transition Function)於本機執行狀態轉換(State Transition)。
區塊鏈上的交易內容與狀態是應當被保護的隱私,一個保護隱私的直覺是:將所有的交易(Transaction)與狀態(State)加密。然而實際上,幾乎目前所有的主流區塊鏈,包含以太坊,其鏈上的交易及狀態皆為未加密的明文,用戶不僅可以查詢任一地址的交易歷史,還能知道任一地址呼叫某智能合約的次數與參數。也就是說,當今主流區塊鏈並未保護隱私。
雖然區塊鏈上的交易使用假名(Pseudonym),即地址(Address),但由於所有交易及狀態皆為明文,因此任何人都可以對所有假名進行分析並建構出用戶輪廓(User Profile)。更有研究[6]指出有些方法可以解析出假名與 IP 的映射關係(詳見下個段落),一旦 IP 與假名產生關聯,則用戶的每個行為都如同攤在陽光下一般赤裸。
區塊鏈的隱私問題很早便引起研究員的重視,因此目前已有諸多提供隱私保護的區塊鏈被提出,例如運用零知識證明(Zero-knowledge Proof)的 Zcash、運用環簽章(Ring Signature)的 Monero、 運用同態加密(Homomorphic Encryption)的 MimbleWimble 等等。區塊鏈隱私是一個大量涉及密碼學的艱澀主題,本文礙於篇幅不再深入探討,想深入鑽研的讀者不妨造訪台北以太坊社群專欄,其中有若干優質文章討論此一主題。
網路層
節點於應用層產生的共識訊息或交易訊息需透過網路層廣播(Broadcast)到其他節點。由於當今的主流區塊鏈節點皆未採取使網路維持匿名的技術,例如代理(Proxy)、虛擬私人網路(Virtual Private Network, VPN)或下文即將介紹的洋蔥路由(Onion Routing),因此區塊鏈無法使用戶維持匿名 — 因為對收到訊息的節點來說,它既知道廣播節點在做什麼(收到的訊息),也知道廣播節點是誰(訊息的 IP 位置)。
一個常見的問題是:使用假名難道不是匿名嗎?若能找到該假名與特定 IP 的映射關係的話就不是。一般來說,要找到與某假名對應的 IP 相當困難,幾可說是大海撈針,但是至少在下列兩種情況下可以找到對應關係:1. 該假名的用戶自願揭露真實 IP,例如在社群網站公開以太坊地址;2. 區塊鏈網路遭受去匿名化攻擊(Deanonymization Attack)[6]。
洩漏假名與 IP 的關聯會有什麼問題? 除了該 IP 的真實身份可能被揭露外,該區塊鏈節點亦可能遭受流量分析(Traffic Analysis)、服務阻斷(Denial of Service)或者審查(Censorship),可以說是有百害而無一利。
區塊鏈如何維持匿名?
其實上文已給出了能讓區塊鏈維持匿名的線索:現有匿名技術的應用。我們先來進一步理解區塊鏈網路層與深入探討網際網路協定的運作原理。
區塊鏈網路層的運作原理
P2P Overlay Network [7]
區塊鏈是一個對等網路(Peer-to-peer, P2P),而對等網路是一種覆蓋網路(Overlay Network),需建構於實體網路(Physical Network)之上。
覆蓋網路有兩種常見的通訊模式:一種是基於中繼的(Relay-based)通訊,在此通訊模式下的訊息皆有明確的接收端,因而節點會將不屬於自己的訊息中繼(Relay)給下一個可能是接收端的節點,分散式雜湊表(Distributed Hash Table, DHT)就是一種基於中繼的對等網路;另一種是基於廣播的(Broadcast-based)通訊,在此通訊模式下的訊息會被廣播給所有節點,節點會接收所有訊息,並且再度廣播至其他節點,直到網路中所有節點都收到該訊息,區塊鏈網路層就是一種基於廣播的對等網路。
覆蓋網路旨在將實體網路的通訊模式抽象化並於其上組成另一個拓墣(Topology)與路由機制(Routing Mechanism)。然而實際上,實體網路的通訊仍需遵循 TCP/IP 協定組的規範。那麼,實體網路又是如何運作的呢?
網際網路的運作原理
OSI Model vs TCP/IP Model
實體網路即是網際網路,它的發明可以追朔至 Robert Kahn 和 Vinton Cerf 於1974 年共同發表的原型[12],該原型經過數年的迭代後演變成我們當今使用的 TCP/IP 協定組[8]。全球資訊網(WWW)的發明更進一步驅使各國的 ISP 建立基於 TCP/IP 協定組的網路基礎建設。網際網路在多個國家經過近 30 年的部署後逐漸發展成今日的規模,成為邏輯上全球最巨大的單一網路。
1984 年,國際標準化組織(ISO)也發表了 OSI 概念模型[9],雖然較 TCP/IP 協定組晚了 10 年,但是 OSI 模型為日後可能出現的新協定提供了良好的理論框架,並且與 TCP/IP 協定組四層協定之間有映射關係,能夠很好地描述既存的 TCP/IP 協定組。
TCP/IP 協定組的各層各有不同的協定,且各層之間的運作細節是抽象的,究竟這樣一個龐大複雜的系統是如何運作的呢?
Packet Traveling [10][11]
事實上,封包的傳送正如同寄送包裹。例如筆者從台北寄一箱書到舊金山,假設每個包裹只能放若干本書,這箱書將分成多個包裹寄送,每個包裹需註明寄件地址、收件地址、收件者。寄送流程從郵局開始,一路經過台北物流中心 → 北台灣物流中心 → 基隆港 → 洛杉磯港 → 北加州物流中心 → 舊金山物流中心 → 收件者住處,最後由收件者收取。
這如同從 IP 位於台北的設備連上 IP 位於舊金山的網站,資料將被切分成多個固定大小的封包(Packet)之後個別帶上請求端 IP、響應端 IP 及其他必要資訊,接著便從最近的路由器(Router)出發,一路送至位於舊金山的伺服器(Server)。
每個包裹上的收件地址也如同 IP 位置,是全球唯一的位置識別。包裹的收件地址中除了包含收件者的所在城市、街道,還包含了門號,每個門號後都住著不同的收件者。門號正如同封包中後綴於 IP 的連接埠(Port),而住在不同門號的收件者也如同使用不同連接埠的應用程式(Application),分別在等待屬於他們的包裹。實際上,特定的連接埠會被分配給特定的應用程式,例如 Email 使用連接埠 25、HTTPS 使用連接埠 443 等等。
雖然包裹的最終目的地是收件地址,但包裹在運送途中也會有數個短程目的地 — 也就是各地的物流中心。包裹在各個物流中心之間移動,例如從北部物流中心到基隆港,再從基隆港到洛杉磯港,雖然其短程目的地會不斷改變,但其最終目的地會保持不變。
封包的最終目的地稱為端點(End),短程目的地稱為轉跳(Hop) — 也就是路由器(Router)。路由器能將封包從一個網段送至另一個網段,直到封包抵達其端點 IP 所在的網段為止。封包使用兩種定址方法:以 IP 表示端點的位置,而以 MAC 表示路由器的位置。這種從轉跳至轉跳(From Hop to Hop)的通訊是屬於 TCP/IP 協定組第一層:網路存取層(Network Access Layer)的協定。
那麼要如何決定包裹的下一個短程目的地呢?理論上,每個物流中心皆需選擇與最終目的地物理距離最短的物流中心作為下一個短期目的地。例如對寄到舊金山的包裹來說,位於基隆港的包裹下一站應該是洛杉磯港,而不是上海港。
封包則使用路由器中的路由表(Routing Table)來決定下一個轉跳位置,有數種不同的路由協定,例如 RIP / IGRP 等,可以進行路由表的更新。從端點到端點(From End to End)的通訊正是屬於 TCP/IP 協定組第二層:網際層(Internet Layer)的協定。
若一箱書需要分多次寄送,則可以採取不同的寄送策略。至於選擇何種寄送策略,則端看包裹內容物的屬性:
求穩定的策略:每個包裹都會有個序號,寄包裹前要先寫一封信通知收件者,收件者於收到信後需回信確認,寄件者收到確認信後“再”寫一次信告訴收件者「我收到了你的確認」,然後才能寄出包裹。收件者收到包裹後也需回確認信給寄件者,如果寄件者沒收到某序號包裹的回信,則會重寄該包裹。
求效率的策略:連續寄出所有的包裹,收件者不需回信確認。
橫跨多個封包的通訊是屬於 TCP/IP 協定組第三層:傳輸層(Transport Layer)的協定。這兩種策略也對應著傳輸層的兩個主要協定:TCP 與 UDP。TCP 注重穩定,它要求端點於傳送封包前必須先進行三向交握(Three-way Handshake),也就是確認彼此的確認,以建立穩固的連線,且端點在接收封包後也會回傳確認訊息,以確保沒有任何一個封包被遺失;反之,UDP 注重效率,它不要求端點在通訊前進行繁瑣的確認,而是直接傳送封包。
包裹本身亦可以裝載任何內容:這箱書可以是一套金庸全集,也可以是一年份的交換日記;同理,封包內的資料也可以是來自任何上層協定的內容,例如 HTTPS / SMTP / SSH / FTP 等等。這些上層協定都被歸類為 TCP/IP 協定組第四層:應用層(Application Layer)的協定。
維持匿名的技術
區塊鏈仰賴於實體網路傳送訊息,欲使區塊鏈網路層維持匿名,則需使實體網路維持匿名。那麼實體網路如何匿名呢? 若以寄包裹的例子來看,維持匿名,也就是不要讓收件者知道寄件地址。
一個直覺的思路是:先將包裹寄給某個中介(Intermediary),再由中介寄給收件者。如此收件者看到的寄件地址將會是中介的地址,而非原寄件者的地址 — 這也就是代理(Proxy)以及 VPN 等匿名技術所採取的作法。
不過這個作法的風險在於:寄件者必須選擇一個守口如瓶、值得信賴的中介。由於中介同時知道寄件地址與收件地址,倘若中介將寄件地址告知收件人,則寄件者的匿名性蕩然無存。
有沒有辦法可以避免使單一中介毀壞匿名性呢?一個中介不夠,那用兩個、三個、甚至多個呢?這便是洋蔥路由的基本思路。由於沒有任何一個中介同時知道寄件地址與收件地址,因此想破壞寄件者匿名性將變得更困難。
洋蔥路由與 Tor
洋蔥路由(Onion Routing)最初是為了保護美國政府情報通訊而開發的協定,後來卻因為其能幫助平民抵抗政府監控而變得世界聞名。
1997 年,Michael G. Reed、Paul F. Syverson 和 David M. Goldschlag 於美國海軍研究實驗室首先發明了洋蔥路由[13],而 Roger Dingledine 和 Nick Mathewson 於美國國防高等研究計劃署(DARPA)緊接著開始著手開發 Tor,第一版 Tor 於 2003 年釋出[14]。2004 年,美國海軍研究實驗室以自由軟體授權條款開放了 Tor 原始碼。此後,Tor 開始接受電子前哨基金會(Electronic Frontier Foundation)的資助;2006年,非營利組織「Tor 專案小組」(The Tor Project)成立,負責維護 Tor 直至今日。
Tor [15]是洋蔥路由的實作,它除了改進原始設計中的缺陷,例如線路(Circuit)的建立機制,也加入若干原始設計中沒有的部分,例如目錄伺服器(Directory Server)與洋蔥服務(Onion Service),使系統更強健且具有更高的匿名性。
Tor 自 2004 年上線至今已有超過 7000 個由志願者部署的節點,已然是一個強大的匿名工具。然而這也使其成為雙面刃:一方面它可以幫助吹哨者揭露不法、對抗監控;另一方面它也助長了販毒、走私等犯罪活動。但不論如何,其技術本身的精巧,才是本文所關注的重點。
Tor 的運作原理
Tor Overview [16]
Tor 是基於中繼的(Relay-based)覆蓋網路。Tor 的基本思路是:利用多個節點轉送封包,並且透過密碼學保證每個節點僅有局部資訊,沒有全局資訊,例如:每個節點皆無法同時得知請求端與響應端的 IP,也無法解析線路的完整組成。
Tor 節點也稱為洋蔥路由器(Onion Router),封包皆需透過由節點組成的線路(Circuit)傳送。要注意的是,Tor 線路僅是覆蓋網路中的路徑,並非實體網路的線路。每條線路皆由 3 個節點組成,請求端首先會與 3 個節點建立線路並分別與每個節點交換線路密鑰(Circuit Key)。
請求端會使用其擁有的 3 組線路密鑰對每個送出的封包進行 3 層加密,且最內層密文需用出口節點的密鑰、最外層密文需用入口節點的密鑰,如此才能確保線路上的節點都只能解開封包中屬於該節點的密文。被加密後的封包被稱為洋蔥,因其如洋蔥般可以被一層一層剝開,這就是洋蔥路由這個名稱的由來。
封包經過線路抵達出口節點後,便會由出口節點送往真正的響應端。同樣的線路也會被用於由響應端回傳的封包,只是這一次節點會將每個送來的封包加密後再回傳給上一個節點,如此請求端收到的封包就會仍是一顆多層加密的洋蔥。
那麼,請求端該選擇哪些節點來組成線路呢?Tor 引入了目錄伺服器(Directory Server)此一設計。目錄伺服器會列出 Tor 網路中所有可用的節點[17],請求端可以透過目錄伺服器選擇可用的洋蔥路由器以建立線路。目前 Tor 網路中有 9 個分別由不同組織維護的目錄,中心化的程度相當高,這也成為 Tor 安全上的隱憂。
Tor 線路的建立機制
Tor Circuit Construction [18]
Tor 是如何建立線路的呢?如上圖所示,Tor 運用伸縮(Telescoping)的策略來建立線路,從第一個節點開始,逐次推進到第三個節點。首先,請求端與第一個節點進行交握(Handshake)並使用橢圓曲線迪菲 — 赫爾曼密鑰交換(Elliptic Curve Diffie–Hellman key Exchange, ECDH)協定來進行線路密鑰的交換。
為了維持匿名,請求端接著再透過第一個節點向第二個節點交握。與第二個節點交換密鑰後,請求端再透過第一、二個節點向第三個節點交握與交換密鑰,如此慢慢地延伸線路直至其完全建立。線路建立後,請求端便能透過線路與響應端進行 TCP 連線,若順利連接,便可以開始透過線路傳送封包。
洋蔥服務
Clearnet, Deepweb and Darknet [21]
洋蔥服務(Onion Service)/ 隱藏服務(Hidden Service)是暗網(Darknet)的一部分,是一種必須使用特殊軟體,例如 Tor,才能造訪的服務;與暗網相對的是明網(Clearnet),表示可以被搜尋引擎索引的各種服務;深網(Deep Web)則是指未被索引的服務,這些服務不需要特殊軟體也能造訪,與暗網不同。
當透過 Tor 使用洋蔥服務時,請求端與響應端都將不會知道彼此的 IP,只有被響應端選定的節點:介紹點(Introduction Point)會引領請求端至另一個節點:會面點(Rendezvous Point),兩端再分別與會面點建立線路以進行通訊。也就是說,請求端的封包必須經過 6 個節點的轉送才能送往響應端,而所有的資料也會採取端對端加密(End-to-end Encryption),安全強度非常高。
洋蔥服務及暗網是一個令人興奮的主題,礙於篇幅,筆者將另撰文闡述。
混合網路、大蒜路由與洋蔥路由
這裡再接著介紹兩個與洋蔥路由系出同源的匿名技術:混合網路與大蒜路由。
Mix Network Overview [22]
混合網路(Mix Network)早在 1981 年就由 David Chaum 發明出來了[23],可以說是匿名技術的始祖。
洋蔥路由的安全性奠基於「攻擊者無法獲得全局資訊」的假設[24],然而一旦有攻擊者具有監控多個 ISP 流量的能力,則攻擊者仍然可以獲知線路的組成,並對其進行流量分析;混合網路則不僅會混合線路節點,還會混合來自不同節點的訊息,就算攻擊者可以監控全球 ISP 的流量,混合網路也能保證維持匿名性。
然而高安全性的代價就是高延遲(Latency),這導致混合網路無法被大規模應用,或許洋蔥路由的設計是一種為了實現低延遲的妥協。
Garlic Routing Overview [25]
混合網路啟發了洋蔥路由,洋蔥路由也啟發了大蒜路由。2003年上線的 I2P(Invisible Internet Project)便是基於大蒜路由(Garlic Routing)的開源軟體,可以視為是去中心化版的 Tor。幾乎所有大蒜路由中的組件,在洋蔥路由中都有對應的概念:例如大蒜路由的隧道(Tunnel)即是洋蔥路由的線路;I2P 的網路資料庫(NetDB)即是 Tor 的目錄;I2P中的匿名服務(Eepsite)即是 Tor 的洋蔥服務。
不過,大蒜路由也有其創新之處:它允許多個封包共用隧道以節省建立隧道的成本,且其使用的網路資料庫實際上是一個分散式雜湊表(DHT),這使 I2P 的運作徹底去中心化。若想進一步理解 DHT 的運作原理,可以參考筆者之前所撰寫的文章:
連Ethereum都在用!用一個例子徹底理解DHT
I2P 最大的詬病就是連線速度太慢,一個缺乏激勵的去中心化網路恐怕很難吸引足夠的節點願意持續貢獻頻寬與電費。
區塊鏈與洋蔥路由
那麼,基於實體網路的區塊鏈能不能使用洋蔥路由或大蒜路由/混合網路/其他技術,以維持節點的匿名?答案是肯定的。事實上,目前已經出現數個專案與提案:
全新的專案
Dusk:實作大蒜路由的區塊鏈[32],不過官方已宣布因其影響網路效能而暫停開發此功能。
cMix:透過預先計算(Precomputation)以實現低延遲的混合網路[33],是混合網路發明者 David Chaum 近期的研究,值得期待。
Loki:結合 Monero 與 Tor/I2P 的區塊鏈 [34],並使用代幣激勵節點貢獻頻寬與電力,由其白皮書可以看出發明者對於匿名技術的熱愛與信仰。
於主流區塊鏈的提案
比特幣:全世界第一條區塊鏈,將於其網路使用一個不同於洋蔥路由的匿名技術:Dandelion++[30][31],該匿名技術因其訊息傳播路徑的形狀類似浦公英而得其名。
閃電網路(Lightning Network):知名的比特幣第二層方案,將於其網路內實作洋蔥路由[27]。
Monero:使用環簽章保護用戶隱私的區塊鏈,將於其網路內實作大蒜路由,已開發出 Kovri[28] 並成為 I2P 官方認可的客戶端之一[29]。
於以太坊的提案
2018 年 12 月,Mustafa Al-Bassam 於以太坊官方研究論壇提議利用洋蔥路由改進輕節點之資料可得性(Light Client Data Availability)[36]。若讀者想了解更多關於以太坊輕節點的研究,可以參考台北以太坊社群專欄的這篇文章。資料可得性是輕節點實現的關鍵,而這之中更關鍵的是:如何向第三方證明全節點的資料可得性?由於這個提案巧妙地運用了洋蔥路由的特性,因此在今年 7 月在另一則討論中,Vitalik 亦強烈建議應儘速使洋蔥路由成為以太坊的標準[35]。
在這個提案中,輕節點需建立洋蔥路由線路,然而線路節點並非由目錄中挑選,而是由前一個節點的可驗證隨機函數(Verifiable Random Function, VRF)決定。例如線路中的第二個節點需由第一個節點的 VRF 決定。線路建立後,出口節點便可以接著向全節點請求特定的可驗證資料。由於輕節點在過程中維持匿名,因此可以防止全節點對輕節點的審查(Censoring)。取得可驗證資料後,其便與 VRF 證明沿著原線路傳回輕節點,輕節點再將可驗證資料與 VRF 證明提交至合約由第三方驗證。若第三方驗證正確,則資料可得性得證。
結語
隱私與匿名是自由的最後一道防線,我們應該盡可能地捍衛它,不論是透過本文介紹的匿名技術或者其他方式。然而,一個能保護隱私與維持匿名的區塊鏈是否能實現真正的去中心化?這是一個值得深思的問題。
本文也是筆者研究區塊鏈至今跨度最廣的一篇文章,希望讀者能如我一樣享受這段令人驚奇又興奮的探索旅程。
參考資料
[1] Jingwang Weishi, Wikipedia
[2] PRISM, Wikipedia
[3] privacytools.io
[4] Nothing-to-hide Argument, Wikipedia
[5] Anonymity vs Privacy vs Security
[6] Deanonymisation of Clients in Bitcoin P2P Network, Alex Biryukov, Dmitry Khovratovich, Ivan Pustogarov, 2014
[7] Example: P2P system topology
[8] Internet protocol suite, Wikipedia
[9] OSI model, Wikipedia
[10] Packet Traveling: OSI Model
[11] Packet Traveling — How Packets Move Through a Network
[12] A Protocol for Packet Network Intercommunication, VINTON G. CERF, ROBERT E. KAHN, 1974
[13] Anonymous Connections and Onion Routing, Michael G. Reed, Paul F. Syverson, and David M. Goldschlag, 1998
[14] Tor: The Second-Generation Onion Router, Roger Dingledine, Nick Mathewson, Paul Syverson, 2004
[15] Tor, Wikipedia
[16] What actually is the Darknet?
[17] Tor Network Status
[18] Inside Job: Applying Traffic Analysis to Measure Tor from Within, Rob Jansen, Marc Juarez, Rafa Galvez, Tariq Elahi, Claudia Diaz, 2018
[19] How Does Tor Really Work? The Definitive Visual Guide (2019)
[20] Tor Circuit Construction via Telescoping
[21] The DarkNet and its role in online piracy
[22] Mix network, Wikipedia
[23] Untraceable Electronic Mail, Return Addresses, and Digital Pseudonyms, David Chaum, 1981
[24] The differences between onion routing and mix networks
[25] Monitoring the I2P network, Juan Pablo Timpanaro, Isabelle Chrisment, Olivier Festor, 2011
[26] I2P Data Communication System, Bassam Zantout, Ramzi A. Haraty, 2002
[27] BOLT #4: Onion Routing Protocol
[28] Kovri
[29] Alternative I2P clients
[30] Bitcoin BIP-0156
[31] Dandelion++: Lightweight Cryptocurrency Networking with Formal Anonymity Guarantees, Giulia Fanti, Shaileshh Bojja Venkatakrishnan, Surya Bakshi, Bradley Denby, Shruti Bhargava, Andrew Miller, Pramod Viswanath, 2018
[32] The Dusk Network Whitepaper, Toghrul Maharramov, Dmitry Khovratovich, Emanuele Francioni, Fulvio Venturelli, 2019
[33] cMix: Mixing with Minimal Real-Time Asymmetric Cryptographic Operations, David Chaum, Debajyoti Das, Farid Javani, Aniket Kate, Anna Krasnova, Joeri De Ruiter, Alan T. Sherman, 2017
[34] Loki: Private transactions, decentralised communication, Kee Jefferys, Simon Harman, Johnathan Ross, Paul McLean, 2018
[35] Open Research Questions For Phases 0 to 2
[36] Towards on-chain non-interactive data availability proofs
隱私、區塊鏈與洋蔥路由 was originally published in Taipei Ethereum Meetup on Medium, where people are continuing the conversation by highlighting and responding to this story.
👏 歡迎轉載分享鼓掌
中介軟體有哪些 在 部長 Youtube 的精選貼文
全新電影直播節目即將開播
每週五的晚間 20:00 - 21:30
將與太空小姐一起主持!想要節目有哪些內容呢?
影片中介紹的遊戲為 PS4『ONE PIECE 海賊無雙4』來這邊看看~
https://store.playstation.com/zh-hant-tw/product/HP0700-CUSA16646_00-ASIAFULLGAME0000
電影酷拉部開播預告 7:00-12:38
PS4『ONE PIECE 海賊無雙4』模型限定版開箱 12:39-40:10
PS4 無雙系列介紹 40:11-44:24
💰【贊助】成為優秀部員: https://goo.gl/IvPFMS
►馬上訂閱部長:https://goo.gl/fhng5L
►加入Telegram:http://bit.ly/bujoTelegram
▼直播規定▼
1.不要洗頻
2.不要使用惡意語言
(罵人或起爭議或釣魚)
3.不要問台主私人隱私
(幾歲、住哪之類的...)
4.不要宣傳自己的頻道
(求互訂閱這個很蠢)
5. 不要爆雷跟過度下指導棋
(我跟觀眾都想要好好體驗遊戲啊)
▌部長。主頻道 (Main Channel)
☞https://goo.gl/fhng5L
▌部長。遊戲頻道 (Gaming Channel)
☞https://goo.gl/ouZUDA
▌FB粉絲頁(發布各種日常,歡迎追蹤)
☞https://goo.gl/Q4tPg7
▌IG(發布各種日常,歡迎追蹤)
☞bujo1104
直播配備:
▶️ 擷取卡 Cam Link 4K
- 可以將單眼數位相機變成視訊使用,大幅提高直播中人像的畫質以及觀影體驗
- 超簡單隨插即用!
DSLR相機相容表格https://www.elgato.com/en/gaming/cam-link/camera-check)
- 支援4K超清晰畫質
- 商城連結: https://reurl.cc/31VyW9
▶️ 鍵盤 K95 RGB Platinum XT
- 航空級鋁合金髮絲紋框架
- 業界頂級Cherry MX櫻桃機械軸(銀/茶/青)
- iCUE軟體控制全鍵RGB動態背光、巨集設定,6顆支援Elgato Stream Deck專用按鍵
- 耐用不沾髒污PBT雙料注塑鍵帽
- 商城連結: https://reurl.cc/xDqemV
▶️ 無線藍芽耳機 Virtuoso
- RGB燈效可自由調整、超耐用金屬框體
- 無線、USB、3.5mm 三種模式
- 獨家Slipstream無線傳輸技術,更穩更快更遠
- 16+小時電池容量
- 語音清晰、可拆卸、指向性麥克風
- 7.1環繞、50mm音效驅動
- 商城連結: https://reurl.cc/qDeaeq
#部長茶水間
![post-title](https://i.ytimg.com/vi/4Zu1fr1PjOs/hqdefault.jpg)