當前位置:首頁 > 物聯網 > 區(qū)塊鏈
[導讀] 眾所周知,礦工比特幣挖礦收益包含兩部分,第一個是區(qū)塊獎勵也就是我們平時耳熟能詳的挖比特幣;第二個是交易手續(xù)費。這一塊,就很多礦工不太清楚了,礦工經常會有疑問,如果打空塊,是不是就收不到交易手續(xù)費

眾所周知,礦工比特幣挖礦收益包含兩部分,第一個是區(qū)塊獎勵也就是我們平時耳熟能詳的挖比特幣;第二個是交易手續(xù)費。這一塊,就很多礦工不太清楚了,礦工經常會有疑問,如果打空塊,是不是就收不到交易手續(xù)費,為什么有礦池會不要手續(xù)費來打空塊呢?所以下面我們來談談挖空塊原理。

POW挖礦原理

工作量證明POW挖礦就是區(qū)塊鏈生成新的區(qū)塊的過程。包括BTC、BCH、ETH、LTC……在內,POW挖礦都是按以下邏輯來。

挖礦是這樣的,系統會給出一個目標值,這是一個數,比如前面有18個零。挖礦就是找出一個小于這個目標值的隨機數,比如前面有19個零。找到了,就挖到了區(qū)塊。關鍵字:隨機數。關鍵問題:這個隨機是怎么計算?

這個隨機數是對礦池對最新高度的區(qū)塊鏈進行哈希得來的。關鍵字:最新高度。關鍵問題:什么是最新高度?

現在有一個礦池挖到了一個區(qū)塊,并且廣播出去,我們假定這個區(qū)塊高度是50W高度。接下來所有礦池就會在這個50W高度后面繼續(xù)挖礦,具體動作是礦池先組裝一個新的區(qū)塊,這個新的區(qū)塊包含了“區(qū)塊頭”和“填充交易的區(qū)塊體”。區(qū)塊頭里有兩個需要特別說明的,第一個是父塊哈希值,這里是50W高度的hash值;第二個是Nonce,這是一個數,一個可以調整的數,從0開始。

組裝好這個新的區(qū)塊后,礦機就對這個新區(qū)塊(“50W+1”高度)加上前面50W高度的區(qū)塊進行哈希。這個新的區(qū)塊就是上面的“最新高度”。

礦機執(zhí)行哈希一次,就得到一個哈希值,這是一個二進制數。礦池會拿這個值和目標值對比,如果小于目標值,就恭喜你,成功挖到礦,否則就將Nonce加1,再哈希,再對比,……

顯然一臺礦機來哈希,你要試出滿足目標值的Nounce值,那真是要慢死了。但礦池可以將不同的Nounce劃分給不同的礦機來試。比如礦池一共有1000臺礦機,將0到1000,給第1臺試;10001到2000給第2臺試……這就是挖礦的并行。

POW挖空塊的原理

針對上面50W高度和最新高度區(qū)塊,我們需要進一步詳說。在礦池在對最新高度區(qū)塊鏈進行挖礦之前,是要對50W高度這個區(qū)塊進行驗證的。如果驗證成功,在“50W+1”這個新組裝的區(qū)塊高度上挖礦才是合法的,如果50W高度是一個非法的區(qū)塊,那所有的礦池是要回到“50W”高度去挖礦的。

但驗證區(qū)塊是需要時間的,因為各個礦池的軟硬件不同,我們假定一個平均時間,10秒鐘驗證1M的區(qū)塊。在驗證結束之前,礦池是無法確認這個區(qū)塊是不是合法,也就無法確認是否應該添加“50W+1”高度的最新區(qū)塊。

而組裝一個最新高度的區(qū)塊也是需要時間的,拿到一個區(qū)塊模板開始組裝,往里填寫父區(qū)塊哈希值和在內存池里挑選交易填充進區(qū)塊體,這都是需要時間,我們假定需要0.1秒。

在驗證“50W”高度區(qū)塊時,和填充交易進“50W+1”區(qū)塊里,有一個提前,填充的交易是絕對不能和50W高度里已經打包的交易相重的。不然你這個最新高度區(qū)塊就會是非法的。

而“50W”高度這個區(qū)塊從挖出到廣播到所有的礦池中也是需要時間的,廣播區(qū)塊有分兩步。第一步是廣播區(qū)塊頭;第二步是廣播區(qū)塊體。區(qū)塊體非常小,只有80字節(jié),比一筆交易還小,廣播特別快,所有礦池可以非??炷玫絽^(qū)塊頭。有了區(qū)塊頭就可以拿到組裝新高度區(qū)塊的“父哈希值”。區(qū)塊體是包含所有交易的那部分,一般非常大,比如2500筆交易就接近1M了。BTC最大可以接近1M,加外3M的隔離見證區(qū)塊。而BCH曾經打包出21M的區(qū)塊體。所有礦池收到區(qū)塊體就要時間更長了,這叫網絡延遲。我們假定網絡延遲平時是0.5秒。

礦池挖礦最簡單的做法是:一個礦池只要在拿到區(qū)塊體,才能確認區(qū)塊體里有哪些交易。而只有驗證完整個區(qū)塊,才能知道這個“50W”高度的區(qū)塊是否合法。然后再開始組裝最新高度區(qū)塊,然后再挖礦計算小于目標值的哈希值。那在拿到區(qū)塊體,和驗證完整個區(qū)塊,再加上組裝最新高度區(qū)塊,的時間長度是多少?0.5+10+0.1=10.6秒。

如果一個礦池按上述過程來挖礦,那就在這10.6秒鐘的時間內是無法挖礦的,礦機是無效工作時間。而且礦機還是在開機耗電的。

如果一個礦池按下面的過程來工作:拿到區(qū)塊頭,就開始組裝一個新的“50W+1”高度的區(qū)塊,但因為無法確認這個50W高度區(qū)塊里的交易和是整個區(qū)塊是否合法,所以這個“50W+1”高度的區(qū)塊,礦池并不對區(qū)塊體填充額外的交易,只填充一個Coinbase獎勵交易。這個“50W+1”高度的區(qū)塊,只有區(qū)塊頭,外加一個Coinbase獎勵交易——這就是一個空塊——然后就直接開始挖礦。這樣操作,在全網出現一個新塊時,礦也只需要等待拿到區(qū)塊頭和組裝空塊的時間,就可以開始挖礦。這個時間就非常短了,平時不到0.5秒。這樣就比10.6秒,節(jié)省了10秒多的時間。

而按上述過程挖礦,礦池在收到完整50W高度區(qū)塊體和驗證完50W高度區(qū)塊,這個過程是10.6秒。在上述0.5秒到10.6秒的時間里,礦機如果計算出了一個隨機數小于目標值,那礦池就成功挖到了一個空塊。如果礦機沒有計算出小于目標值的隨機數,那礦池就會放棄這10.1秒的挖礦時間,然后改成組裝一個填充了交易的“50W+1”高度的最新高度區(qū)塊進行挖礦。

上述就是挖空塊的全部邏輯。

優(yōu)化挖礦原理

上述挖空礦的原理中,確認“50W”高度區(qū)塊里的交易是一個重要的工作,如果能夠提前知道這些交易,那組裝“50W+1”高度的區(qū)塊,不就可以避開這些交易,去組裝另外一些交易了嗎,這樣就可以不用打空塊了。

現在BTC和BCH網絡有兩個技術可以優(yōu)化這個區(qū)塊體的傳播,也就可以讓所有礦池更快知道“50W”高度里有哪些交易。第一個技術叫布隆過濾器;第二個叫致密區(qū)塊(Compactblock)和瘦區(qū)塊(Xthinblock)。(compactblock是Coredev開發(fā)的,Xthin是unlimiteddev開發(fā)的,兩者功能一樣。)

布隆過濾器是用來標記“50W”高度的區(qū)塊有哪些交易的,只是標識。礦池拿到這個標記就知道了里面有哪些交易,然后礦池會去自己的內存池查找這些交易,并列出自己沒有的交易,然后向其他節(jié)點索要自己沒有的交易。要到這些沒有的交易后,就在本地重新組裝一個“50W”高度的區(qū)塊,而不是從網絡上下載一個“50W”高度區(qū)塊。這個過程就是Compactblock和Xthinblock的原理。

通過這兩個技術就可以壓縮網絡延遲時間,但依然壓縮不了驗證“50W”高度區(qū)塊的時間,而前者只有0.5秒,后者有10秒。

這樣的時間差距,礦池還是要去挖空塊,不然整個礦機就在白白浪費電,要知道這個浪費10秒對全網來說是無比巨大的能源。

那怎么辦?

徹底解決挖空塊的辦法

上述分析了挖空塊的原理和優(yōu)化挖礦的原理,挖空塊的核心原因是礦池不敢往“50W+1”這個空塊中填充和“50W”高度里已經有的交易。

如果有一種辦法可以保證礦池組裝的“50W+1”高度的空塊里絕對沒有“50W”高度里出現過的交易,不就可以解決問題了嗎?

一種辦法是,礦池自己生成一些交易,不廣播,只保存在自己的內存池里,用來填充“50W+1”高度的空塊區(qū)塊,就可以了。

但礦池不能生成一些無意義的交易,不然就是一些垃圾交易,這是對網絡的浪費。打包用戶發(fā)的交易肯定是有意義的,但用戶發(fā)的交易往往都是經過廣播的,打包就和“50W”高度區(qū)塊里的交易相沖突的風險。

一定要找那些沒有經過廣播的交易。

一種方法是礦池和交易所合作,用戶在交易所發(fā)起的提現交易,交易所不去廣播,而是通過IP到IP的方式,以加密的方法直接發(fā)給礦池,這些交易絕對不會被“50W”高度區(qū)塊打包的。這些交易就可以100%沒有沖突的打進“50W+1”高度。

如果有交易所和礦池是同一個公司主體,那這種方法就非常好執(zhí)行了。不是同一個主體,礦池還是怕被交易所坑,萬一交易所塞一個經過廣播的交易就可能被浪費掉一個空塊的區(qū)塊獎勵。

但這種方法會讓交易所的用戶體驗有所下降,因為打空塊的概率低啊,這些交易得何年馬月才能被打包,雖然礦池可以在挖非空塊中打包,但用戶也得等這個礦池出塊才有確認,這和全網有出塊是差好長的時間的。

另一種方法是讓交易所給礦池提交的保密交易不是用戶的提現交易,而是一些零散UTXO拼湊成大UTXO的交易。這種交易是對整個UTXO體積有很大的優(yōu)化的,而且這些交易都沒有非常強烈的時間要求。適合被空塊打包。

所以,只需要考慮經濟因為的POW挖礦機制是最優(yōu)的設定,道德不應該被摻進來。所有批評礦池打空塊的言論,都是對POW挖礦機制沒有信心的。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯系該專欄作者,如若文章內容侵犯您的權益,請及時聯系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數據產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數據產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數字經濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯合牽頭組建的NVI技術創(chuàng)新聯盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現場 NVI技術創(chuàng)新聯...

關鍵字: VI 傳輸協議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉