上一篇文章討論了如何保護ETH2.0的取款密鑰,并總的介紹了ETH2.0驗證者所使用的幾個密鑰對。在閱讀本文之前,建議先閱讀一下這篇文章。同樣地,我們預設讀者對驗證者有最基本的了解,包括但不限于“驗證者是什么”,“他們為什么需要密鑰”,以及“他們通常需要什么操作”等概念。
什么是驗證者密鑰?
在ETH2.0中,驗證者密鑰被用來確定相關消息是哪位驗證者發出的。驗證者要發送這些消息才能獲得獎勵。
驗證者密鑰的風險很難衡量:驗證者密鑰本身無法用來訪問資產。因此,即使攻擊者獲得了你的驗證者密鑰,也無法直接盜取資產。但是,他們可以通過敲詐勒索?1?等方式間接獲利,更有甚者,比起自己獲利,他們更想讓你蒙受損失?2?。因此,我們通常認為驗證者密鑰的安全需求很高。
-圖1:驗證者的安全需求-
但是,不像取款密鑰那樣,驗證者密鑰要能夠隨取隨用,因為驗證者在每個epoch都要簽署多個消息。因此,驗證者密鑰的訪問需求也很高。
-圖2:驗證者密鑰的訪問需求-
因此,我們發現自己陷入了兩難困境:從傳統上來說,同時滿足安全性和可訪問性需求是很難實現的,因為提高安全性往往會降低可訪問性,反之亦然。
-圖3:驗證者密鑰的雙重需求-
為滿足對安全性和可訪問性的雙重需求,我們需要采取更高級的措施,在不作重大妥協的前提下,較高程度地滿足這兩方面的需求。這可以通過分層來實現。本文的目的是探究每一層所提供的功能,并了解哪些功能適用于或不適用于驗證者設置。
Eth2中的密鑰對都有一把公鑰和一把私鑰。出于本文的寫作目的,全篇所用的“key”一詞指代的都是通常叫做私鑰的那把;如果指代的是公鑰,會有明確的說明。
Arbitrum網絡目前已恢復正常:6月8日消息,據官方消息,Arbitrum的排序器代碼此前出現bug,導致該網絡批量提交交易的功能短暫中斷,交易無法在主鏈上得到確認。隨后漏洞已被修復,交易批量提交功能已恢復。
此前報道,Arbitrum網絡運行短暫延遲。[2023/6/8 21:23:14]
目標和分層
首先,我們需要定義攻擊者和用戶的目標。在知道為什么要保護驗證者密鑰之后,我們就可以思考每個功能可以在多大程度上實現這一目標。首先,攻擊者的目標可以被定義成:
攻擊者的目標是,簽署某一條消息時能簽出與目標驗證者公鑰相對應的簽名。
當然了,如果這是唯一的目標,那么直接毀掉驗證者密鑰就能阻止攻擊者了。但是,這對用戶來說一點幫助也沒有。因此,我們需要考慮的第二個目標,也就是用戶的目標,可以被定義成:
用戶的目標是只簽署理想消息,不簽署不良消息。
就本文的目標而言,理想消息指的是能夠獲得獎勵的消息,不良消息指的是會觸發?罰沒事件?3?的消息。
請注意,攻擊者要想實現其目標,只需要簽署任意一條消息即可,而用戶的目標是持續性的。這種不對稱性是安全系統的一大特征,即,攻擊者只需贏一次就夠了,而用戶需要每次都贏。
為此,我們需要一個由不同分層或者說獨立功能組成的系統,提供增強型安全性或增強型可訪問性,而且可以將二者結合起來,共同達到較高水平。一個良好的安全模型需要具備多個分層,每個分層都會提供某種保障或其它分層的備份,并且有足夠多的分層提供可訪問性,從而確保用戶的目標可以實現。請注意,本文聚焦于技術保護:其它層面上的安全性都不屬于本文的討論范圍內,雖然它們在任何安全模型中都是至關重要的部分,應該采取相應解決方案。
DeFi借貸協議OpenLeverage推出質押借貸服務,并將在Arb上發二次空投:4月18日消息,據官方推特,去中心化借貸和保證金交易協議OpenLeverage宣布已經在Arbitrum上上線了質押借貸協議,可以給Arb上所有的長尾項目提供質押和借貸服務,此外,OpenLeverage即將在Arb上推出第二個追溯獎勵計劃(空投),以鼓勵協議使用、市場創造和流動性增加。[2023/4/19 14:11:59]
分層
為了探討驗證者密鑰的保護方式,我們先來做個簡單的演示:
-圖4:驗證者密鑰-
與ETH2.0的所有密鑰一樣,驗證者密鑰也是一串數字?4?。如果驗證者在不采取任何保護措施的情況下存儲了驗證者密鑰,攻擊者很容易就能獲得該密鑰并實現其目標。以下幾類人能夠獲得驗證者密鑰:
任何有權訪問運行驗證者客戶端的計算機賬號的人
任何被授權訪問運行驗證者客戶端的計算機的人
任何可以物理訪問運行驗證者客戶端的計算機的人
任何有權訪問運行驗證者客戶端的計算機的數據的人
這樣一來,用戶就無法實現其目標。因此,我們首先要通過加密的方式來保護驗證者密鑰:
-圖5:加密驗證者密鑰-
我們可以通過多種方式加密驗證者密鑰,例如,?EIP-2335?標準?5?。一旦驗證者密鑰被加密,除非攻擊者掌握加密口令,否則無法解密出密鑰?6?。這樣就可以很好地保護驗證者密鑰。
乍看之下,攻擊者似乎無法通過任何方式來實現其目標。然而,用戶也沒有辦法實現其目標,因為他們再也無法簽署理想消息:無論是對于用戶還是攻擊者來說,經過加密的密鑰都是沒用的,因為用戶必須先將該密鑰解密,然后才能用它來簽署消息。這樣一來,驗證者進程就一定要包含訪問解密口令這一步驟。即然驗證者進程可以訪問解密口令,那么攻擊者也可以訪問該口令,尤其是在解密口令被存儲在驗證者客戶端的情況下,因為驗證者客戶端有可能遭到攻擊。
美國SEC增加其工作人員重點調查DeFi平臺、NFT和穩定幣等違反證券法的行為:金色財經報道,美國證券交易委員會(SEC)正在增加員工人數,增強審查、調查、審計、檢查和可能起訴與這些新加密產品和交易活動相關的證券法違法行為的能力。
新增的工作人員將包括監管人員、調查人員律師、欺詐分析師和出庭律師,重點調查以下方面違反證券法的行為:加密資產發行、交易以及借貸和質押產品;DeFi平臺;NFT和穩定幣。(福布斯)[2023/3/7 12:46:16]
因此,這種改變本身不算上策。不過,如果我們將它與第二層結合起來,就能提供更有力的保護:
-圖6:遠程口令-
如果解密口令是遠程存儲的,加密驗證者密鑰會帶來更強大的保護?7?。由于口令不再存儲于驗證者客戶端內,攻擊者無法從磁盤數據中獲得未加密的私鑰。攻擊者只能發動更加復雜的攻擊,例如,從內存中獲取解密后的密鑰,或模仿驗證者客戶端進程來獲得解密密鑰。
雖然攻擊難度更大了,但是復雜攻擊依然有可能獲得驗證者密鑰。此外,用戶依然可能在不經意間簽署不良消息。因此,我們可以通過增加一個遠程簽名器層來為用戶提高安全性和可訪問性。
-圖7:遠程簽名器-
遠程簽名器分離了驗證者客戶端的核心功能:確定要放到消息中的數據、簽署消息并將該消息發送至ETH2.0網絡。第一個和第三個功能仍保留在驗證者客戶端手中,第二個功能由遠程簽名器來實現。遠程簽名器還引入了?罰沒保護機制?,可以確定哪些是理想消息,哪些是不良消息,并予以簽署或拒絕。
如何阻止攻擊者將攻擊目標從驗證者客戶端轉移到遠程簽名器呢?首先,簽名器可以具備比驗證者客戶端更高的安全性。驗證者客戶端需要執行許多任務,包括與ETH2.0網絡的其它組成部分通信。這些通信可以為攻擊者提供信息和攻擊界面。由于簽名器只與驗證者客戶端通信,它們的活動受到很多限制,這就為雙方的服務器帶來了更高的安全性。
Decentraland LAND系列NFT市值達2.35億美元:金色財經報道,據NFTGo.io數據顯示,Decentraland LAND系列NFT總市值達2.35億美元,在所有NFT項目總市值排名中位列第13;其24小時交易額為2.85萬美元,跌幅達5.94%%。截止發稿時,該系列NFT當前地板價為1.23ETH,漲幅達515%。[2022/7/9 2:01:17]
其次,遠程簽名器為用戶帶來了其它好處。現在,同一個遠程簽名器可以與多個驗證者客戶端通信,使得我們能夠創建具備高可用性的驗證者客戶端基礎設施。遠程簽名器確保驗證者客戶端不會簽署任何不良消息。
然而,事實上,遠程簽名器存在單點故障問題:如果遠程簽名器遭到攻擊,或出現故障,用戶就連理想消息也簽名不了。有沒有一種方法可以讓遠程簽名器更能抵抗攻擊,同時又不會失去上述任一好處?
-圖8:門限簽名-
我們還可以在上述層次的基礎上再構建一層門限簽名,進一步增強安全性和可訪問性。驗證者密鑰需要用Shamir密鑰分割流程來處理,即,使用驗證者私鑰生成多個密鑰,然后將它們發送給遠程簽名器。
-圖9:Shamir密鑰分割-
現在,每個遠程簽名器都持有由驗證者私鑰生成的密鑰了,而且只需幾個遠程簽名器就可以創建有效簽名,也就是所謂的?門限簽名?。假設有3個遠程簽名器,其中2個遠程簽名器提供個人簽名來生成一個聚合簽名,如下圖所示:
-圖10:生成聚合簽名-
門限簽名的表達式通常寫成m/n,也就是說,假設總共有n個簽名,需要任意m個簽名來生成一個有效簽名。如果門限值是2/3,那么使用任意兩個簽名即可生成一個有效簽名。
引入門限簽名之后,即使有一個服務器?8?出故障,用戶也能簽署理想消息,而且也不會增加用戶無意間簽署不良消息的概率。鑒于硬件、軟件和操作失敗的可能性不可消除,門限簽名確實是一個具有抗逆性的驗證基礎設施應有的功能。
NFT價值發現平臺EyesFi完成200萬美元融資,Multicoin Capital領投:6月24日消息,NFT價值發現平臺EyesFi完成200萬美元融資,Multicoin Capital領投,Puzzle Ventures和Delta Blockchain Fund等參投。
據悉,EyesFi成立于2021年第二季度。團隊通過NFT估值系統、資產管理系統、3D Gallery等獲得了超過10,000名忠實用戶,早期貢獻者可以免費鑄造Genesis Utility NFT。EyesFi推出了基于策展的“Like2Earn”獎勵機制,并決定將GameFi維度整合到其生態系統中。此外,EyesFi將于7月上旬推出alpha測試。(Medium)[2022/6/24 1:28:52]
雖然門限簽名機制會帶來額外的安全性,但是它有兩大缺點。第一,分發密鑰并不能預防長期攻擊:假設門限值是2/3,如果有一個簽名器反水,整個機制就會留下永久的漏洞,只要再有一個簽名器反水,攻擊者就可以達成目標。第二,攻擊者有可能在密鑰分發過程開始前搶先獲得該密鑰,從而導致整個機制喪失意義。分布式密鑰生成可以一舉解決這兩個問題:
-圖11:分布式密鑰生成-
分布式密鑰生成是一個比較復雜的話題。具體的運作方式不在本文的討論范圍內。但是,我們會提供一個簡短的功能說明,來闡述它是如何克服簡單門限簽名的局限性的。
在分布式密鑰生成開始前,用戶先要決定門限值,例如2/3。他們可以選擇3個遠程簽名器,并啟動生成過程。這3個遠程簽名器會通過密鑰管理器?9?生成自己的密鑰,不與用戶或其他任何一個簽名器共享,以及一些公共信息。將來自3個簽名器的公共信息結合起來就能創建出一個合成公鑰。
-圖12:創建合成公鑰-
只需3個簽名器中的任意2個即可生成簽名,類似簡單的門限簽名。
-圖13:一組簽名器簽署消息-
如果有一個簽名器不可用,例如,下線維護或遭到攻擊,還可以通過另外兩個簽名器生成簽名。
-圖14:另一組簽名器簽署消息-
可以看出,分布式密鑰生成與簡單的門限簽名具備相同的優勢,可以避免最開始需要分發密鑰的風險。但是,一個簽名器被攻陷就會留下永久漏洞的問題仍然存在。那分布式密鑰生成還有其它招數嗎?
有的,就是“密鑰更新”。密鑰更新就是毀掉現有密鑰,由每個簽名器重新生成新的密鑰。新生成的密鑰保留原有密鑰的特性,即,任意兩個密鑰可以結合起來生成一個有效簽名。新的密鑰與原有密鑰不具有相關性,因此無法通過原有密鑰計算出新的密鑰。
-圖15:密鑰更新-
如果有一個簽名器遭到攻擊,其它簽名器可以觸發密鑰更新。新舊密鑰無法結合起來生成一個有效簽名。這樣一來,被攻擊者盜走的密鑰就會變得毫無用處。
-圖16:攻擊失敗-
密鑰更新可以多次執行,以防多個簽名器遭到攻擊。
其它需要考慮的要點
安全性是一個大概念。上文闡述了不同安全層的功能和優點,并沒有提出任何完美甚至最佳解決方案。就保護驗證者密鑰而言,我們還需考慮很多要點,例如:
硬件錢包
支持BLS12-381的硬件錢包預計很快就會上線。硬件錢包可以替代下層所使用的簡單磁盤存儲系統。但是這樣一來,我們可能無法引入分布式密鑰生成之類的高級技術。
成本效益
凡是涉及安全性的方案都有可能為了提高一點安全性而花費大量資金。每個用戶都需要決定自己想要防范的攻擊,及其愿意為此付出的代價。
遠程存儲驗證者密鑰
上文已經討論過了遠程口令存儲。但是,遠程存儲驗證者密鑰是否還會帶來其它優勢?雖然它不會增強安全性,但是在出現硬件故障的情況下,它可以讓驗證者客戶端更快恢復,這點對于用戶來說非常有利。但是,遠程存儲也會帶來額外的風險,因為我們必需正確配置遠程存儲,確保只有那些獲得許可的人能夠訪問密鑰。
備份驗證者密鑰
雖然本文聚焦于如何保護驗證者密鑰不受攻擊,但是實際上大多數驗證者密鑰丟失事件背后的原因都平平無奇。最常見的就是存儲密鑰的硬件丟失。用戶需要一個備份策略,而且他們需要知道的是,一旦攻擊者獲得了被備份的密鑰,ta就能對任意消息簽出與驗證者公鑰相對應的簽名。我們應該采取適當的措施來確保攻擊者無法訪問已備份的驗證者密鑰。在理想情況下,這些密鑰最好完全脫機存儲,而且外人無法接觸其存儲設備。
多個驗證者密鑰
如果有多個驗證者密鑰,它們之間,或者與它們各自的取款密鑰之間是否應該具備什么關系?例如,將多個驗證者密鑰備份成一個種子,這樣確實使用起來比較方便,但是不會帶來安全效益。用戶應該考慮是否想在任意階段單獨控制驗證者密鑰,再進行相應的計劃。
結論
本文提供了多種方法來保護驗證者密鑰,同時確保它們可以用來履行驗證職責。
每個用戶都應該考慮他們想要提供的安全級別,以及他們應該采取的措施。應當考慮的是,驗證者密鑰不控制資金,因此竊取驗證者密鑰的攻擊者無法直接獲得任何利益?10?。
本文單純從技術層面上探究了如何保護驗證者密鑰。我們還應該考慮運營和社會安全需求。若想全面保護驗證者密鑰,就得考慮到所有這些方面。
或者,你可以使用提供這類功能的質押服務。在綜合考慮技術、風險和資金管理的情況下,Attestant正在構建硬件、軟件和操作服務,以提供機構級的質押服務,讓你可以隨時控制自己的資金。
腳注
“交出贖金,否則就讓你遭到罰沒。”
通過“金手指攻擊”或者將適當規模的攻擊與ETH衍生品相結合,這可能會對攻擊者的財富產生間接影響。
罰沒事件指的是,如果有驗證者對ETH2.0網絡造成傷害,就會損失很大一部分質押物。
其范圍在1和52,435,875,175,126,190,479,447,740,508,185,965,837,690,552,500,527,637,822,603,658,699,938,581,184,512之間。
至文本截稿時,EIP-2335標準仍處于起草階段,不過已經有很多ETH2.0密鑰生成器在使用該標準。
我們假設口令足夠強大,無法暴力破解。
這個例子很好地體現了,如何將兩個層次結合起來提供更高的安全性。
其它門限簽名的變體可以提高冗余性。
我們使用密鑰管理器一詞來指代那些除簽名之外還要執行更多操作的遠程服務器。
還應該注意的是,潛在攻擊者并不一定知道這一事實。
原文鏈接:
https://www.attestant.io/posts/protecting-validator-keys/
作者:?JimMcDonald
翻譯&校對:?閔敏&?阿劍
北京時間8月4日晚上21:00,以太坊2.0第0階段信標鏈的最終版測試網Medalla正式上線.
1900/1/1 0:00:00大家好,誠信立本,德行天下,用心研判趨勢和分析,傳遞有價值的投資理念!希望價有所值,值有所得!?近幾日經歷多空拉鋸后昨日多頭繼續發力,早間一波探底后開啟慢漲模式.
1900/1/1 0:00:00BTC自上周末斷崖以來,一直處于盤整震蕩姿態,終于在昨晚多頭伴隨美元導致的避險情緒開始發力,突破了壓制區間連續拉升,最高觸及11780位置,然而市場還未來得及狂呼.
1900/1/1 0:00:00996的日常生活讓你覺得枯燥無味?想要偷偷找點樂趣順便賺些小錢?為慶祝庫幣合約一周年,庫幣合約上線全世界最酷的合約交易玩法——合約大亂斗.
1900/1/1 0:00:00一、合約保險是什么? CoinBene滿幣合約保險是指您在進行合約交易時,可以在開倉的時候自由選擇購買一定數量的保險,當您的倉位爆倉后,可以根據購買的保險獲得賠付.
1900/1/1 0:00:00本周早些時候,我們朝著在Polkadot上實現平行鏈功能邁出了重要的一步,我們推出了專門為平行鏈及其相關技術設計的新測試網,稱為洛可可.
1900/1/1 0:00:00