以太坊基金會的 Tim Beiko 在 11 月做了一次主題為《理解轉換到權益證明的過程》的演講。在這次的分享里,他回顧并整理了以太坊主網在 2021 年里進行的四次硬分叉,分別概述進行了哪些方面的改進;梳理了以太坊2.0路線圖的演變過程,解釋了為什么目前以 rollup 為中心以及采用可執行信標鏈的架構;詳細剖析了合并后的以太坊架構以及過渡的發生過程;最后回顧了2021年客戶端團隊探索合并的實現和進行測試的歷程,并交代了當前的進度以及未來的實現計劃。
這個演講非常適合作為以太坊主網在過去一年的總結,ECN 特此譯制了這個視頻的演講部分,并附上相關的文章資源作為補充和索引,方便讀者重溫與整理。
2021 年以太坊的四次硬分叉
柏林升級 (四月)
納入的 EIP:
EIP-2565:模冪運算 Gas 開銷 (ModExp Gas Cost)
對之前引入模冪運算預編譯模塊的 EIP-198 (大數模冪運算) 進行重新重定價,該模塊使我們能引入許多需要模冪運算的密碼學算法,比如 RSA 簽名驗證。EIP - 2565 提議降低了該模塊 ModExp (0x00..05) 的 gas 開銷,使其與執行其他操作的開銷水平相仿。
EIP-2718:類型化的交易信封 (Typed Transaction Envelop)
以太坊擴容項目Scroll升級并重置測試網五天內,單一地址數達27萬:1月16日消息,以太坊擴容項目Scroll聯創發推表示,自1月9日Scroll升級并重置其Pre-Alpha測試網以來,單一地址數于五天內達到27萬個,每日處理交易數達11萬筆。[2023/1/16 11:14:14]
這份提案引入一種新的交易類型,它是一種交易信封,可以更易于支持多種交易類型。以太坊一開始上主網時只有一種交易類型,帶有字段“To"(指定交易發送的目的地) 和“Data"(在交易中包含任意數據),這使得以太坊客戶端必須步調一致,確保在完全相同的時間做完全相同的變更。后來,隨著交易類型發生變化,在偽龍 (Spurious Dragon) 硬分叉時納入了 EIP-155 (重放攻擊的簡單防護),允許客戶端對字段有不同的解讀。EIP-2718 無法解決由 ?EIP-155 引入的復雜性,但可以防止未來再引入更多的復雜性,使得加入新的交易類型變得更簡單,例如 EIP-1559 類型的交易。
EIP-2929:提高狀態訪問操作碼的 Gas 開銷 (Gas cost increases for state access opcodes)
這份 EIP 提高了一筆交易在首次調用 SLOAD, CALL, BALANCE, EXT 和 SELFEDESTRUCT 時的 gas 開銷。但值得注意的是,對每個地址或存儲槽,這樣的高開銷僅發生在第一次觸發,隨后的多次調用每次僅消耗 100 gas。提高這些 gas 開銷一方面可以化解以太坊協議上仍保有的最大 DoS 攻擊向量的影響,另一方面是為以后實現無狀態以太坊限制見證數據的大小。
Goerli測試網將在以太坊總區塊難度達到10,079,000時切換,預計在8月12日前發生:8月11日消息,Goerli是以太坊合并之前第三個也是最后一個以太坊測試網,一旦以太坊總區塊難度達到10,079,000時,Goerli測試網就會正式切換,開發人員預計將在本周五(8月12日)之前的某個時間發生。
Framework Ventures聯合創始人Vance Spencer表示,如果Goerli測試網成功遷移到PoS,那么以太坊主網合并很可能會在9月中旬發生。(Blockworks)[2022/8/11 12:17:29]
EIP-2930:可選的訪問列表 (Optional access lists)
這份提案的目的是修正 EIP-2929 對現有合約帶來的破壞,并緩解 gas 開銷增大帶來的問題。此提案新增一個交易類型,它包含一個交易計劃會訪問的訪問列表 (內容是地址和存儲項鍵)。通過指定一個訪問列表,客戶端可以更容易處理交易,而 gas 消耗量也因此可以安全地降低。
相關閱讀:
《柏林硬分叉后的 gas 成本》
《以太坊柏林升級公告》
倫敦升級 (八月)
EIP-1559: Eth1.0 費用市場變更 (Fee market change for ETH1.0 chain)
EIP-1559 是以太坊史上最令期待的變更之一,也是倫敦升級里帶來最大變更的EIP。這份 EIP 將在網絡區塊里引入“基本費用 (basefee)",它會追蹤 gas 價格,這些價格來自網絡將接受的、基于對區塊空間需求的交易。這意味著錢包和用戶將可以更容易預測他們交易的價格。另外,EIP-1559 新增了一種交易類型,用戶可以指定他們愿意支付的最高限額,當他們把這個最高限額費用發送給礦工時,會獲得最高限額費用減去基本費用與礦工小費之和的差值退款。最后,這份 EIP 還將導致部分交易費被燒毀,這一點被社區的大部分人認為是以太坊網絡經濟上的一個重要改善舉措。
排名前列的以太坊巨鯨買入326萬枚GALA:1月13日消息,據以太坊巨鯨追蹤平臺 WhaleStats 發現,一位排名前列的以太坊巨鯨買入 326 萬枚 GALA,約合 113.7 萬美元。截至目前,SHIB 是該巨鯨賬戶里美元價值最大的 Token 頭寸(占到該巨鯨投資組合的 33.91%)。[2022/1/13 8:46:16]
EIP-3198: BASEFEE 操作碼 (BASEFEE opcode)
這份 EIP 是與 EIP-1559 搭配的。它只是簡單添加了一個 BASEFEE 操作碼,它返回的是執行交易所在的區塊的基本費用。這將使得智能合約可以在鏈上訪問這個值,這有助于提交欺詐證明和創建去信任的 gas 價格衍生品。
EIP-3529: 減少 gas 返還 (Reduction in refunds)
在倫敦引入的另一個重大變更是取消了操作碼SELFDESTRUCT 的 gas 返還和減少了操作碼 SSTORE 的 gas 返還。雖然設立返還的初衷是希望激勵開發者在可能的情況下清除狀態,然而現實是,這導致了Gas Token的出現,反而增加了狀態大小。利用這些返還的 gas,Gas Token 可以在 gas 價格很低的時候填滿狀態,然后在 gas 價格上升的時候獲得執行這些交易的返還。此外,gas 返還還會導致區塊執行時間的變化。EIP-3529 把"執行 gas 返還"從 50% 下調到最多 20%。這一變更將有助于抵消由 EIP-1559 引入的額外區塊大小變化,因為 EIP-1559 允許區塊使用的 gas 是現在 gas limit 的兩倍。
動態 | 當前以太坊未確認交易數為50502筆:據Etherscan.io數據顯示,以太坊未確認交易數為50502筆。以太坊全網算力為172.36TH/s,當前挖礦難度2189.48TH,交易處理能力12.4TPS。[2019/8/2]
EIP-3541: 拒絕以 0xEF 字節開頭的新地址 (Reject new contracts starting with the 0xEF byte)
這份 EIP 將使得倫敦升級后,以 0xEF 字節開頭的新合約就無法部署,它們會被保留下來以后作為識別符合 EIP-3540 語義的方式。EIP-3540 提出的 EVM 對象格式 (EVM Object Format, EOF) 是一種可擴展和版本化的 EVM 字節碼容器格式,會在部署時進行一次性驗證。因此,EIP-3541 是為以后更廣泛的 EVM 改良奠定基礎。
EIP-3554: 難度炸彈延遲至2021年12月 1 日 (Difficulty Bomb Delay to December 1st 2021)
EIP-3554 延遲難度炸彈,也以冰河時代為人所知。難度炸彈或冰河時代是以太坊引入的一種機制,在網絡過渡到權益證明時”凍結“挖礦。由于權益證明的過渡還未準備好,我們需要推遲炸彈的”爆炸“時間。這在過去已經進行過三次:在大都會(EIP-649)、君士坦丁堡 (EIP-1234) 和穆爾冰川 (EIP-2384)。
《倫敦升級概覽》
《倫敦主網升級公告及相關代碼變更》
動態 | 過去24小時以太坊總交易額較此前下降近18%:根據amberdata.io數據顯示,過去24小時內以太坊總交易額為209.37萬ETH,較此前數據下降17.89%;日活躍用戶量159058,用戶活躍下降3.77%;新增合約10442個,較此前數據下降20.73%;平均交易費用為10.46GWEI,上升0.37%;最活躍合約為BCACHAIN INITIAL TOKEN(BCAC);通證代幣交易總額為457884,較此前數據上升4.30%。[2019/4/1]
《為什么需要 1559》
《為什么我認為 EIP-1559 的區塊容量變化無須擔心》
《MEV 與 EIP-1559》
《從 MEV 視角分析 EIP-1559 下的交易打包市場》
《以太坊倫敦升級完成時 (第 37 期以太七日談)》
《EIP-3529:減少 GAS 返還》
信標鏈 Altair 升級 (十月)
Altair 是信標鏈的一次升級,它新增的功能包括:
支持輕客戶端的同步委員會
為了減少規范復雜性的激勵計算改革
修改證明獎勵,以提高激勵兼容性
單獨核算每個驗證者的怠工懲罰
懲罰參數更新為原定的懲罰水平
《Altair 主網升級公告》
《建模分析 Altair 升級的影響》
《Finalized no.24》
《Altair 升級講解 (第 30 期以太七日談)》
各期的《共識層進展更新》
Arrow Glacier 升級 (十二月)
Arrow Glacier 是另一個類似于 Muir Glacier 的網絡升級。它將只包括一份 EIP——把難度炸彈推遲到明年夏天,以防區塊鏈凍結,即“冰河時代 (ice age)"。
以太坊 2.0 路線圖演變過程
在 2018 年臺北的一次研討會上,以太坊的核心開發者做出了一個分三個階段的以太坊 2.0 路線圖,每個階段交付的內容是:
階段 0 將帶來信標鏈
在階段 1,會加入數據分片
在階段 2,在每個分片加入虛擬機,以在系統里實現計算。
到了 2020 年末,在信標鏈快可以啟動之前,盡管階段 1 的工作進展順利,但將在階段 1 引入的分片上實現計算功能的階段 2 仍然有很多未解決的問題。同時,rollup (即二層的擴容方案) 方面正發生非常快速的進展。多個團隊公布要上測試網,且取得令人鼓舞的早期成果。大約在這個時候,Vitalik 在 Ethereum Magicians 論壇上發表了長文,論述我們應該把短期和中期的擴容工作集中在 rollup 上。它們不僅會在階段 2 完成前上主網,還會是階段 1 的最大受益者。
同年 11 月,Mikhail Kalinin 發表的《可執行信標鏈 (Executable Beacon Chain)》,提出了目前的合并架構,帶出了幾點洞見:
信標鏈已經啟動了,現在可以作為共識引擎來使用;
Rollup 是擴展計算的最佳短期解決方案;
當前的 Eth1 客戶端是作為合并后執行層的最佳基礎;
搬到權益證明可以通過對當前運行的應用影響最小的方式實現
在文章里,Mikhail 提議直接把權益證明作為客戶端使用的新共識算法。
合并后的架構與合并過程
概括來說,合并后,客戶端將從根據 PoW 鏈轉為根據 PoS 鏈來決定以太坊的最新有效區塊。此外,客戶端大多數的功能,以及更重要的 EVM、它的狀態,和它是如何執行交易的,都保持不變。現在的 Eth1 和 Eth2 客戶端分別變成以太坊的執行層和共識層 (或叫做引擎)。這意味著 Eth1 或信標鏈客戶端的節點運行者將需要運行堆棧的“另一半”,以擁有一個完整的驗證節點。
在合并的過程中,信標節點將監測當前的 PoW 鏈,當有區塊的 Total Difficulty 觸達設定的 TERMINAL_TOTAL_DIFFICULTY (終結總難度) 時,該區塊就成為最后的 PoW 區塊,隨后的區塊都開始由信標鏈上的驗證者構建和證明。當這個區塊在信標鏈上被最終敲定時,合并就完成了。
實現合并的歷程與計劃
實現合并的三次標志性事件為:四月進行的 Rayonism 黑客松、十月進行的 Amphora 工作坊,以及十一月開啟的 Kintsugi 計劃。
為了驗證可執行信標鏈架構的可行性,在長達一個月的 Rayonism 黑客松里,客戶端團隊進行了原型設計,搭建了測試網 Nocturne,證明了可執行信標鏈是一個可行的架構。
到了十月,在 Amphora 工作坊活動中,客戶端團隊再次聚集在一起解決規范上懸而未決的問題。活動最后,客戶端團隊搭建了一個開發測試網,它跑完了所有客戶端組合的轉換過程,并對合并后的區塊做了最后敲定。
Amphora 活動后,經歷了四個短暫的開發測試網,開發者推出了 Kintsugi 測試網計劃。在十一月到十二月中旬這段期間,每周開發者會上線一個新的開發測試網,并基于上一個進行改進。在圣誕假期期間,已經上線了一個長期的公共測試網,并鼓勵大家參與測試。
目前實現工作已經完成了80%~90%,Arrow Glacier 把難度炸彈推遲到明年六月,也就是說明年六月前更多的是測試工作。
12月17日金色財經CEO安鑫鑫發內部信宣布卸任CEO一職,并表示金色財經業務已出售給新股東。未來金色財經將繼續由現有團隊運營,過渡期由原COO王瑜琨擔任CEO一職,直到新股東任命新的CEO為止.
1900/1/1 0:00:00隨著數字人民幣的推廣在 2021 年全面提速,無論其覆蓋城市、應用場景,還是錢包開通數量都迎來了大幅增長.
1900/1/1 0:00:00本文來源于孫銘律師于智堡年會的演講,主題為“各國對虛擬貨幣的監管政策現狀以及展望”。本文主要整理了演講中關于美國的部分.
1900/1/1 0:00:00談到 Web3.0,大多人會想到區塊鏈、token、元宇宙等等這些概念。毋庸置疑,Web3.0 包含了這一切,但我們該如何看清 Web3.0 的全貌呢?首先,我們需要將 Web 和 3.0 拆開.
1900/1/1 0:00:00本文梳理自 FTX US 總裁 Brett Harrison 在個人社交媒體平臺上的觀點,律動 BlockBeats 對其整理翻譯如下:以太坊 NFT 是由為特定 NFT 合集所創建的智能合約生.
1900/1/1 0:00:00FCA(Financial ConductAuthority)是英國金融行為監管局,成立于2013年4月1日,總部在英國倫敦.
1900/1/1 0:00:00