以太幣交易所 以太幣交易所
Ctrl+D 以太幣交易所
ads
首頁 > LTC > Info

兼顧安全性和可訪問性 保護驗證者密鑰有幾種方法?_ETH

Author:

Time:1900/1/1 0:00:00

上一篇文章討論了如何保護ETH2.0的取款密鑰,并總的介紹了ETH2.0驗證者所使用的幾個密鑰對。在閱讀本文之前,建議先閱讀一下這篇文章。同樣地,我們預設讀者對驗證者有最基本的了解,包括但不限于“驗證者是什么”,“他們為什么需要密鑰”,以及“他們通常需要什么操作”等概念。

什么是驗證者密鑰?

在ETH2.0中,驗證者密鑰被用來確定相關消息是哪位驗證者發出的。驗證者要發送這些消息才能獲得獎勵。

驗證者密鑰的風險很難衡量:驗證者密鑰本身無法用來訪問資產。因此,即使攻擊者獲得了你的驗證者密鑰,也無法直接盜取資產。但是,他們可以通過敲詐勒索?1?等方式間接獲利,更有甚者,比起自己獲利,他們更想讓你蒙受損失?2?。因此,我們通常認為驗證者密鑰的安全需求很高。

-圖1:驗證者的安全需求-

但是,不像取款密鑰那樣,驗證者密鑰要能夠隨取隨用,因為驗證者在每個epoch都要簽署多個消息。因此,驗證者密鑰的訪問需求也很高。

-圖2:驗證者密鑰的訪問需求-

因此,我們發現自己陷入了兩難困境:從傳統上來說,同時滿足安全性和可訪問性需求是很難實現的,因為提高安全性往往會降低可訪問性,反之亦然。

-圖3:驗證者密鑰的雙重需求-

為滿足對安全性和可訪問性的雙重需求,我們需要采取更高級的措施,在不作重大妥協的前提下,較高程度地滿足這兩方面的需求。這可以通過分層來實現。本文的目的是探究每一層所提供的功能,并了解哪些功能適用于或不適用于驗證者設置。

Eth2中的密鑰對都有一把公鑰和一把私鑰。出于本文的寫作目的,全篇所用的“key”一詞指代的都是通常叫做私鑰的那把;如果指代的是公鑰,會有明確的說明。

X(原Twitter)向符合資格的創作者開放廣告收益分成:7月29日消息,X(原Twitter)官推宣布,其創作者廣告收益分成現已面向全球符合資格的創作者推出,創作者將能夠獨立設置廣告收益分成和創作者訂閱。

有資格獲得創作者廣告收入分成的用戶必須:訂閱Blue或Verified Organizations;過去3個月內累積帖子至少有1500萬次瀏覽量;至少有500名關注者。符合資格的創作者還需有一個Stripe帳戶,該計劃與支付處理商Stripe合作進行支付。[2023/7/29 16:05:56]

目標和分層

首先,我們需要定義攻擊者和用戶的目標。在知道為什么要保護驗證者密鑰之后,我們就可以思考每個功能可以在多大程度上實現這一目標。首先,攻擊者的目標可以被定義成:

攻擊者的目標是,簽署某一條消息時能簽出與目標驗證者公鑰相對應的簽名。

當然了,如果這是唯一的目標,那么直接毀掉驗證者密鑰就能阻止攻擊者了。但是,這對用戶來說一點幫助也沒有。因此,我們需要考慮的第二個目標,也就是用戶的目標,可以被定義成:

用戶的目標是只簽署理想消息,不簽署不良消息。

就本文的目標而言,理想消息指的是能夠獲得獎勵的消息,不良消息指的是會觸發?罰沒事件?3?的消息。

請注意,攻擊者要想實現其目標,只需要簽署任意一條消息即可,而用戶的目標是持續性的。這種不對稱性是安全系統的一大特征,即,攻擊者只需贏一次就夠了,而用戶需要每次都贏。

為此,我們需要一個由不同分層或者說獨立功能組成的系統,提供增強型安全性或增強型可訪問性,而且可以將二者結合起來,共同達到較高水平。一個良好的安全模型需要具備多個分層,每個分層都會提供某種保障或其它分層的備份,并且有足夠多的分層提供可訪問性,從而確保用戶的目標可以實現。請注意,本文聚焦于技術保護:其它層面上的安全性都不屬于本文的討論范圍內,雖然它們在任何安全模型中都是至關重要的部分,應該采取相應解決方案。

BIS準備開發比特幣的替代品:金色財經報道,BitcoinNews在推特上分享的圖片顯示,國際清算銀行(BIS)提出了開發比特幣替代品的方案。圖片中列出了對待加密貨幣的三種立場:禁止、納入、監管,并分別展示了各種立場的利弊。此外還提出了開發替代品的解決方案,旨在為健康創新構建基礎設施。[2023/3/5 12:43:40]

分層

為了探討驗證者密鑰的保護方式,我們先來做個簡單的演示:

-圖4:驗證者密鑰-

與ETH2.0的所有密鑰一樣,驗證者密鑰也是一串數字?4?。如果驗證者在不采取任何保護措施的情況下存儲了驗證者密鑰,攻擊者很容易就能獲得該密鑰并實現其目標。以下幾類人能夠獲得驗證者密鑰:

任何有權訪問運行驗證者客戶端的計算機賬號的人

任何被授權訪問運行驗證者客戶端的計算機的人

任何可以物理訪問運行驗證者客戶端的計算機的人

任何有權訪問運行驗證者客戶端的計算機的數據的人

這樣一來,用戶就無法實現其目標。因此,我們首先要通過加密的方式來保護驗證者密鑰:

-圖5:加密驗證者密鑰-

我們可以通過多種方式加密驗證者密鑰,例如,?EIP-2335?標準?5?。一旦驗證者密鑰被加密,除非攻擊者掌握加密口令,否則無法解密出密鑰?6?。這樣就可以很好地保護驗證者密鑰。

乍看之下,攻擊者似乎無法通過任何方式來實現其目標。然而,用戶也沒有辦法實現其目標,因為他們再也無法簽署理想消息:無論是對于用戶還是攻擊者來說,經過加密的密鑰都是沒用的,因為用戶必須先將該密鑰解密,然后才能用它來簽署消息。這樣一來,驗證者進程就一定要包含訪問解密口令這一步驟。即然驗證者進程可以訪問解密口令,那么攻擊者也可以訪問該口令,尤其是在解密口令被存儲在驗證者客戶端的情況下,因為驗證者客戶端有可能遭到攻擊。

Beosin成為BNB Chain Kickstart Program官方安全審計服務商:據官方消息,近日,區塊鏈安全公司Beosin宣布正式成為BNB ChainKickstart Program官方安全審計服務商。據了解,BNB Chain啟動的“Kickstart Program”計劃,旨在幫助區塊鏈開發人員在業內機構的支持下開始他們的項目。[2023/2/16 12:10:16]

因此,這種改變本身不算上策。不過,如果我們將它與第二層結合起來,就能提供更有力的保護:

-圖6:遠程口令-

如果解密口令是遠程存儲的,加密驗證者密鑰會帶來更強大的保護?7?。由于口令不再存儲于驗證者客戶端內,攻擊者無法從磁盤數據中獲得未加密的私鑰。攻擊者只能發動更加復雜的攻擊,例如,從內存中獲取解密后的密鑰,或模仿驗證者客戶端進程來獲得解密密鑰。

雖然攻擊難度更大了,但是復雜攻擊依然有可能獲得驗證者密鑰。此外,用戶依然可能在不經意間簽署不良消息。因此,我們可以通過增加一個遠程簽名器層來為用戶提高安全性和可訪問性。

-圖7:遠程簽名器-

遠程簽名器分離了驗證者客戶端的核心功能:確定要放到消息中的數據、簽署消息并將該消息發送至ETH2.0網絡。第一個和第三個功能仍保留在驗證者客戶端手中,第二個功能由遠程簽名器來實現。遠程簽名器還引入了?罰沒保護機制?,可以確定哪些是理想消息,哪些是不良消息,并予以簽署或拒絕。

如何阻止攻擊者將攻擊目標從驗證者客戶端轉移到遠程簽名器呢?首先,簽名器可以具備比驗證者客戶端更高的安全性。驗證者客戶端需要執行許多任務,包括與ETH2.0網絡的其它組成部分通信。這些通信可以為攻擊者提供信息和攻擊界面。由于簽名器只與驗證者客戶端通信,它們的活動受到很多限制,這就為雙方的服務器帶來了更高的安全性。

數據:2023年1月份比特幣礦工收入環比增長50%至2300萬美元:1月30日消息,比特幣礦工在 2023 年 1 月賺取的收入較上月增長約 50%,達到約 2300 萬美元。上個月,比特幣挖礦收入約為 1500 萬美元,這與不斷上漲的能源成本一起,鼓勵 BTC 礦工兌現其挖礦和持有的資產。與此同時,近日比特幣算力突破300EH/s,創歷史新高。[2023/1/30 11:36:43]

其次,遠程簽名器為用戶帶來了其它好處。現在,同一個遠程簽名器可以與多個驗證者客戶端通信,使得我們能夠創建具備高可用性的驗證者客戶端基礎設施。遠程簽名器確保驗證者客戶端不會簽署任何不良消息。

然而,事實上,遠程簽名器存在單點故障問題:如果遠程簽名器遭到攻擊,或出現故障,用戶就連理想消息也簽名不了。有沒有一種方法可以讓遠程簽名器更能抵抗攻擊,同時又不會失去上述任一好處?

-圖8:門限簽名-

我們還可以在上述層次的基礎上再構建一層門限簽名,進一步增強安全性和可訪問性。驗證者密鑰需要用Shamir密鑰分割流程來處理,即,使用驗證者私鑰生成多個密鑰,然后將它們發送給遠程簽名器。

-圖9:Shamir密鑰分割-

現在,每個遠程簽名器都持有由驗證者私鑰生成的密鑰了,而且只需幾個遠程簽名器就可以創建有效簽名,也就是所謂的?門限簽名?。假設有3個遠程簽名器,其中2個遠程簽名器提供個人簽名來生成一個聚合簽名,如下圖所示:

-圖10:生成聚合簽名-

門限簽名的表達式通常寫成m/n,也就是說,假設總共有n個簽名,需要任意m個簽名來生成一個有效簽名。如果門限值是2/3,那么使用任意兩個簽名即可生成一個有效簽名。

引入門限簽名之后,即使有一個服務器?8?出故障,用戶也能簽署理想消息,而且也不會增加用戶無意間簽署不良消息的概率。鑒于硬件、軟件和操作失敗的可能性不可消除,門限簽名確實是一個具有抗逆性的驗證基礎設施應有的功能。

數據:超過45%的以太坊PoS節點由兩個地址運行:9月16日消息,加密分析平臺Santiment公布的數據顯示,以太坊合并后,由兩個地址運行超過45%的以太坊PoS節點。兩個地址已經驗證293個區塊,占所有區塊的45.18%。第一個地址已經驗證188個區塊,占28.97%的份額。第二個地址已經驗證105個區塊,占16.18%的份額。(Zycrypto)[2022/9/16 7:01:04]

雖然門限簽名機制會帶來額外的安全性,但是它有兩大缺點。第一,分發密鑰并不能預防長期攻擊:假設門限值是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

翻譯&校對:?閔敏&?阿劍

Tags:ETHETH2ETH2.0比特幣IETHCRETH2ETH2.0價格比特幣從開始到現在的走勢圖

LTC
晚間必讀5篇 | DeFi崛起對中心化交易所意味著什么?_加密貨幣

BCH再鬧分叉:社區反響激烈幣價平平今日,幣圈博主“Bitcoin”爆料,ViaBTC礦池CEO楊海坡將發起對BCH的再一次分叉,新的分叉鏈代碼為BCC.

1900/1/1 0:00:00
臨時關閉DCHS/BTC交易對的公告_INE

親愛的用戶: 因DochStar(DCHS)項目方節點更新,DigiFinex已于公告發出之日起臨時關閉DCHS/BTC交易對交易服務以及DCHS充提幣服務.

1900/1/1 0:00:00
【關于OASIS綠洲OSS 全球首次發行的公告】_OSS

親愛的用戶:BG是全球領先的BTC合約交易平臺,持有資產排名前列,是全世界用戶體量最大、最高級的比特幣交易平臺之一。BG不斷探究,助推優質項目發展.

1900/1/1 0:00:00
高瞻遠矚!農村小伙第一桶金后遠離享樂,投資比特幣挖礦年入百萬_比特幣

面對人生的第一桶金,很多人有不同的分配方式,有的人想拿著錢去旅游,有的選擇繼續投資。在青海就有這么一位小伙子,他在拿到自己第一桶金的時候,他沒有貪圖一時享受,而是將自己的目光聚焦到了數字貨幣上面.

1900/1/1 0:00:00
BTC多頭依然主導行情 隱私幣拉盤啟動_BTC

BTC24小時成交量回升到250美元附近,使得看多跡象再次出現。點位上,BTC近期連續2次向上突破11515美元以后,進一步檢驗了突破效果.

1900/1/1 0:00:00
“測試網獎勵計劃”要來 從TPS視角分析Filecoin可用性_COI

在“云算力、Filecoin主網上線、各大礦商算力戰”等事件推動下,Filecoin已成為繼DeFi、ETH2.0之后的,區塊鏈行業2020年第三大熱點.

1900/1/1 0:00:00
ads