比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads
首頁 > Gate.io > Info

內存池——交易的驛站_HAI

Author:

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

01交易是區塊鏈的基石

交易是區塊鏈的基石,我們每天都會接觸到各式交易,不論你是操作DeFi,還是轉賬購買NFT,或者只是單純的從交易所提現/充值,交易都是上述操作的基礎。

不過,鮮有人知曉交易的中轉站——內存池的重要性,由于大量教材為大家提供了“區塊鏈是一個不需要中介的交易賬本”這個概念,如果不深入了解區塊鏈的技術細節往往會忽略內存池,并導致在一些特殊時刻出現不必要的損失。

比特幣、以太坊、WisdomChain都有內存池設計,幾乎所有的區塊鏈項目都離不開內存池,那么究竟什么是內存池?內存池又在交易過程中扮演了什么角色呢?

02內存池是什么?

要了解內存池的概念,首先我們需要回顧交易的狀態。

Kava:Kava 9升級之一將包括針對更高交易費用的優先級內存池:11月13日消息,Kava在推特上表示,Kava 9的高質量升級之一將包括針對更高交易費用的優先級內存池。在高網絡擁塞期間,交易內存池的構建速度比驗證器處理交易的速度要快。為了解決這個問題,優先級的內存池將按照支付費用對要處理的交易進行排序。這將防止零費用垃圾交易攻擊,并允許有關鍵交易需求用戶,通過支付稍高費用優先處理其交易。為用戶提供工具,以更有效地管理其CDPs或在市場波動時借入頭寸。[2021/11/13 21:48:43]

相信大家在操作以太坊,尤其是近期擁堵的以太坊時,如果設置了較低的手續費,那么交易將會被等待一段時間才會被礦工打包。

等待的這段時間交易將會儲存在收到這筆交易的礦工節點中,而礦工節點則會將這些等待被它打包的交易存放在“內存池”中。

靈蹤安全:Arbitrum昨日因channel 阻塞引發內存泄漏,出現網絡故障:9月14日晚,以太坊 Layer2 項目Arbitrum出現網絡故障,其交易排序器因為內存泄漏而停止運行。根據靈蹤安全漏洞檢測系統提示:內存泄漏的位置在源碼SequencerBatcher.SendTransaction() 函數中。

此處漏洞是因為channel 阻塞導致大量goroutine 沒有及時釋放,引發內存泄漏。建議在處理并發時,考慮channel的阻塞情況。當存在高并發條件時,為channel寫入數據時,加上select default 處理。[2021/9/15 23:27:04]

放在內存池中的交易,礦工一般會按照手續費價格的多少來進行排序,優先打包價格較高的交易,至于手續費比較少的交易自然就必須排隊了。

JustLend 上線24小時內存款規模已超8200萬美元:據官方最新消息,波場TRON網絡上的首個官方借貸項目JustLend 上線24小時內存款規模已超8200萬美元,據悉,JustLend已于昨日正式上線。截至目前,JustLend存款規模Top前三的幣種分別為TRX、USDT、BTC。據悉,JustLend致力于打造完美的去中心化借貸協議,將成為波場上的首個官方的“去中心化算法銀行“。JustLend是波場TRON網絡首個官方借貸平臺,用于建立基于波場TRON資產的供求變化,以算法計算得出利率的資金池。協議中存在兩種角色,包括資產的存款方和借款人,并且資產的存款方和借款人可以直接與協議進行交互,從而賺取或支付浮動利率。[2020/12/8 14:33:48]

不過由于礦工每時每刻都會接收到其他節點發來的新交易,這些交易也會不斷的更新到內存池中,因此礦工也會在一定時間后重新排列交易池中的順序——換句話說,如果你的手續費太低,那么交易有可能一輩子都不會被打包。

動態 | nchain否決CTOR提案 因社區內存在反對意見:據nchain官網消息,該團隊已經評估了Canonical Transaction Ordering提案CTOR。該提案旨在改變BCH網絡中塊內交易順序。但是因為社區內的反對意見,nchain目前已否決該項提案。BitcoiUnlimited的首席開發人員Andrew Stone認為,CTOR的分片提議既不需要CTOR也不能解決激勵性的可擴展性問題,因此CTOR不需要網絡優化。[2018/9/17]

以太坊和比特幣雖然采用了完全不同的結構,但他們的交易內存池設計都是大同小異的,或者說,所有的區塊鏈項目在內存池上的設計都大同小異,我們以WisdomChain的內存池作為例子:

上述各個參數定義了WisdomChain中內存池的各個特點,我們挑選其中最重要的幾點進行解釋:

1Pending

pending代表著尚未被礦工打包的交易,這些交易已經經過了初次校驗并等待被礦工打包

2Queued

queued代表著初步被驗證過的交易,但這些交易的優先級比pending低,處于”等待進入pending“隊列的狀態。需要注意的是pending和queued隊列也會按照Nonce隨機數來進行排序。

3過期時間

過期時間。交易如果超過了一段時間將會從內存池中清除,用戶需要重新向網絡廣播交易才能讓交易被放入到礦工的內存池中

4手續費

手續費,顧名思義,避免大量無意義的交易填塞網絡導致擁堵。

5最大事務數

最大事務數。確保礦工的內存池不會儲存過多交易,導致節點宕機。

不論比特幣、以太坊,內存池的設計都離不開”交易隊列“,”手續費門檻“,”內存池上限“三大概念,WisdomChain中也是如此。

03為什么需要內存池?

試想一下,如果沒有內存池,區塊鏈會發生什么?

雖然作為點對點交易的媒介,區塊鏈看起來是一個用戶同另一個用戶直接交易,就像線下一手交錢一手交貨一樣,加入交易池作為中介媒介似乎是徒增摩擦成本。但實際上,內存池的存在不僅沒有對網絡造成負擔,甚至還是網絡減負的重要手段。

如果沒有內存池,首先區塊鏈就喪失了對粉塵攻擊的抵抗性。所謂區塊鏈上的粉塵攻擊,指的是大量毫無意義的交易填充了整個區塊網絡,而交易驗證是需要花費時間和算力的,如果用戶和礦工節點被大量的粉塵交易所填塞,那么他們將無法正常的驗證并打包本應當正常的交易。

甚至如果礦工節點不設上限地接收粉塵交易,交易將會直接填滿礦工節點的內存導致宕機。內存池的存在,通過最大事務數和手續費門檻,確保無價值的粉塵攻擊不會讓網絡陷入擁堵狀態。

交易額低數量大

其次,缺乏內存池,網絡激勵機制將會受到挑戰。內存池設置了按照隨機數手續費進行排列的交易隊列,為的是讓礦工盡可能以網絡、用戶還有礦工個人所期望的方式打包交易——即優先高手續費的交易。

如果缺乏內存池,雖然從利己角度礦工依然會選擇較高手續費的交易進行打包,但惡意礦工可以通過以低手續費門檻吸引大量的交易并孤立其他礦工,如果交易過多的聚集在某個礦工控制的節點下,發動雙花攻擊的難度也會有所下降。

另一方面,如果礦工對交易不按照隨機數進行排序,那么事務/合約的執行也會存在問題。如果一個礦工節點收到了來自一個用戶的多筆交易,在內存池的輔助下交易將會按照隨機數大小進行排列,本質上也符合交易的”理想發起時間“。

缺乏內存池,如果在網絡存在延遲的環境下,用戶發起的交易并不會按照實際發送時間廣播到礦工手中,礦工如果單純按照接收時間來執行某一用戶的多筆交易,那么對于事務/合約這種嚴格限定交易先后順序的設計,錯序交易會讓用戶無法正常的調用合約。

04?內存是交易的驛站

內存池是交易的驛站,或者說港口。所有的交易都需要在內存池進行校驗、打包、排序,之后才會經由礦工發送到區塊鏈網絡中。如果忽視內存池設計,或者忽視內存池的存在,在市場劇烈波動或者網絡環境不穩定的情況下,是會發生類似3.12MakerDAO0價格ETH拍賣烏龍事件的。

本文來自WisdomChain公鏈社區

Tags:ENDCHA區塊鏈HAIQueenDex CoinSentinel Chain區塊鏈賺錢是什么模式Venus Chain

Gate.io
關于“Bingbon跟單系統”使用規范的優化說明_NFT

尊敬的用戶: 跟單功能上線以來,受到廣大用戶的歡迎。由于跟單資源有限,系統將通過優化以下使用規范的方式,來保障Bingbon跟單系統用戶的切身權益.

1900/1/1 0:00:00
火幣全球站于9月16日17:30開放RENBTC幣幣交易

尊敬的用戶: 火幣全球站定于2020年9月16日17:30(GMT8)開放RENBTC(renBTC)的幣幣交易(RENBTC/BTC,RENBTC/ETH)和提幣業務.

1900/1/1 0:00:00
關于Haicoin早鳥充值達到限額的公告_OIN

親愛的CoinW用戶: CoinW近期Haicoin(HAIC)早鳥充值福利活動目前已達到充值限額,詳情如下:滿足活動參與資格的用戶共計207人,實際參與早鳥充值活動人數102人.

1900/1/1 0:00:00
紫盈說幣:9.16比特幣投資——實用實戰做單技巧(全是干貨)_ROM

華爾街市場上流行著這樣的一句話:“市場一定會朝著大多數人預期的方向相反運行,群眾的觀點永遠會出錯.

1900/1/1 0:00:00
BeeX研報 | 穩定幣重要性及過去一周市場數據情況_USDT

穩定幣是加密生態系統的重要組成部分,可以說是加密貨幣市場最近兩年來最成功的應用了。很多17年以后入場的玩家,首先接觸應該就是穩定幣的場外交易.

1900/1/1 0:00:00
關于CoinW“幣贏跑腿計劃”第二期進度同步的公告_區塊鏈

親愛的CoinW用戶: CoinW“幣贏跑腿計劃”第二期已于2020年8月24日21點提前結束,本次申請總人數為146人.

1900/1/1 0:00:00
ads