一文了解以太坊跨鏈DeFi項目RenVM的工作原理
編者按:本文來自以太坊愛好者(ID:ethfans)編者按:本文來自
以太坊愛好者(ID:ethfans)
以太坊愛好者(ID:ethfans)
編者按:本文來自
以太坊愛好者(ID:ethfans)
以太坊愛好者(ID:ethfans)
編者按:本文來自
以太坊愛好者(ID:ethfans)
RenVM 是一種功能豐富的去中心化託管方,具有免信任性和免許可性。
,作者:Loong,翻譯&校對:閔敏& 阿劍,Odaily經授權轉載。
首先,我們來介紹一下RenVM 及其功能,然後來看一下互操作性流程。就本文而言,我們將以在以太坊上鑄造代表BTC 的ERC20 代幣為例,不過具體流程可以套用到所有跨鏈資產上。 RenVM 目前支持BTC 、BCH 和Zcash ,並且能夠支持任何使用ECDSA 私鑰(幾乎所有ECDSA 私鑰)的資產。作為參考,RenVM 主網的ERC20 命名方式如下:
RenVM 是一種功能豐富的去中心化託管方,具有免信任性和免許可性。
以太坊上代表ZEC 的ERC20 代幣被稱為renZEC
RenVM 是一種功能豐富的去中心化託管方,具有免信任性和免許可性。
RenVM 是什麼?
圖片描述
RenVM 是一種功能豐富的去中心化託管方,具有免信任性和免許可性。
我們來看一下另一種相似的模型:WBTC 。
圖片描述
從技術層面來看,WBTC 和RenVM 幾乎沒有相似之處,不過WBTC 可以幫助我們理解RenVM 。 WBTC 的運作流程是:符合資格的實體將BTC 交由中心化託管方BitGo ,BitGo 將這筆BTC 存入冷錢包中,並根據錢包的餘額增長情況在以太坊區塊鏈上1:1 鑄造代表BTC 的ERC20 代幣(即,WBTC)。賣家會在公開市場上出售這些WBTC 。總的來說,BitGo 將收到的BTC 存儲起來,並在以太坊區塊鏈上1:1 鑄造WBTC 。
RenVM 的運作流程幾乎相同:將收到的BTC 存儲起來,並在以太坊區塊鏈上1:1 鑄造renBTC 。區別在於RenVM 的速度更快一點。
圖片描述
- RenVM 是如何將BTC 轉移到以太坊上的 -
三個重要區別
RenVM 沒有將BTC 存儲在中心化或可信的託管機構中,而是存儲在一個由去中心化節點(叫做“Darknode”)組成的網絡上。一旦RenVM 收到BTC ,就會立即以1:1 的比例鑄造出代表BTC 的ERC20 代幣,供個人和DeFi 應用使用。一個重要的細微差別是,這種價值交換(鑄造和銷毀)是流動的;每分鐘可以轉移任意數量的資產上百次,不需要依靠中心化機構、賣家、簽署人,也不存在任何摩擦,從而實現跨鏈數字資產的無縫轉移(即,互操作性)。
2. 可組合性
3. 去中心化、免信任和免許可
圖片描述
RenVM 中使用的ECDSA 私鑰是完全私密的,甚至對節點本身同樣保密。 RenVM 通過一種安全多方計算算法使用ECDSA 私鑰生成並簽署數據。沒人能阻止用戶使用他們的BTC 來鑄造renBTC、銷毀他們的renBTC 來取回BTC ,或是隨心所欲地使用他們的renBTC 。
好吧,我現在知道RenVM 是什麼了,但是跨鏈轉賬是如何實現的?
通過RenVM 在以太坊上鑄造的資產都是1:1 錨定某個資產的ERC20 代幣。這就意味著,如果你持有1 renBTC (一種ERC20 代幣),你隨時都可以用它來贖回1 BTC 。通過RenVM 鑄造的ERC20 代幣直接錨定原有資產的供應量。所以說,renBTC 不是一種合成資產,不依賴於清算機制,也不是以太坊上錨定BTC 價格的ERC20 代幣,而是在以太坊上1:1 代表BTC 的ERC20 代幣,可以隨時用來贖回等量的BTC 。
在以太坊上鑄造BTC
- 將BTC 鎖入RenVM ,然後在以太坊上鑄造renBTC -
圖片描述
你只需要將BTC 發送到某個BTC 地址,即可鑄造renBTC :
2)Bob 向這個地址發送1 BTC ,並等待6 個區塊確認。積累到6 個區塊確認之後,RenVM 會立即使用其秘密ECDSA 私鑰之一來生成一個鑄幣簽名。 Bob 獲得這個簽名之後就可鑄造1 renBTC (需支付RenVM 費用),renBTC 會發送至Bob 指定的Web 3.0 錢包(例如,MetaMask)。注:這些步驟通常由UI 自動執行,不需要Bob 進行具體操作。
圖片描述
3)現在,Bob 獲得了1 renBTC ,可以隨心所欲地在任何DeFi 應用中使用它了。他可以用這個renBTC 來貸款,在Uniswap 上交易,進行保證金交易。請注意,renBTC 是完全同質化的,可以分割成任意數量,與其他人鑄造的renBTC 並無區別。
從以太坊上贖回BTC圖片描述- 指定BTC 地址,銷毀renBTC ,然後BTC 就會被歸還至該地址 -


