01交易是區塊鏈的基石
交易是區塊鏈的基石,我們每天都會接觸到各式交易,不論你是操作DeFi,還是轉賬購買NFT,或者只是單純的從交易所提現/充值,交易都是上述操作的基礎。
不過,鮮有人知曉交易的中轉站——內存池的重要性,由于大量教材為大家提供了“區塊鏈是一個不需要中介的交易賬本”這個概念,如果不深入了解區塊鏈的技術細節往往會忽略內存池,并導致在一些特殊時刻出現不必要的損失。
比特幣、以太坊、WisdomChain都有內存池設計,幾乎所有的區塊鏈項目都離不開內存池,那么究竟什么是內存池?內存池又在交易過程中扮演了什么角色呢?
02內存池是什么?
要了解內存池的概念,首先我們需要回顧交易的狀態。
比特幣內存池已接近1GB,但并非因Ordinals銘文導致:3月24日消息,據Glassnode數據顯示,比特幣內存池容量已接近1 GB,數據顯示當前有超過6萬筆交易未確認,不過出現這種情況可能不是因為Ordinals銘文導致,分析認為本次比特幣內存池容量擴大很可能由現貨交易驅動。(cryptoslate)[2023/3/24 13:24:17]
相信大家在操作以太坊,尤其是近期擁堵的以太坊時,如果設置了較低的手續費,那么交易將會被等待一段時間才會被礦工打包。
等待的這段時間交易將會儲存在收到這筆交易的礦工節點中,而礦工節點則會將這些等待被它打包的交易存放在“內存池”中。
放在內存池中的交易,礦工一般會按照手續費價格的多少來進行排序,優先打包價格較高的交易,至于手續費比較少的交易自然就必須排隊了。
靈蹤安全:Arbitrum昨日因channel 阻塞引發內存泄漏,出現網絡故障:9月14日晚,以太坊 Layer2 項目Arbitrum出現網絡故障,其交易排序器因為內存泄漏而停止運行。根據靈蹤安全漏洞檢測系統提示:內存泄漏的位置在源碼SequencerBatcher.SendTransaction() 函數中。
此處漏洞是因為channel 阻塞導致大量goroutine 沒有及時釋放,引發內存泄漏。建議在處理并發時,考慮channel的阻塞情況。當存在高并發條件時,為channel寫入數據時,加上select default 處理。[2021/9/15 23:27:04]
不過由于礦工每時每刻都會接收到其他節點發來的新交易,這些交易也會不斷的更新到內存池中,因此礦工也會在一定時間后重新排列交易池中的順序——換句話說,如果你的手續費太低,那么交易有可能一輩子都不會被打包。
區塊鏈數據平臺Blocknative發布內存池瀏覽器 提供內存池交易數據實時流:區塊鏈數據平臺Blocknative發布內存池瀏覽器“MempoolExplorer”,為開發者和交易者提供內存池交易數據實時流。Blocknative還具有以下主要功能:1.檢測1萬美元以上的大額流動資金流入或流出至一種協議;2.在與自行添加的熱錢包有關的待確認交易(pendingTX)成功完成后發送slack信息;3.監控最新流動性挖礦項目的內幕交易、流動性等情況。[2020/9/24]
以太坊和比特幣雖然采用了完全不同的結構,但他們的交易內存池設計都是大同小異的,或者說,所有的區塊鏈項目在內存池上的設計都大同小異,我們以WisdomChain的內存池作為例子:
上述各個參數定義了WisdomChain中內存池的各個特點,我們挑選其中最重要的幾點進行解釋:
金馬:EOS上內存租賃成本會是一個穩定的價格:EOS超級節點競選團隊EOS Asia 的金馬在《歐鏈·寧話區塊鏈》第二季的節目中稱 “EOS上內存租賃成本會是一個穩定的價格,因為通過多方博弈,隨著EOS的增長,用戶的增多,DApp開發公司的增多,最終帶寬CPU,以及RAM內存,會是一個穩定的價格。不會像外界所說的,EOS價格增長,DApp運營成本或者資源成本就更貴。在我看來會是一個穩定的價格,跟現在互聯網的云計算云服務器收費方式相同,價格是穩定的。”[2018/6/22]
1Pending
pending代表著尚未被礦工打包的交易,這些交易已經經過了初次校驗并等待被礦工打包
2Queued
queued代表著初步被驗證過的交易,但這些交易的優先級比pending低,處于”等待進入pending“隊列的狀態。需要注意的是pending和queued隊列也會按照Nonce隨機數來進行排序。
3過期時間
過期時間。交易如果超過了一段時間將會從內存池中清除,用戶需要重新向網絡廣播交易才能讓交易被放入到礦工的內存池中
4手續費
手續費,顧名思義,避免大量無意義的交易填塞網絡導致擁堵。
5最大事務數
最大事務數。確保礦工的內存池不會儲存過多交易,導致節點宕機。
不論比特幣、以太坊,內存池的設計都離不開”交易隊列“,”手續費門檻“,”內存池上限“三大概念,WisdomChain中也是如此。
03為什么需要內存池?
試想一下,如果沒有內存池,區塊鏈會發生什么?
雖然作為點對點交易的媒介,區塊鏈看起來是一個用戶同另一個用戶直接交易,就像線下一手交錢一手交貨一樣,加入交易池作為中介媒介似乎是徒增摩擦成本。但實際上,內存池的存在不僅沒有對網絡造成負擔,甚至還是網絡減負的重要手段。
如果沒有內存池,首先區塊鏈就喪失了對粉塵攻擊的抵抗性。所謂區塊鏈上的粉塵攻擊,指的是大量毫無意義的交易填充了整個區塊網絡,而交易驗證是需要花費時間和算力的,如果用戶和礦工節點被大量的粉塵交易所填塞,那么他們將無法正常的驗證并打包本應當正常的交易。
甚至如果礦工節點不設上限地接收粉塵交易,交易將會直接填滿礦工節點的內存導致宕機。內存池的存在,通過最大事務數和手續費門檻,確保無價值的粉塵攻擊不會讓網絡陷入擁堵狀態。
交易額低數量大
其次,缺乏內存池,網絡激勵機制將會受到挑戰。內存池設置了按照隨機數手續費進行排列的交易隊列,為的是讓礦工盡可能以網絡、用戶還有礦工個人所期望的方式打包交易——即優先高手續費的交易。
如果缺乏內存池,雖然從利己角度礦工依然會選擇較高手續費的交易進行打包,但惡意礦工可以通過以低手續費門檻吸引大量的交易并孤立其他礦工,如果交易過多的聚集在某個礦工控制的節點下,發動雙花攻擊的難度也會有所下降。
另一方面,如果礦工對交易不按照隨機數進行排序,那么事務/合約的執行也會存在問題。如果一個礦工節點收到了來自一個用戶的多筆交易,在內存池的輔助下交易將會按照隨機數大小進行排列,本質上也符合交易的”理想發起時間“。
缺乏內存池,如果在網絡存在延遲的環境下,用戶發起的交易并不會按照實際發送時間廣播到礦工手中,礦工如果單純按照接收時間來執行某一用戶的多筆交易,那么對于事務/合約這種嚴格限定交易先后順序的設計,錯序交易會讓用戶無法正常的調用合約。
04?內存是交易的驛站
內存池是交易的驛站,或者說港口。所有的交易都需要在內存池進行校驗、打包、排序,之后才會經由礦工發送到區塊鏈網絡中。如果忽視內存池設計,或者忽視內存池的存在,在市場劇烈波動或者網絡環境不穩定的情況下,是會發生類似3.12MakerDAO0價格ETH拍賣烏龍事件的。
本文來自WisdomChain公鏈社區
Tags:區塊鏈CHADINEND有人拉你做區塊鏈blockchain是什么行業DINOSAUR價格TendieSwap
Eth2升級對以太坊網絡來說是一次基礎架構的更新。如果讀者持有ETH或使用最流行的DeFi協議之一,無需做任何事,因為當前的以太坊網絡將與Eth2兼容.
1900/1/1 0:00:00代表來自美國所有州和領地的監管機構的州銀行監管人會議已經啟動了針對支付和加密貨幣公司的新監管框架。一套適用于美國所有州的規則美國49個州的監管機構已同意針對貨幣服務業務的一套監管規則.
1900/1/1 0:00:00為了回饋用戶對COINW長久以來的支持,COINW聯合OceanChain團隊開啟“OC登陸幣贏網,交易送雙重好禮”活動,具體規則如下:第一重好禮:OC交易贏好禮.
1900/1/1 0:00:00狗幣自有一套策略,它并不走比特幣的賺錢路線,而是很好地利用了美國的“小費文化”。這種被視作是對服務者的捐贈或跪拜的謙卑姿態,也在互聯網上廣泛使用.
1900/1/1 0:00:00比特幣,一個讓股神巴菲特看走眼的投資領域,挖礦,一個百分之九十九都除了名稱,啥也不懂的行業。引得無數人趨之若鶩.
1900/1/1 0:00:00OKExInsights和Catallact的最新研究表明,隨著新冠肺炎大流行開始,散戶和機構比特幣投資者采取了截然不同的方法.
1900/1/1 0:00:00