買以太坊 買以太坊
Ctrl+D 買以太坊
ads
首頁 > AVAX > Info

ICE:理解閃電網絡:構建比特幣的雙向支付通道_ALI

Author:

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

閃電網絡(Lightning Network)可能是比特幣區塊鏈上最受期待的創新(編者注:原文撰寫于 2016 年)。這種支付方案最早由 Joseph Poon 和 Tadge Dryja 在一年多以前提出,號稱能支持用戶之間在鏈下發送無限次的交易,而且成本極低 —— 還能借用比特幣網絡提供的安全性。

至少有三家公司 —— Poon 和 Dryja 的 Lightning、Blockstream 和 Blockchain 正在開發這種技術的實現。但在技術人員的小圈子之外,很少有人理解 “微支付的未來”如何能引爆比特幣的潛能。

在本系列文章里,Bitcoin Magazine?嘗試列舉閃電網絡最基礎的磚石,并展示這些東西如何能組合出閃電網絡這種即將到來的協議。

本系列的第一篇文章將列舉必要的模塊并展示這些模塊如何能組合起來創建 “智能合約”;這個概念可以用來理解閃電網絡的第一個前提:雙向的支付通道。

比特幣協議的核心是所謂的 “事務” 的概念;一般來說,一筆事務總是關聯著另一筆前序事務,并且可以用在未來的事務中。每筆事務都包括?輸入,指向?轉出?比特幣的地址;以及?輸出,指向?收到?比特幣的地址。此外,為了發送比特幣,輸入還必須滿足一些條件,比如要提供數字簽名來證明發送者具有輸入地址的 “所有權”。同時,輸出也會確立這些比特幣在日后使用時候的新條件,在?后序事務?發出的時候必須滿足。

FDIC主席:未能理解與加密相關風險加速了Signature Bank的倒閉:金色財經報道,美國聯邦存款保險公司(FDIC)主席 Martin J. Gruenberg 表示,管理不善是 Signature Bank 失敗的根本原因,未能理解與加密貨幣相關的風險加速了其倒閉的速度。此外,該銀行未能了解其與加密行業存款相關聯和依賴的風險,也未能了解其容易受到 2022 年末至 2023 年發生的加密行業動蕩蔓延的影響。

Gruenberg 稱,SVB 和 Signature Bank 的倒閉分別導致了 161 億美元和 24 億美元的損失。資產在 1000 億美元或以上的銀行值得特別關注,包括考慮長期債務要求以促進有序解決。[2023/5/16 15:06:17]

(譯者注:把比特幣想象成一張張有面額的支票,在使用時,支票自身給出了資金的來源,而在使用后又會形成新的支票。所以對每一張支票來說,都有形成這張支票的事務,也即是前序事務;而當這些支票被再次花用時,那筆事務就可稱為后序事務。)

閃電網絡的一個關鍵特性是,它是由或多或少的常規比特幣事務組成的。只是,這些事務一般不會在比特幣網絡里傳播。相反,這些事務都是用戶保存在節點本地的 —— 只不過,它們隨時可以放到比特幣網絡中傳播。

INX Digital Company宣布與BitGo合作推出機構級數字證券錢包管理解決方案:金色財經報道,加密交易所運營商INX Digital Company宣布與BitGo合作,為受監管的安全代幣推出了一個試點企業級錢包管理解決方案。[2023/5/4 14:41:01]

譯者注:如圖所示,比特幣就像支票一樣可以拆分,且其流轉會形成清晰的鏈條

閃電網絡所需的第二個模塊可能不需要太多解釋,因為它可以說是比特幣協議本身的存在理由:多重支付的防范措施。如果兩筆事務(或者說輸入)依賴于同一個輸出,那只有其中一筆才會得到整個網絡的確認。

謹記:即使尚未確認的事務之間發生了沖突,最終也只有一筆會得到確認。

閃電網絡的第三個模塊也很好理解:多簽名地址。(或者更廣義地說:P2SH 地址(腳本哈希值地址)。)

顧名思義,多簽名地址就是需要多個私鑰來 “解鎖”、使用比特幣的地址。多簽名地址的條件可以設置得很多樣。比如,可以要求在 3 把私鑰中要有 2 把參與,才能轉出比特幣;或者是其它的數量要求(比如 2/5,3/4,等等)。

閃電網絡一般使用 2-2 的多簽名要求。要從這樣的地址中轉出比特幣需要提供跟這兩把私鑰相關的兩個簽名,少一個都不行。

沙特機場地勤服務提供商SGS將在28個機場實施DocCerts區塊鏈管理解決方案:金色財經報道,沙特機場地勤服務提供商 SGS 將與區塊鏈公司 IR4LAB 合作,在沙特的 28 個機場實施 DocCerts 區塊鏈管理解決方案,適用于 SGS 提供地面服務的 28 個沙特阿拉伯機場頒發的所有培訓相關數字文件和地面服務設備許可證。[2023/2/9 11:56:45]

第四個模塊是時間鎖。時間鎖功能可以在一個輸出中放置一個鎖定條件,讓這些比特幣僅在未來某個時間之后才能花用(也即被用作一筆事務的輸入)。

有兩種類型的時間鎖:1)絕對時間鎖,叫做 CheckLockTimeVerify(CLTV);2)相對時間鎖,CheckSequenceVerify(CSV)。CLTV 會鎖定比特幣直至未來某個(可以說是)具體的具體:一個具體時間和日期,或者一個具體的區塊高度;而 CSV 只會使用相對時間。當一個 CVS 輸出上鏈之后,就要等待一定數量的區塊后,這筆輸出才能花用。

第五個,也是最后一個模塊 —— 密碼學 —— 也是比特幣本身最基礎的模塊。但在閃電網絡中,用法有所不同。

Billbitcoins為馬來西亞金融科技公司提供加密支付處理解決方案:區塊鏈開發公司HashCash Consultants宣布,其原生交易軟件Billbitcoins將為馬來西亞金融科技公司提供加密支付處理解決方案。該產品將設計為以法定貨幣和加密貨幣的形式處理付款。該解決方案的Beta版計劃在8月15日之前部署。(PRWeb)[2021/7/31 1:26:30]

簡而言之,一個 “秘密值” 是一個很長而且獨一無二的數字串,是幾乎不可能猜測出來的,一臺電腦暴力運算無數次也猜不出來。而通過特殊的計算,這個秘密值又可以 “打散” 成一個不同的數,叫做 “哈希值”。有趣之處正是這里:知道這個秘密值得人可以很容易地計算出其哈希值,但反之不成立,拿著哈希值你是反推不出那個秘密值的。

在比特幣區塊鏈上,這個機關又可以用在 “鎖定比特幣” 上(實際上,鎖定比特幣就是比特幣協議運行的方式)。舉個例子,你可以在一個輸出中包含一個哈希值,要求后序的事務只有包含該哈希值對應的秘密值才能花費這筆輸出。

在閃電網絡出現之前,就已經有 “支付通道” 的概念了。標準的支付通道是用于特定用途的,因此也很局限:它們都是單向的通道。Alice 可以在鏈下向 Bob 發起多比支付,但 Bob 沒法用同一個通道給 Alice 支付。

聲音 | 瑞士加密貨幣銀行SEBA高管:需要一個加密銀行讓人們理解區塊鏈在銀行部門的用例:據消息,瑞士加密貨幣銀行SEBA托管存儲和交易銀行業務負責人Phil Dettwiler表示,比特幣確實是一個投資機會,鑒于其估值不斷上升,他強調了比特幣作為價值儲存工具的資格。而Dettwiler被問及為什么在使用比特幣不需要銀行的情況下甚至需要加密銀行時,他表示,需要一個加密銀行來讓人們理解區塊鏈在銀行部門的用例。Phil Dettwiler說:“純粹的比特幣最大化主義者可能永遠不會進入一家銀行,但看看區塊鏈的三難困境:分散、可擴展性和安全性……我確實認為,為了增加安全,我正在減少一些權力下放,這是值得的,特別是在帶來便利的同時。”[2020/2/15]

而閃電網絡的一個關鍵特性就是, Poon 和 Dryja 提出的免信任的雙向支付通道。

要建立一個雙向的支付通道,參與的雙方都必須首先對一筆開啟通道事務達成共識。這筆開啟事務決定了他們倆各要在這個通道中存入多少比特幣。

假設 Alice 想給 Bob 發送 1 btc。因為他們倆都預期以后會有頻繁往來,他們決定開啟一個雙向的支付通道。(在通道里發送 1 btc 可能有點太大了,畢竟通道可能對小額支付更有用 —— 但也是完全可以做到的。)

要開啟這個通道,Alice 和 Bob 每人都發送 5 btc 到一個 2-2 的多簽名地址里。這就是 “通道開啟事務”。這個地址里面的錢,只有 Alice 和 Bob 簽名同一筆事務才能花用。

此外,Alice 和 Bot 都各自創建一個秘密值(也就是一串數字),然后交換哈希值。

現在,Alice 創建一筆通道開啟事務的后序事務,且這是一筆 “承諾事務”。在這筆承諾事務里,Alice 把 4 btc 發給她自己,而 6 btc 發送給第二個多簽名地址;這個多簽名地址更有趣:Bob 可以獨自解鎖這個地址,但是,要等(Alice 的事務上鏈后的) 1-00 個區塊之后,Bob 才能花里面的錢(這是一個相對時間鎖);Alice 也可以獨自打開這個地址,前提是她?也?擁有 Bob 給她的哈希值所對應的秘密值。(當然,Alice 是完全不知道這個秘密值的 —— 她只有 Bob 給她的哈希值 —— 所以只是表面上可以這么做而已。)(譯者注:即,這第二個多簽地址既有時間鎖,也有哈希鎖。)

Alice 簽名了她的承諾事務。但是她不會把這筆事務廣播出去!相反,她只會把這筆事務發給 Bob。

同時,Bob 也做剛好對稱的操作。他也創建一筆承諾事務,把 6 btc 發給自己,4btc 發給一個新的多簽地址。Alice 在等待 1000 個區塊后就可以獨自解鎖這個地址,或者 Bob 可以拿 Alice 的秘密值來解鎖這個地址。

Bob 簽名了這筆事務,然后發給了 Alice。

交換完了這些承諾事務和哈希值之后,他們再共同簽名并把那筆通道開啟事務廣播出去,使之能夠上鏈。現在,一個雙向的支付通道就開好了。

開啟通道之后,Alice 和 Bob 都可以簽名和廣播他們從地方那里得到的、部分有效的承諾事務。如果 Alice 廣播了(Bob 發給她的承諾事務),則 Bob 會立即得到 6 btc。如果 Bod 廣播了,則 Alice 會立即拿到 4 btc。但簽名和廣播事務的那個,必須等待 1000 個區塊才能解鎖那個后序的多簽名地址,把剩余的比特幣拿走。

不過,這就是支付通道的關鍵技巧:不去簽名和廣播他們得到的承諾交易。

(譯者注:先交互承諾事務,再廣播通道開啟事務,是為了避免對手欺詐;而獲得承諾事務之后,不必廣播,也可以獲得安全性保證了。)

后來,Bob 想給 Alice 發回 1 btc,他們想更新這個通道的狀態,使之回到 5:5 的狀態。要實現這一點,Alice 和 Bob 需要做兩件事。

首先,雙方都要把上面所講的流程再做一遍(除了開啟事務的那部分,因為已經記錄在鏈上了)。這一次,Alice 和 Bob 都把 5 btc 分配給對方,都把 5 btc 分配給那個多簽名地址。這些后續的多簽名地址的條件是類似的,只不過,他們都需要生成?新的?秘密值:Alice 和 Bob 都要提供?新的?哈希值。他們都簽名自己的新承諾事務,并發送給對方。

其次,Alice 和 Bob 都把他們的?第一個?秘密值(用在第一次承諾事務中的那個)交給對方。

這時候,Alice 和 Bob 都能簽名和廣播他們最新得到的這筆承諾事務。他們的對手會立即獲得 5 btc,而廣播這自己則必須等待 1000 個區塊。就這樣,通道的狀態更新了。

但是,有什么能阻止 Bob 廣播舊的承諾事務呢?那筆承諾事務會給他分配 6 btc,比 5 btc 要多 ……

阻止 Bob 的,當然就是他的第一個秘密值,也就是他已經給了 Alice 的那個秘密值。

因為,這時候 Bob 已經無法隨心所欲地簽名和廣播更老的那筆承諾事務了,因為 Alice 已經知道了 Bob 的第一個秘密值。如果 Bob 要簽名和廣播(Alice 給他的那筆)更老的承諾事務,他會立即把 4 btc 發給 Alice …… 且他自己要等 1000 個區塊才能申領,但是,Alice 已經知道他的秘密值了,所以她可以利用這段時間先發制人,直接把剩下的 6 btc 也提走!

而且,因為 Bob 也有了 Alice 的秘密值,所以對 Bob 來說同樣如此!要是 Alice 想簽名和廣播舊的承諾事務,Bob 就可以偷走她放在通道里所有的 btc 了!

這就意味著 Alice 和 Bob 都要重組的激勵不去耍小手段,只廣播最近的狀態。

好了,有了雙向的支付通道之后,我們要把它拓展成一個支付網絡。這就是我們第二篇的主題。

感謝 Rusty Russell 和 Joseph Poon 的專門反饋。

(完)

Tags:ICEALILICALICEiCEX價格代幣化基金Realio創始人:花三年時My Neighbor Alice

AVAX
ROLL:Rollup擴容方案能否后來居上?_以太坊幣怎么挖礦賺錢

過去六個月以來以太坊上最受關注的事件便是交易需求的爆炸式增長。交易費用已經創下歷史新高,許多日常用戶現在都因為費用太高而沒有使用以太坊。 以美元計算的 ETH 交易費.

1900/1/1 0:00:00
NBS:證監會科技局姚前:基于區塊鏈的OTC衍生品金融基礎設施_區塊鏈

為了支持高效的場外衍生品交易匹配、確認、執行、清算和報告等,需要在現有標準化工作的基礎上,進一步構建一個可自動化執行的統一、開放、高效、合規、穩健的場外衍生品基礎設施平臺.

1900/1/1 0:00:00
ETHE:USDT:瘋狂的優雅_Etherean Socks

盡管埃隆·馬斯克(Elon Musk)“朝秦暮楚”的態度引發了加密市場過山車般的動蕩,但世界上市值最大的穩定通證 Tether(USDT)仍在繼續增長.

1900/1/1 0:00:00
以太坊:V神提出新型密鑰分享方案:可用于腦錢包和社交恢復設計應用_VIT

注:原文作者是以太坊聯合創始人Vitalik Buterin,在這篇文章中,他描述了一種新型的M-of-N密鑰分享方案,并提出了腦錢包和社交恢復設計的兩種應用案例.

1900/1/1 0:00:00
KEN:科普:區塊鏈能讓盜版問題得到根治嗎?_TOKE

從十八世紀初第一部版權法誕生到現在,已經幾百年過去了,但隨著時代一起進步的,不僅是版權法,還有屢禁不止的盜版.

1900/1/1 0:00:00
AVE:從借貸到社交 Aave計劃今年發布“以太坊上的Twitter”_TWIN

DeFi 借貸協議 Aave 的創始人告訴 Decrypt,Aave 今年將推出一款基于以太坊的 Twitter 替代方案.

1900/1/1 0:00:00
ads