在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

以太坊無狀態客戶端是什么

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2020-12-25 18:57 ? 次閱讀

現在有一個協議轉換現象,從理論上來說,它可以轉換成很多其他不同的協議,從數學上來看,它就像如下情況。假設我們使用狀態轉移,STF(S, B) -> S’,其中S和S’是狀態,B是區塊(或者說它是轉賬T),并且STF是狀態轉移函數。那么,我們可以轉換為:

S -> S的根狀態(也就是說,Merkle樹所包含S的32位)。B -> (B, W),其中W是一個“見證者”,Merkle樹的分支會提供所有數據的價值,可以執行讓B進入STF-> STF’,這可以作為狀態根部的輸入,以及區塊鏈上的見證者,使用見證者作為“數據庫”,任何時候區塊的執行都需要閱讀任何賬戶,存儲秘鑰或者其他狀態數據【如果見證者沒有包含一些需要被請求的數據】,并且輸出新的狀態根部。

這就是,全節點只會存儲狀態根部,并且它會成為礦工的責任來打包這些Merkle樹的分支(見證者),以及區塊,還有全節點會下載以及驗證這些擴展的區塊。對于無狀態的全節點和常規的全節點來說,在網絡中共存,這都是有可能的;你需要獲得擁有區塊B的翻譯區塊,附上所需要的見證者,并且在無狀態節點存在的不同網絡協議上廣播(B, W);如果有礦工在這個無狀態網絡上挖出區塊,那么見證者可以很簡單地去除,同時區塊會在正常的網絡上進行重新廣播。

假設真實協議中的見證者,最簡單的方法就是把它作為RLP編碼的對象,這會被客戶端解析為{sha3(x): x}關鍵價值圖譜;這個圖譜然后可以很簡單地嵌入到現在的以太坊中,作為“數據庫”布局。

將以上這個想法布局到以太坊上的局限在于,還是需要礦工成為存儲狀態的全節點。有人會假設這樣一個系統,其中轉賬發出方需要存儲全狀態Trie(甚至只有和他們相關的部分),而且礦工也是無狀態的,但是問題在于以太坊的狀態存儲入口是動態的。例如,你可以假設getcodesize(sha3(sha3(…sha3(x)…)) % 2**160)的合約形式,其中會有幾千個sha3’s。這就導致進入的賬戶代碼只有在幾百萬gas燃料的計算消耗完成后,才可能知道。因此,轉賬發出者可以創造一個轉賬,其中包含新賬戶的見證者,進行很多計算,然后最后嘗試進入一個沒有見證者的賬戶。這就和DAO軟分叉漏洞一樣。

其中一個的解決方案,就是讓轉賬包含這些賬戶的靜態列表;例如EIP 648,但是需要精確數字,而不是一個范圍。但是就會產生一個問題:到時候,轉賬會通過網絡,賬戶狀態,進行擴散,從而因此正確的Merkle樹分支可以作為見證者,也許會和轉賬生成時的正確數據不同。為了解決這個問題,我們把見證者放在轉賬中的簽名數據之外,并且讓包含轉賬信息的礦工在有需要地時候,在轉賬前對見證者進行調整。如果礦工擁有對所有創建出來的新狀態樹節點,也就是說,在過去24小時,他們已經獲得必要的信息來更新過去24小時公開轉賬的Merkle樹分支。
這項設計有如下優勢:

1.礦工和全節點再也不需要存儲任何狀態。這會讓“快速同步”變地非??欤赡苤恍枰獛酌耄?。

2 關于狀態存儲經濟學的問題都會導致例如租賃的設計,并且甚至目前復雜的SSTORE支出/回款架構就會消失,而且區塊鏈經濟學能夠只專注于價格帶寬和計算,這會是更加容易的問題。

3. Disk IO對于全節點和礦工來說,就不會是個問題。Disk IO是以太坊上主要的DoS攻擊來源,而且甚至現在它好像是最容易發生的DoS因素。

4. 對指定帳戶列表的轉賬要求附帶地增加了高度的可并行性;這在很多方面是EIP 648的高配版本。

5. 對于狀態存儲的客戶端,賬戶列表讓客戶端能夠從disk預取存儲數據,也許是并行的,大概率降低了DoS攻擊的漏洞。

6. 在分片區塊鏈中,通過在分片中對客戶端進行調整,從而增加安全性;客戶端分片調整地越快,在拜占庭容錯模型中,這個架構就更加安全。但是,在狀態存儲的客戶端模型中,被洗牌的客戶端就會下載新分片中的全部狀態。在無狀態的客戶端中,這部分成本為零,這就讓客戶端可以在它們創建的每個區塊間進行調整。

但是這帶來一個問題:誰存儲了這個狀態?以太坊的關鍵優勢就是這個平臺很容易使用,并且用戶不需要關心存儲私有狀態這類細節。因此,為了這類框架能夠很好地完成,我們需要復制類似的用戶經驗。這是一個關于如何做到這一點的混合建議:

1.任何創造出來的新的狀態樹對象都會默認被全節點保存3個月。這大約有2.5GB的存儲空間,而且這就好像“福利儲存”,這是基于自愿地基礎上由網絡提供。我們知道這個層次的服務當然能夠基于自愿的基礎來提供,因為目前的輕節點結構已經是基于利他主義了。在3個月后,客戶端可以隨機地忘記,以至于例如一個12個月前接觸到的狀態樹對象,還會被25%的節點存儲,而且60個月之前的對象還被5%的節點存儲??蛻舳四軌驀L試使用常規的輕節點協議,來調用這些對象。

2.希望確保特定數據段的可用性客戶端可以在狀態信道中進行支付??蛻舳丝梢栽O置支付節點的通道,而且在“我放棄0.0001美元,并且默認這筆支付會永遠丟失。但是,如果你之后給某個對象提供哈希H,然后我簽名,之后這個0.0001美元會到你手上”這種模式下進行有條件支付。這將標志著一個可信的承諾:可能愿意為未來的對象解鎖那些資金,檔案節點可以進入數以百萬計的這樣的安排,等待數據請求出現,并成為收入流。

3.我們期望DAPP開發人員能夠讓他們的用戶來隨機存儲一部分的存儲秘鑰,在瀏覽器本地存儲中存儲與它們的DAPP相關的部分存儲密鑰。這甚至可以故意在Web3API中很容易做到。

事實上,我們希望能夠知道“檔案節點”的數量,可以永遠存儲任何事物,并且持續足夠高來服務網絡,直到在分片引入之后,整個狀態大小超過 1-10兆字節,所以以上所說的可能甚至都不需要。

審核編輯:符乾江

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 智能計算
    +關注

    關注

    0

    文章

    190

    瀏覽量

    16684
  • 以太坊
    +關注

    關注

    14

    文章

    1838

    瀏覽量

    32609
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    MKW45B41Z客戶端無法從服務器獲取服務是為什么?

    。MKW45B41Z (自定義板) 充當中央設備客戶端角色。MKW45 客戶端掃描外圍設備(NRF 連接)設備并連接到外圍設備(NRF 連接)設備。連接 MKW45(自定義板卡)后,客戶端無法從服務器
    發表于 03-28 07:40

    如何構建MCP客戶端

    Anthropic開源了一套MCP協議,它為連接AI系統與數據源提供了一個通用的、開放的標準,用單一協議取代了碎片化的集成方式。本文教你從零打造一個MCP客戶端。
    的頭像 發表于 03-20 09:32 ?1273次閱讀
    如何構建MCP<b class='flag-5'>客戶端</b>

    請問STM32WB55客戶端應用接收的特征長度為什么更改無效呢?

    STM32WB55客戶端應用接收的特征長度為什么更改無效呢?
    發表于 03-10 06:18

    邁威通信工業無線客戶端:智能制造的高效連接新解法

    隨著智能制造的興起,企業越來越依賴自動化和數字化技術來提高生產效率和靈活性。工業無線客戶端作為連接各個設備和系統的橋梁,其重要性日益凸顯。通過工業無線客戶端,可以實現設備間的實時數據交換和遠程監控,從而進一步提升生產過程的智能化水平。
    的頭像 發表于 11-22 16:10 ?451次閱讀
    邁威通信工業無線<b class='flag-5'>客戶端</b>:智能制造的高效連接新解法

    socket 客戶端與服務器的實現

    1. 理解Socket 在計算機網絡中,socket是一種通信機制,允許兩個程序(一個客戶端和一個服務器)通過網絡進行通信。在Python中,可以使用 socket 庫來創建和管理sockets
    的頭像 發表于 11-12 14:30 ?774次閱讀

    NTP網絡時間服務器能帶同步多少客戶端?

    NTP網絡時間服務器能帶同步多少客戶端
    的頭像 發表于 09-04 10:43 ?822次閱讀
    NTP網絡時間服務器能帶同步多少<b class='flag-5'>客戶端</b>?

    Rambus推出DDR5客戶端時鐘驅動器

    在追求極致性能與效率的科技浪潮中,Rambus再次引領行業前行,正式宣布推出面向下一代高性能臺式電腦與筆記本電腦的DDR5客戶端時鐘驅動器(CKD)。這一創新舉措標志著Rambus將其在服務器領域的先進內存接口技術成功擴展至廣闊的客戶端市場,為PC用戶帶來前所未有的性能飛
    的頭像 發表于 09-03 15:26 ?849次閱讀

    esp_iot_sdk_v0.9.6_b1客戶端斷開連接導致WDT重置怎么解決?

    客戶端斷開連接,服務器一定不會掛起。實際上,由于客戶端啟動了連接,因此客戶端理所當然地應該能夠斷開連接,而不會對服務器造成任何問題。 IPD,0,80:GET /測試 HTTP/1.1 用戶代理
    發表于 07-18 06:33

    如果ESP上的TCP客戶端與服務器斷開連接,如何啟用自動重連?

    ESP - TCP 客戶端 嵌入式 Linux 服務器 - TCP 服務器 如果ESP上的TCP客戶端與服務器斷開連接,如何啟用自動重連?
    發表于 07-17 06:25

    如何獲取連接的TCP客戶端的ESPCONN指針?

    我幾乎閱讀了 SDK API 指南版本 1.0.1 的所有文檔 并開始了解如何添加用戶 AT 命令。 這真的很簡單,只需撥打at_cmd_array_register。 BUT! 如何獲取連接的 TCP 客戶端的 ESPCONN 指針?
    發表于 07-12 14:54

    Esp8266與SSL REST的連接失敗,并顯示“客戶端握手失敗”,為什么?

    Esp8266 與 SSL REST 的連接失敗,并顯示“客戶端握手失敗”
    發表于 07-12 07:43

    STA模式下TCP客戶端異常自動斷開是什么原因呢?

    兩個WIFI模塊,一個工作在AP模式作為TCP服務器,一個工作在STA模式作為TCP客戶端。TCP客戶端在串口出現打印信息pm open,type:2 0后就會斷開。后面我又改成UDP通訊,在串口出現打印信息pm open,type:2 0后UDP就間歇收不到數據,請問是
    發表于 07-09 06:30

    如何同時在ESP8266上運行TCP客戶端和TCP服務?

    我們是 esp8266 的長期用戶,并在該芯片上運行數千臺家庭自動化類別的現場設備。然而,一個小小的限制阻礙了我們開發一些更有趣和創新的產品。 要求:我們需要同時運行 TCP 客戶端(連接
    發表于 07-08 08:26

    求助,關于ESP32C3 TCP客戶端連接斷線問題求解

    ESP32C3開啟AP模式做TCP服務器,手機做客戶端連接服務器;超過默認最大連接數(5)以后,即使有部分客戶端斷開了,也無法再發起連接連接不上。一定需要服務器給客戶端發送數據,確認客戶端
    發表于 06-27 07:54

    MQTT客戶端棧大小分配過大而導致無法初始化怎么處理?

    在配置MQTT客戶端時,因為我想接收很大的數據包(最大500k)。因此我想一次接收完成(擴展了psram)。所以我在配置MQTT客戶端時將棧大小設置為114688,將接收緩沖區大小設置為
    發表于 06-21 12:54
    主站蜘蛛池模板: 美女被视频网站在线看九色 | 亚洲综合久久综合激情久久 | 午夜在线观看免费观看大全 | 狠狠色伊人亚洲综合第8页 狠狠色依依成人婷婷九月 狠狠色影院 | 亚洲小说区图片区另类春色 | 亚洲第一久久 | 欧美国产精品主播一区 | 日本不卡毛片一二三四 | 免费看的黄网站 | 亚洲综合黄色 | 在线看片福利 | 1000部啪啪未满十八勿入 | 中文字幕第二区 | 伊人网络 | 国产日韩精品一区二区三区 | 国模私拍大尺度视频在线播放 | 扒开双腿猛进湿润18p | 午夜激情小视频 | 五月婷婷激情在线 | 欧美成人全部免费观看1314色 | 欧美一级视频在线观看 | 在线精品91青草国产在线观看 | 日本在线一区二区 | 高清视频黄色录像免费 | 色综合欧美综合天天综合 | 四虎院影永久在线观看 | 一级视频在线观看免费 | 夜夜夜精品视频免费 | 欧美一级片在线视频 | 成人综合色站 | 国模无水印一区二区三区 | 欧美人与牲动交xxxxbbbb | 午夜噜噜噜 | 欲妇放荡叫床很浪的小说 | heyzo在线播放4k岛国 | 美女扒开尿口给男人爽的视频 | 色婷婷5月精品久久久久 | 五月天婷婷网亚洲综合在线 | 国产精品久久久久久免费播放 | 婷婷6月| 天天靠天天擦天天摸 |