📜 [專欄新文章] 從 Rollups 來聊聊以太坊 Layer2 的演進
✍️ Kimi Wu
📥 歡迎投稿: https://medium.com/taipei-ethereum-meetup #徵技術分享文 #使用心得 #教學文 #medium
Photo by Clark Van Der Beken on Unsplash
去年 Defi summer 的熱潮後,以太上 Defi 應用呈現爆炸性成長,造就高昂的交易手續費,為了有更快的交易速度及可負擔的交易費用,人們對側鏈、Layer2 的需求更加強烈。Rollups 是 Layer2 的一種技術,在今年相當熱門,幾個耕耘已久的專案 zkSync、Optimism、Arbitrum 等也開始廣為人知。今天想來聊聊以太坊上 Layer2 技術的演進。
State Channel
state channel 最一開始是建立在 Bitcoin 上,最廣為人知的就是 lightning network。簡單來說,就是兩方在私下建立一條可以互相轉帳的通道,轉帳完畢後把通道關閉,接著將交易後的狀態更新到鏈上。若交易一筆後即關閉通道,那交易成本就跟在鏈上一樣,所以在實務上,通道一直開著(或是一段時間),交易數筆、數百筆後再上鏈更新狀態,藉此平均每筆的交易手續費就大幅降低。也因為只需通道雙方驗證交易內容,交易速度能大幅提升,讓小額支付能夠實現,就不需等10分鐘(Bitcoin)後交易才會被打包,甚至要等6個區塊的時間。而最早在以太上的 state channel 是 Raiden。
對於 Raiden 技術有興趣的可以參考這篇文章。
Plasma
Plasma 於2017年8月由 V 跟 Joseph Poon (Lightning Network的創始人之一)所提出,概念上是可以有鏈中鏈中鏈(就是Layer2 → Layer3 → … LayerN),藉此可達到百萬級甚至更高的交易量,不過概念太美好,沒人知道怎麼實作。
隔年1月 V 提出了 Plasma 的第一個版本 Plasma MVP,是以 UTXOs 模型的設計,接著3月提出了第二個版本 Plasma Cash,同年(2018)Plasma 的提案數呈現著爆炸性的成長(絕大部分都是基於 Plasma MVP 跟 Plasma Cash 做改進)(如下圖),強大的社群力量,讓大部分關鍵的問題在同年年底都找到了解答。也為之後的 Optimistic Rollup 打下了基礎。
而較著名的開發團隊,除了 EF 出來的 Plasma Group 外,還有 OmiseGo 跟 Matic(現在的 Polygon)。
對 Plasma 技術有興趣的,可以參考這篇、這篇跟這篇
https://ethresear.ch/t/plasma-world-map-the-hitchhiker-s-guide-to-the-plasma/4333
Plasma 看似一切美好,但因為資料的可取得性(data availability)的問題,使得在使用者體驗上有點糟糕。
Plasma 的所有交易資料都在 Plasma 鏈上,而 Plasma 鏈的礦工(即operator)只需繳交 Merkle root 到 L1 的合約作公證就好。因此若 operator 作惡,在 Plasma 鏈上交易者,就需有能力證明 operator 作惡。
在 Plasma 設計中有”所有者”的概念(UTXOs 的設計中,收款者需要到拿送款者的轉出證明,才能動用這筆款項,轉出證明只有收款人會擁有),如果該所有者不關心自己的資產,就可能造成資產無效的結果(account-based 的設計,若你不理你的帳號,別人一樣可以轉帳到你的戶頭中)。因此每個交易者須有能力自行提出證明,無法委託第三方。
而要證明這件事,用戶需要把 Plasma 鏈上的交易都下載下來,才能證明 operator 做了一件不合法的行為,也才能產生詐欺證明(fraud proof)到 L1 上的合約來證明 operator 作惡。而這個送出的詐欺證明,必需要被確保可以安全地送到 L1 上的合約被執行,因此需要有一段挑戰期,讓使用者可以下載及驗證資料(或是網路塞車造成詐欺證明無法被合約執行)。
題外話,Eth 2.0 light client利用了 ECC (Error Correction Code)的原理,所以只需要部分資料就可以驗證正確性。
Rollups
同年(2018) 9月,在支線專注隱私性的開發的 Barry Whitehat 提出了 zk Rollup,隨後 V 也在以太坊研究員論壇發了一篇文章,解釋 zk Rollup 是如何運作的,並以On-chain scaling to potentially ~500 tx/sec through mass tx validation 為標題,也因此開啟了 Layer2 新的一頁。隔年(2019)三月,Matter Labs 獲得了 EF 的 grant 將 zk Rollup 產品化,也就是大家所知的 zkSync。
所謂的 rollups,一樣是在 Layer2 上做交易,不同的是 L1 上會記錄每一筆的交易紀錄。什麼!如果每一筆交易紀錄都上鏈,跟一般 L1 交易有什麼不同?想了解細節可以看這篇。簡單來說,在合約裡用了一顆樹來記錄每個帳號的狀態,樹的第幾片葉子(index)代表一個帳號地址,因此帳號就從20 bytes 的地址變成了幾個 bytes 的 index。以 ZK Rollups 來說,交易都是在 Layer2 被驗證過的,所以簽章資訊(65 bytes)也不用上鏈,Optimistic Rollups 會利用簽章聚合的技術,數百個簽章最終會被聚合成一個。因此,交易資料從原本100多 bytes 變成了10幾個 bytes。因為交易紀錄都 ”放上鏈“,資料可取得性也就不是問題了。
”放上鏈”指的是利用 calldata 的方式放在鏈上,並非一般認知的寫進合約裡。非0值的 calldata 每 byte 需要耗費 16 gas,而合約寫進一個 32bytes 的資料需要花 20,000(新增) or 5,000(修改) gas,相當於每個 byte 的成本為625 or 156 gas,約為 calldata 的 40 or 10倍。
同年(2019)六月 John Adler 在以太坊研究者論壇提出了Minimal Viable Merged Consensus,也就是大家熟知的 Optimistic Rollups 的原型,接著 Plasma Group 基於John Adler 的提案,提出了 OVM,從此 Layer2 上除了單純的轉帳外,還可以執行合約,也奠定了 Rollups 在 Layer2 的地位,開啟 rollups 的新世代。
StarkWare 團隊建立了可評估的數學模型,驗證了 calldata 的成本從64 gas 降到 16 gas並不會對鏈的安全造成危害,提出了 EIP-2028(在 Istanbul 上線),也是推動 rollups 可行性的重要一環。
Validity Proof v.s. Fraud Proof
Optimistic Rollups 跟 ZK Rollups 最近有很多文章在介紹跟比較,這邊就不贅述。這邊想聊的是資料的有效性,這篇文章解釋地很好,這裏擷取部分敘述。ZK Rollups 保證了上鏈的資料都是正確的,資料必須被驗證過是合法的(例如沒有被雙花)才會改變使用者的狀態(例如 balance),跟現在各個主鏈的設計是一樣的,稱作有效性證明(Validity Proof),這種設計假設大家都是壞人,要通過驗證才會相信你,確認資料是百分之百的正確聽起來很理所當然,但是背後要維護資料的正確性,需要相當高的成本。
Optimistic Rollups 則是相反,假設大家都是好人,送上鏈的交易都接受,當發現有人作弊,再靠檢舉機制來更正狀態,這稱作詐欺證明(Fraud Proof)。這樣的機制系統維護成本較低(L1 上不需要驗證每一筆資料的正確性),但需要多一個爪耙子的角色來維護系統的安全,也就多一個系統潛在的風險。而要確保爪耙子有足過的時間反應,就不能讓使用者即時地離開系統,這是 Optimistic Rollups 最被詬病的一點,提款要等七天(現在有第三方流動性提供者,使用者可以請第三方流動性提供者預付使用者的提款。使用者支付手續費來換取快速提款的服務,而流動性提供者則承擔資產鎖住七天的風險來賺取手續費。不過在 protocol 層以安全性為主要考量,還是需要較長的挑戰期)。
ZK Rollups 的實作上,也有數個小時的提款期,不過那是基於成本考量,而非安全性。
此外對照於 Plasma, rollups 的設計是 account-based,交易也都公開在鏈上,每個人都可以參與監督及提出詐欺證明。
ZK Rollups v.s. Optimistic Rollups
ZK Rollups 從資料的有效性來看勝過 Optimistic Rollups,離開系統時不需要額外的挑戰期,能即時提款離開系統,不過付出的代價就是交易延遲上鏈。因為產生 zkp 證明需要龐大的運算量,產生一次證明,大約需要10 ~ 20分鐘,所以說在 Layer2 上做一筆交易,10分鐘後你的交易才是有 L1 的安全性。
為了能盡早得知發出的交易是否完成,實作上會把完成的交易先丟上鏈,等zkp 證明產生後再上鏈驗證其正確性,若驗證成功,則交易視同有 L1 的安全性。
但是在通用性上,Optimistic Rollups 沒有複雜的 zkp 電路的限制,對於合約的支援度上更好,而且 zkp(SNAKRKs)在使用前需要一個盛大的啟用典禮(trusted setup ceremony)。
zkSync
zkSync 1.0 在去年(2020) 六月上線,因為不能執行合約,使用的專案並不多。同年的年初,Matter Labs 已經默默在開發一種新語言 Zinc,是可以在 zkSync 上開發合約的語言。年底,與 Defi 專案 Curve 合作,發表了在 zkSync上可以跑基本版的 Curve(兩幣交換)。今年(2021)三月,Matter Labs 發表了令人振奮的消息,zkSync 支援 EVM!只需要部分修改現有的合約就可以部署到 zkSync 上,測試網今年五月已經上線,主網預計8月上線。不過目前測試網上的交易量非常地少,相信在初期還是有相當多問題或是困難,以短期來看,Optimistic Rollups 陣營的速度跟支援度略勝一籌,不過個人相信長期會是 ZK Rollups 的世代(私心認為 lol),但最終還是由生態系的大小來決定贏家。
在 ZK 這個陣線上有延伸出不同的設計,為了加快速度及減少上鏈成本,StarkWare 提出了 Validium 的概念,資料不上鏈但使用 zkp 確保資料的正確性,像是 StarkWare 的 Volition 跟 Matter Labs 的 zkPorter 都是同樣概念的實作,不過不是本篇的重點,就不多解釋。
ETH 2
V在2020年10月提出了 A Rollup Centric Ethereum,rollup 也因此進到 Eth2 的規劃中。Eth2 的設計中 shard chain 是資料層,而在 phase 2 後才有執行層(也就是才能執行合約),V 的提案 除了讓 shard chain 當資料層外,也會內建 rollups 的邏輯。至於會採用哪種 rollups 目前沒看到結論,不過 V 本人是傾向 ZK Rollups。如果成真,那未來數百個 rollups 之間的溝通,將會是另一個挑戰 。
專案比較
ZK Rollups 有目前這幾個較知名的專案: zkSync(Matter Labs)、 Hermez(Iden3)、 Loopring(Loopring)、 StarkNet(StarkWare)跟 Aztec(Aztec)。
Optimistic Rollups 目前幾個專案 Optimism(Optimisim,前Plasma Group 成員)、 Arbitrum(Offchain Labs)、 Fuel(Fuel)。
這是目前幾大 rollups 的生態系(今年3月時的統計),比較值得一提的是,Uniswap 團隊因為社群的投票,也將會在 Arbitrum 上面部署,對於整個 Arbitrum 的生態,相信有很大的影響。
https://www.chainnews.com/articles/872971457746.htm
感謝 NIC Lin 及 Chih-Cheng Liang 的審查跟建議。若有錯誤或不同觀點,歡迎指教。
從 Rollups 來聊聊以太坊 Layer2 的演進 was originally published in Taipei Ethereum Meetup on Medium, where people are continuing the conversation by highlighting and responding to this story.
👏 歡迎轉載分享鼓掌
同時也有1部Youtube影片,追蹤數超過12萬的網紅GodJJ,也在其Youtube影片中提到,我們今天打戰術:情況不對先保隱分 人只要不斷的洗隱分,遲早會上去的 d(`・∀・)b 實況日期:2021年05月05日 感謝您收看GodJJ的實況精華 – J起來!! 喜歡的話記得順手按個訂閱唷 https://bit.ly/3gPX0De Facebook 請往這走 - https://www...
「lol隱分2021」的推薦目錄:
- 關於lol隱分2021 在 Taipei Ethereum Meetup Facebook 的最佳解答
- 關於lol隱分2021 在 GodJJ Youtube 的最佳貼文
- 關於lol隱分2021 在 [問題] 積分和隱分的問題- 看板LoL - 批踢踢實業坊 的評價
- 關於lol隱分2021 在 積分隱分疑問 - 英雄聯盟板 | Dcard 的評價
- 關於lol隱分2021 在 [問題] 戰績網計算隱分的方式是不是有調整提高? | PTT 問答 的評價
- 關於lol隱分2021 在 隱藏積分是什麼、lol隱分2021在PTT/mobile01評價與討論 的評價
- 關於lol隱分2021 在 隱藏積分是什麼、lol隱分2021在PTT/mobile01評價與討論 的評價
- 關於lol隱分2021 在 lol隱分查詢2020在PTT/Dcard完整相關資訊 - 健康急診室 的評價
- 關於lol隱分2021 在 lol隱分查詢2020在PTT/Dcard完整相關資訊 - 健康急診室 的評價
- 關於lol隱分2021 在 lol隱分在PTT/Dcard完整相關資訊 - 幸福屋 的評價
- 關於lol隱分2021 在 lol隱分在PTT/Dcard完整相關資訊 - 幸福屋 的評價
- 關於lol隱分2021 在 [問題] 積分和隱分的問題- 英雄聯盟 - PTT遊戲區 的評價
- 關於lol隱分2021 在 lol隱分對照2021 :: 全台民宿& 旅館情報網 的評價
- 關於lol隱分2021 在 LoL - [閒聊] S11積分贏一場加多少分數算正常 - PTT生活資訊討論 的評價
- 關於lol隱分2021 在 [情報] 開發日誌:2021 季前積分改動- 看板LoL | PTT遊戲區 的評價
- 關於lol隱分2021 在 [問題] 積分和隱分的問題 - Mo PTT 鄉公所 的評價
- 關於lol隱分2021 在 【Nye】爬分精華(上) 低隱分帳號一個禮拜從銀排爬上白金? 的評價
- 關於lol隱分2021 在 lol隱分2020在PTT/Dcard完整相關資訊 - 數位感 的評價
- 關於lol隱分2021 在 lol隱分2020在PTT/Dcard完整相關資訊 - 數位感 的評價
- 關於lol隱分2021 在 lol積分加分2021在PTT/Dcard完整相關資訊 的評價
- 關於lol隱分2021 在 lol積分加分2021在PTT/Dcard完整相關資訊 的評價
lol隱分2021 在 GodJJ Youtube 的最佳貼文
我們今天打戰術:情況不對先保隱分
人只要不斷的洗隱分,遲早會上去的 d(`・∀・)b
實況日期:2021年05月05日
感謝您收看GodJJ的實況精華 – J起來!!
喜歡的話記得順手按個訂閱唷 https://bit.ly/3gPX0De
Facebook 請往這走 - https://www.facebook.com/GodJJLOL/
★-:+:-:+:-:+:-:+:-:+:-:+:-:+:-:+:-:+:-:+:-★
想看更多的J師傅:
訂閱【J群玩家】 http://bit.ly/389wdfh
訂閱【VODJJ】 https://bit.ly/3l3Pwxm
魔法少女接接平常也會在Twitch開實況哦
請多follow實況台 - https://www.twitch.tv/godjj
★-:+:-:+:-:+:-:+:-:+:-:+:-:+:-:+:-:+:-:+:-★
#最新戰術11111分推 #兄弟們吃漢堡囉
lol隱分2021 在 積分隱分疑問 - 英雄聯盟板 | Dcard 的推薦與評價
積分隱分疑問. 英雄聯盟. 2021年11月19日23:48. 單雙第一場打出來銅牌但是彈性第一場打出來銀牌⋯? 好好奇喔為什麼而且我彈性第一場打超爛的差不多1殺7死ಥ_ಥ 也不是 ... ... <看更多>
lol隱分2021 在 [問題] 戰績網計算隱分的方式是不是有調整提高? | PTT 問答 的推薦與評價
看板: lol, 時間: 2021年01月03日, 作者: nicholas0406 ... 好像不能查詢不知什麼原因是網站掛掉還是說在調整隱藏分數的計算方式我的問題就是關於這個戰績網對於隱藏 ... ... <看更多>
lol隱分2021 在 [問題] 積分和隱分的問題- 看板LoL - 批踢踢實業坊 的推薦與評價
大家好 這邊想請教一些積分跟隱分的問題
我個人的帳號是S5辦的
S5 S6很菜的時候打過積分 但是都是10場打完都沒打
那時候就銀4銀5
後面S7~S10都沒打積分 所以應該算乾淨帳號?
這季開季開始打積分
從鐵二開始一路爬到現在金三
先說說現在的瓶頸
上禮拜一我就打到金四了
並且隔天以7勝2敗的速度爬到金三
那時候是一場+22分左右 輸-9分還10分
結果上金三後一路輸輸贏贏
偏偏在一個剛上去的位子所以來回金三金四好幾次
我自己本來是不信什麼連勝組連敗組
但是我前天金三一路六連敗輸到金四20分
隔天再以六連勝回金三 我自己都不信能這樣狂輸狂贏==
而且我每場都會稽察隊友
在連敗組的時候 只有我一個人勝率是超過54%
其他人都是不到50% 甚至有上季白金鑽石只有20幾%勝率
擺明就是買來的
連勝組的時候隊友都是勝率超過50% 了不起就一個低於50
結果金三金四來回跳好幾次之後
現在贏一場+15左右 輸一場也是-15左右
所以一贏一輸就打平了
想請教的問題是
1.如果我放置一段時間再爬的話 加減的分數會不會比較適合爬分
2.看以前的文章說在選角時看到不利就跳 這個現在也適用?
3.如果我再這樣金三金四來回跳 會不會加更少扣更多?
4.隱分是怎麼運作的 是當下馬上根據隱分安排隊友
還是是固定一個時間(可能一週?)系統紀錄一次隱分
這段時間你的隊友對手都是固定同一階
然後下次新一輪刷新的時間會再根據新的隱分安排隊友
雖然還有個人狀態的問題
但是我不怎麼信以超過70%的勝率從金四爬到金三
會被以隱分過低的原因全安排一些勝率不到50%甚至30%的隊友導致連敗
所以才感覺是不是因為我原本的隱分還在銀一到金四
導致系統需要分配我一些牌位相近 但是隱分比較低的隊友
需要等刷新之類的才會安排符合現在牌位等級的
5.問個跟上面比較無關的 現在積分還有分蓋倫區努努區之類的嗎
印象中以前有分 不過現在找不到相關顯示
但是我這區的金牌4~1加起來又不到幾百人
這遊戲再過氣也不會人這麼少吧 是現在不顯示區了嗎
以上 先感謝各位回答
-----
Sent from JPTT on my Samsung SM-N9750.
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 111.71.44.150 (臺灣)
※ 文章網址: https://www.ptt.cc/bbs/LoL/M.1614621121.A.999.html
想請問一下像這種自己對手牌位都比自己低的場不是加比較少嗎 怎會比較多
※ 編輯: nelson9461 (111.71.44.150 臺灣), 03/02/2021 02:05:31
另外還想請問一下 第三點你說趨於平衡是指現在這樣嗎 看到板上有人提到自己是一場加不到十分但是輸一場就扣25的
※ 編輯: nelson9461 (111.71.44.150 臺灣), 03/02/2021 02:18:27
※ 編輯: nelson9461 (111.71.44.150 臺灣), 03/02/2021 02:20:05
輸一場扣到0 再輸一場就下去變75分 然後又贏兩場上來 又剛好在10分的位子 一直來回 不過也是我自己沒有10分後贏下來變30 50分讓他有餘地可以扣
... <看更多>