⑴ 濡備綍鍙栨秷鍙戦佽鍗′綇鐨勪互澶鍧婁氦鏄撳叿浣撴搷浣滄槸浠涔
鍦ㄧ綉緇滄瘮杈冩嫢鍫電殑鏃跺欙紝涓絎斾氦鏄撳氨浼氭湁鍙鑳借鍗″湪浠ュお鍧婄殑鏈鍐充簨鍔℃睜涓銆傞栧厛鐭垮伐瑕佽冭檻Gas璐歸珮鐨勪氦鏄擄紝濡傛灉浣犵殑Gas璐規湁鐐逛綆鐨勮瘽錛屽彲鑳藉氨瑕佹帓闃熴備絾鏄鍙栨秷鍗′綇鐨勪氦鏄撳苟涓嶉毦鐨勩傚彧瑕佷綘鎰挎剰錛屽氨鑳藉熼噸鏂伴夋嫨涓涓鏇撮珮鐨凣as璐規潵瀹屾垚鍘熷厛鐨勪氦鏄撱備笅鍒楁槸鍏蜂綋榪囩▼錛
1.棣栧厛瑕佸艱埅鍒頒互澶鍧婃祻瑙堝櫒etherscan.io銆
2.鐒跺悗灝辮佹妸浣犵殑浜ゆ槗鍝堝笇鍊肩矘璐村埌浠ュお鍧婃祻瑙堝櫒鐨勬悳緔㈡爮銆
3.鎺ヤ笅鏉ヨ繘鍏ュ湪浜ゆ槗欏甸潰涓鐐瑰嚮鈥滅偣鍑繪煡鐪嬫洿澶氣濇寜閽銆
4.鐒跺悗灝變細鍑虹幇nonce錛堥殢鏈烘暟錛夛紝闇瑕佹妸榪欎釜鍙風爜璁頒笅鏉ャ
5.鎺ヤ笅鏉ュ氨瑕佸湪浣犵殑閽卞寘閲屽噯澶囦竴絎旀柊鐨勪氦鏄撱
6.鐒跺悗榪涘叆閽卞寘錛岀偣鍑燴滈珮綰р濋夐」錛岃緭鍏ュ拰浣犵殑鍗′綇鐨勪氦鏄撳搱甯屽肩浉鍚岀殑nonce(闇瑕佹敞鎰忕殑鏄:浣犲湪閽卞寘璁劇疆涓鍙浠ヨ佹縺媧昏嚜瀹氫箟nonce鍔熻兘)銆
7.鍙戦佹柊鐨勪氦鏄擄紝鐒跺悗鐐瑰嚮鈥滃揩閫熲滸as璐廣
8.鍙瑕佺『璁や簡錛岄偅涔堜氦鏄撳氨浼氳琚瑙i櫎鏉ユ簮錛氬尯鍧楀嵃璞
鎴戜滑閫氳繃浠ヤ笂鍏充簬濡備綍鍙栨秷鍙戦佽鍗′綇鐨勪互澶鍧婁氦鏄撳叿浣撴搷浣滄槸浠涔堝唴瀹逛粙緇嶅悗,鐩鎬俊澶у朵細瀵瑰備綍鍙栨秷鍙戦佽鍗′綇鐨勪互澶鍧婁氦鏄撳叿浣撴搷浣滄槸浠涔堟湁涓瀹氱殑浜嗚В,鏇村笇鏈涘彲浠ュ逛綘鏈夋墍甯鍔┿
⑵ 以太坊的gas費被誰賺了
gas主要是被消耗了,收益比較少。
Gas費的組成主要有以下幾個要素:GasFeeCap、GasPremium、GasLimit、GasUsed、BaseFee。
GasLimit是消耗資源的最大限制,GasFeeCap是用戶所能支付給礦工的最大單價限額。在Filecoin鏈上,在打包前要檢查賬戶是否有足夠的余額,不然交易不會被打包。所以GasLimit和GasFeeCap可以得到用戶的最高能支付的費用,是用戶自主設置的。但要注意的是,GasLimit不要隨意設置,多餘的GasLimit會被燃燒一部分,這是和ETHGas費機制最大的不同點。
BaseFee相當於一個基礎價位,同樣用汽車燃料費來看,可以理解為政府根據整個市場的交易情況設置了一個油價,這個價位會浮動,因此這里起到的類似於一個宏觀調控的作用。同樣也可以比喻為計程車的起步價,如果用戶不願意支付起步價,司機就不願意載人,因此如果用戶想要乘車就必須接受起步價,而這個起步價在FilecoinGas費中就是BaseFee。當然在Filecoin中這個起步價是動態的,當總GasLimit超過某個區塊(網路擁塞信號)的GasLimit目標時,它將增加;低於GasLimit目標時將降低。換句話說,在區塊擁堵或者區塊交易不夠的情況下,BaseFee都會按照12.5%進行相應的調節。
GasPremium在這個機制里被描述為小費,即在網路擁堵的情況下支付給礦工的小費,這個也意味著礦工有優先選擇權。如果你支付了GasPremium,礦工就會優先打包你區塊的數據。最終給到礦工的酬勞是小費(GasPremium)*最大消耗量(GasLimit)
⑶ 浠ュお鍧婃嫢鍫墊庝箞鏍瘋В
浠ュお鍧婃嫢鍫墊庝箞瑙e喅
浠ュお鍧婄綉緇滄嫢鍫墊槸鎸囧湪鍖哄潡閾劇綉緇滀笂浜ゆ槗閲忚繃澶э紝瀵艱嚧浜ゆ槗璐圭敤鎬ュ墽涓婃定銆佷氦鏄撻熷害鍙樻參銆佷氦鏄撹鍗′綇絳夌幇璞°傝В鍐充互澶鍧婄綉緇滄嫢鍫電殑鏂規硶鏈変互涓嬪嚑縐嶏細
澧炲姞鐭垮伐璐圭敤
鍦ㄤ互澶鍧婄綉緇滄嫢鍫墊椂錛岀敱浜庡尯鍧楅摼鐨勮繍琛屾満鍒訛紝鐭垮伐闇瑕佷負姣忎釜浜ゆ槗璁$畻鍜岄獙璇侊紝鐒跺悗鎵撳寘鍒板尯鍧椾腑銆傚洜姝わ紝涓轟簡鍚稿紩鏇村氱熆宸ュ勭悊浜ゆ槗錛岀敤鎴峰彲浠ュ炲姞鐭垮伐璐圭敤錛岃繖鏍蜂氦鏄撳氨鑳芥洿蹇鍦板緱鍒板勭悊銆備絾鏄錛岄殢鐫浜ゆ槗璐圭敤鐨勪笉鏂澧炲姞錛岀敤鎴峰彲鑳介渶瑕佹敮浠樻洿楂樼殑璐圭敤鎵嶈兘浣誇氦鏄撳緱鍒伴獙璇佸拰澶勭悊銆
浣跨敤Layer2鏂規
Layer2鏂規堟槸浠ュお鍧婄綉緇滀笂鐨勮В鍐蟲柟妗堜箣涓錛岄氳繃灝嗕竴浜涗氦鏄撲粠浠ュお鍧婁富緗戠Щ鑷沖彟涓涓騫寵岀殑緗戠粶錛屾潵鍑忚交浠ュお鍧婁富緗戠殑璐熻澆銆傝繖浜涘鉤琛岀綉緇滐紝渚嬪俁ollup鍜孭lasma錛屽厑璁稿湪鏈鍦板勭悊澶ч噺浜ゆ槗錛岀劧鍚庡湪闇瑕佹椂灝嗗畠浠鐨勬眹鎬繪暟鎹鎻愪氦鍒頒富緗戙傝繖縐嶆柟妗堝彲浠ユ樉钁楁彁楂樹互澶鍧婄綉緇滅殑鍚炲悙閲忓拰浜ゆ槗閫熷害錛屼粠鑰屽噺灝戞嫢鍫甸棶棰樸
絳夊緟闈為珮宄版椂孌
鐢變簬浠ュお鍧婄綉緇滅殑浜ゆ槗閲忔嘗鍔ㄨ緝澶э紝鐢ㄦ埛鍙浠ラ夋嫨鍦ㄩ潪楂樺嘲鏃舵佃繘琛屼氦鏄擄紝渚嬪傚湪娣卞滄垨鍛ㄦ湯銆傝繖鏍峰彲浠ラ伩鍏嶄笌鍏朵粬鐢ㄦ埛絝炰簤錛屼粠鑰屼嬌浜ゆ槗璐圭敤鍜岄熷害閮藉緱鍒版敼鍠勩
浼樺寲浜ゆ槗絳栫暐
鐢ㄦ埛鍙浠ヤ紭鍖栦氦鏄撶瓥鐣ワ紝渚嬪傞檷浣庣噧姘斾環鏍箋佷嬌鐢ㄤ笉鍚岀殑浜ゆ槗鏂瑰紡鎴栫瓑寰呭悎閫傜殑鏃舵満鎻愪氦浜ゆ槗絳夈傝繖浜涗紭鍖栫瓥鐣ュ彲浠ュ湪鎷ュ牭鏈熼棿闄嶄綆浜ゆ槗鎴愭湰錛屽苟灝藉彲鑳藉湴鍔犲揩浜ゆ槗閫熷害銆
緇間笂鎵榪幫紝浠ュお鍧婃嫢鍫電殑瑙e喅鏂規硶鍖呮嫭澧炲姞鐭垮伐璐圭敤銆佷嬌鐢↙ayer2鏂規堛侀夋嫨闈為珮宄版椂孌佃繘琛屼氦鏄撳拰浼樺寲浜ゆ槗絳栫暐銆備絾鏄錛岃繖浜涙柟娉曞苟涓嶈兘瀹屽叏瑙e喅鎷ュ牭闂棰橈紝鍙鑳藉湪涓瀹氱▼搴︿笂緙撹В緗戠粶璐熻澆銆
⑷ 以太倫敦升級後,AITD靠什麼完成逆襲
眾所周知,由於目前以太坊是全球第一大超級公鏈,各種區塊鏈應用,特別是defi應用基本都是基於以太坊公鏈開發的,導致以太坊網路擁堵不堪,如果把以太坊比做一條高速公路的話,那麼搭載期間的各種defi應用就是行駛在其中的 汽車 ,隨著駛入以太這條高速公路的 汽車 越來越多,必然導致交通擁堵,以及油耗的攀升和通過的時間變得更長,這就相當於在以太上完成一筆交易所花的時間拉長了和礦工費和gas費升高了!
為了解決這一難題,以太坊技術開發人員也是不斷進行系統升級,這不,最近備受矚目的以太坊倫敦升級完成,倫敦升級涉及眾多提案,其中最令人關注的是EIP-1559。該提案引入銷毀機制,讓鏈上費用更合理,同時也一定程度緩解了以太坊的通脹,截至8月6日20:33,已經有4696ETH被銷毀,銷毀速度大約是3.26ETH/分鍾。按照當前速度,預計每年將有170萬ETH被銷毀,價值約為47億美元。
那麼這次升級後,真的就能徹底解決以太坊網路的擁堵和高昂的交易手續費和gas費了嘛?我們以大家所熟悉的方式做個比方,就好比打開一個網路的速度,最主要依靠的就是數據交換(tps)的速度,而tps取決於三個方面,一個是埠的傳播速度,一個是介面的接收速度,另外一個就是傳輸中介的速度;目前造成以太坊網路擁堵的主要原因是其自身的數據擁堵造成的,也就是其埠的數據擁堵,如果把以太坊比做一個數據池子的話,而其中的水已近處於滿載狀態,而倫敦升級好比給這個池子開了個小口,放水!能否讓水位下降取決於進水量與出水量的正負差,而這個就很好理解,一個是以太坊自身的交易量數據,另外就是搭載期間的defi項目的交易量數據;在引入EIP1559之後,用戶在鏈上發生交互產生的費用有兩部分,一部分是基礎費(需要銷毀),另一部分是付給礦工的小費(不銷毀)。基礎費根據網路動態調整,一般不需用戶調整。用戶調整的是支付給礦工的小費。當網路越活越,用戶支付的基礎費越高,銷毀的越多,導致一段時間內看起來是「通縮」的。但是長期來看,如果以太坊不轉為POS機制,比起當前每年增發的400-600萬ETH,現在的銷毀量恐怕並不足以使ETH通縮。而已目前defi的火熱程度,產生的數據量完全不亞於2018年底幣圈牛市階段,而越來越多的defi項目的落地生根,必將引發新一輪的網路擁堵。
雖然此次升級在一段時間內一定程度上改善了乙太網的擁堵,以及引入通縮概念使得以太坊更具稀缺性,但是其想降低gas費和交易費的目標短期內並沒有實現!那麼,此次升級之後,眾多的商用公鏈是否還有更大的市場空間去拓展其實並不取決於以太坊網路的升級,而是在公鏈競爭將進入白熱化階段,誰能帶給世人更好更快更實用的體驗,以及實實在在的利益共享機制,才是這些公鏈能否崛起的關鍵因素;區塊鏈技術之所以得以快速發展,不斷壯大的根本原因其實就是去中心化思潮的共鳴以及利益分配機制的公平公開和共建共享!
那麼,在眾多公鏈中,AITD到底依靠什麼來完成逆襲?實現最初的夢想,改變未來全球資產通兌方式,讓價值傳遞全球,讓金融普惠萬家!首先是互聯網技術的後發優勢,隨著互聯網技術的不斷更新迭代,後發優勢逐漸體現出來,就拿數據交換速度(TPS)來說,比特幣的TPS只有7,以太坊可能稍微好一點,TPS大約在10-20,EOS可以將TPS做到100萬,而AITD能將TPS做到每秒百兆級別;第二:目前AITD還屬於發展初期,任何新的機會一定是參與的越早,其獲得利益或者說未來的收益一定是越大的,就好比十年前參與比特幣挖礦和現在參與比特幣挖礦完全就不是一個量級了;現在參與AITD就相當於十年前參與比特幣一個道理,由於其廣闊的應用場景和技術實力的支撐,必將不斷吸引優質的項目參與!第三,更多生態應用的搭建,使得AITD相較於其他公鏈而言,對廣大的普通用戶極其具有吸引力,AITD構建了豐富的社區交流體系和社區治理體系,不斷完善共識家園豐富的文娛休閑文化基礎設施,讓AITD的每一個參與者都能隨時隨地了解AITD,參與AITD的建設,並且公正公平的享受AITD的發展成果!
所有偉大的夢想源於強大的實力所決定的,站在實力的角度出發,AITD完全具備從眾多公鏈項目中脫穎而出的基礎!
⑸ 以太坊區塊鏈大小多少(以太坊區塊高度是多少)
以太坊公鏈區塊高度根據之前的消息,以太坊區塊高度現在調整高度到4730660!以太坊是一個全新開放的區塊鏈平台,它允許任何人在平台中建立和使用通過區塊鏈技術運行的去中心化應用。
就像比特幣一樣,以太坊不受任何人控制,也不歸任何人所有——它是一個開放源代碼項目,由全球范圍內的很多人共同創建。和比特幣協議有所不同的是,以太坊的設計十分靈活,極具適應性。在以太坊平台上創立新的應用十分簡便,隨著Homestead的發布,任何人都可以安全地使用該平台上的應用。
以太坊是可編程的區塊鏈。它並不是給用戶一系列預先設定好的操作,而是允許用戶按照自己的意願創建復雜的操作。這樣一來,它就可以作為多種類型去中心化區塊鏈應用的平台。
以太坊區塊鏈大小
與比特幣網路不同,以太坊不會明確地按內存限制每個區塊的大小,而是通過區塊GasLimit強制規定每個區塊的大小。
以太坊的區塊GasLimit設置有效的限制了一個區塊中可以打包的交易量。GasLimit參數由以太坊礦工集體決定,即通過投票的方式來動態地增加或降低GasLimit數值。
最近的一次投票是2019年下半年,礦工們群體投票同意將以太坊的區塊GasLimit由原來的800萬Gas單位提高至1000萬,使每個區塊相比之前區塊的大小增加了25%左右,這從理論上提高了以太坊網路的TPS。
什麼是區塊鏈擴容?普通用戶能夠運行節點對於區塊鏈的去中心化至關重要
想像一下凌晨兩點多,你接到了一個緊急呼叫,來自世界另一端幫你運行礦池(質押池)的人。從大約14分鍾前開始,你的池子和其他幾個人從鏈中分離了出來,而網路仍然維持著79%的算力。根據你的節點,多數鏈的區塊是無效的。這時出現了余額錯誤:區塊似乎錯誤地將450萬枚額外代幣分配給了一個未知地址。
一小時後,你和其他兩個同樣遭遇意外的小礦池參與者、一些區塊瀏覽器和交易所方在一個聊天室中,看見有人貼出了一條推特的鏈接,開頭寫著「宣布新的鏈上可持續協議開發基金」。
到了早上,相關討論廣泛散布在推特以及一個不審查內容的社區論壇上。但那時450萬枚代幣中的很大一部分已經在鏈上轉換為其他資產,並且進行了數十億美元的defi交易。79%的共識節點,以及所有主要的區塊鏈瀏覽器和輕錢包的端點都遵循了這條新鏈。也許新的開發者基金將為某些開發提供資金,或者也許所有這些都被領先的礦池、交易所及其裙帶所吞並。但是無論結果如何,該基金實際上都成為了既成事實,普通用戶無法反抗。
或許還有這么一部主題電影。或許會由MolochDAO或其他組織進行資助。
這種情形會發生在你的區塊鏈中嗎?你所在區塊鏈社區的精英,包括礦池、區塊瀏覽器和託管節點,可能協調得很好,他們很可能都在同一個telegram頻道和微信群中。如果他們真的想出於利益突然對協議規則進行修改,那麼他們可能具備這種能力。以太坊區塊鏈在十小時內完全解決了共識失敗,如果是只有一個客戶端實現的區塊鏈,並且只需要將代碼更改部署到幾十個節點,那麼可以更快地協調客戶端代碼的更改。能夠抵禦這種社會性協作攻擊的唯一可靠方式是「被動防禦」,而這種力量來自去一個中心化的群體:用戶。
想像一下,如果用戶運行區塊鏈的驗證節點(無論是直接驗證還是其他間接技術),並自動拒絕違反協議規則的區塊,即使超過90%的礦工或質押者支持這些區塊,故事會如何發展。
如果每個用戶都運行一個驗證節點,那麼攻擊很快就會失敗:有些礦池和交易所會進行分叉,並且在整個過程中看起來很愚蠢。但是即使只有一些用戶運行驗證節點,攻擊者也無法大獲全勝。相反,攻擊會導致混亂,不同用戶會看到不同的區塊鏈版本。最壞情況下,隨之而來的市場恐慌和可能持續的鏈分叉將大幅減少攻擊者的利潤。對如此曠日持久的沖突進行應對的想法本身就可以阻止大多數攻擊。
Hasu關於這一點的看法:
「我們要明確一件事,我們之所以能夠抵禦惡意的協議更改,是因為擁有用戶驗證區塊鏈的文化,而不是因為PoW或PoS。」
假設你的社區有37個節點運行者,以及80000名被動監聽者,對簽名和區塊頭進行檢查,那麼攻擊者就獲勝了。如果每個人都運行節點的話,攻擊者就會失敗。我們不清楚針對協同攻擊的啟動群體免疫的確切閾值是多少,但有一點是絕對清楚的:好的節點越多,惡意的節點就越少,而且我們所需的數量肯定不止於幾百幾千個。
那麼全節點工作的上限是什麼?
為了使得有盡可能多的用戶能夠運行全節點,我們會將注意力集中在普通消費級硬體上。即使能夠輕松購買到專用硬體,這能夠降低一些全節點的門檻,但事實上對可擴展性的提升並不如我們想像的那般。
全節點處理大量交易的能力主要受限於三個方面:
算力:在保證安全的前提下,我們能劃分多少CPU來運行節點?
帶寬:基於當前的網路連接,一個區塊能包含多少位元組?
存儲:我們能要求用戶使用多大的空間來進行存儲?此外,其讀取速度應該達到多少?(即,HDD足夠嗎?還是說我們需要SSD?)
許多使用「簡單」技術對區塊鏈進行大幅擴容的錯誤看法都源自於對這些數字過於樂觀的估計。我們可以依次來討論這三個因素:
算力
錯誤答案:100%的CPU應該用於區塊驗證
正確答案:約5-10%的CPU可以用於區塊驗證
限制之所以這么低的四個主要原因如下:
我們需要一個安全邊界來覆蓋DoS攻擊的可能性(攻擊者利用代碼弱點製造的交易需要比常規交易更長的處理時間)
節點需要在離線之後能夠與區塊鏈同步。如果我掉線一分鍾,那我應該要能夠在幾秒鍾之內完成同步
運行節點不應該很快地耗盡電池,也不應該拖慢其他應用的運行速度
節點也有其他非區塊生產的工作要進行,大多數是驗證以及對p2p網路中輸入的交易和請求做出響應
請注意,直到最近大多數針對「為什麼只需要5-10%?」這一點的解釋都側重於另一個不同的問題:因為PoW出塊時間不定,驗證區塊需要很長時間,會增加同時創建多個區塊的風險。這個問題有很多修復方法,例如BitcoinNG,或使用PoS權益證明。但這些並沒有解決其他四個問題,因此它們並沒有如許多人所料在可擴展性方面獲得巨大進展。
並行性也不是靈丹妙葯。通常,即使是看似單線程區塊鏈的客戶端也已經並行化了:簽名可以由一個線程驗證,而執行由其他線程完成,並且有一個單獨的線程在後台處理交易池邏輯。而且所有線程的使用率越接近100%,運行節點的能源消耗就越多,針對DoS的安全系數就越低。
帶寬
錯誤答案:如果沒2-3秒都產生10MB的區塊,那麼大多數用戶的網路都大於10MB/秒,他們當然都能處理這些區塊
正確答案:或許我們能在每12秒處理1-5MB的區塊,但這依然很難
如今,我們經常聽到關於互聯網連接可以提供多少帶寬的廣為傳播的統計數據:100Mbps甚至1Gbps的數字很常見。但是由於以下幾個原因,宣稱的帶寬與預期實際帶寬之間存在很大差異:
「Mbps」是指「每秒數百萬bits」;一個bit是一個位元組的1/8,因此我們需要將宣稱的bit數除以8以獲得位元組數。
網路運營商,就像其他公司一樣,經常編造謊言。
總是有多個應用使用同一個網路連接,所以節點無法獨占整個帶寬。
P2P網路不可避免地會引入開銷:節點通常最終會多次下載和重新上傳同一個塊(更不用說交易在被打包進區塊之前還要通過mempool進行廣播)。
當Starkware在2019年進行一項實驗時,他們在交易數據gas成本降低後首次發布了500kB的區塊,一些節點實際上無法處理這種大小的區塊。處理大區塊的能力已經並將持續得到改善。但是無論我們做什麼,我們仍然無法獲取以MB/秒為單位的平均帶寬,說服自己我們可以接受1秒的延遲,並且有能力處理那種大小的區塊。
存儲
錯誤答案:10TB
正確答案:512GB
正如大家可能猜到的,這里的主要論點與其他地方相同:理論與實踐之間的差異。理論上,我們可以在亞馬遜上購買8TB固態驅動(確實需要SSD或NVME;HDD對於區塊鏈狀態存儲來說太慢了)。實際上,我用來寫這篇博文的筆記本電腦有512GB,如果你讓人們去購買硬體,許多人就會變得懶惰(或者他們無法負擔800美元的8TBSSD)並使用中心化服務。即使可以將區塊鏈裝到某個存儲設備上,大量活動也可以快速地耗盡磁碟並迫使你購入新磁碟。
一群區塊鏈協議研究員對每個人的磁碟空間進行了調查。我知道樣本量很小,但仍然...
此外,存儲大小決定了新節點能夠上線並開始參與網路所需的時間。現有節點必須存儲的任何數據都是新節點必須下載的數據。這個初始同步時間(和帶寬)也是用戶能夠運行節點的主要障礙。在寫這篇博文時,同步一個新的geth節點花了我大約15個小時。如果以太坊的使用量增加10倍,那麼同步一個新的geth節點將至少需要一周時間,而且更有可能導致節點的互聯網連接受到限制。這在攻擊期間更為重要,當用戶之前未運行節點時對攻擊做出成功響應需要用戶啟用新節點。
交互效應
此外,這三類成本之間存在交互效應。由於資料庫在內部使用樹結構來存儲和檢索數據,因此從資料庫中獲取數據的成本隨著資料庫大小的對數而增加。事實上,因為頂級(或前幾級)可以緩存在RAM中,所以磁碟訪問成本與資料庫大小成正比,是RAM中緩存數據大小的倍數。
不要從字面上理解這個圖,不同的資料庫以不同的方式工作,通常內存中的部分只是一個單獨(但很大)的層(參見leveldb中使用的LSM樹)。但基本原理是一樣的。
例如,如果緩存為4GB,並且我們假設資料庫的每一層比上一層大4倍,那麼以太坊當前的~64GB狀態將需要~2次訪問。但是如果狀態大小增加4倍到~256GB,那麼這將增加到~3次訪問。因此,gas上限增加4倍實際上可以轉化為區塊驗證時間增加約6倍。這種影響可能會更大:硬碟在已滿狀態下比空閑時需要花更長時間來讀寫。
這對以太坊來說意味著什麼?
現在在以太坊區塊鏈中,運行一個節點對許多用戶來說已經是一項挑戰,盡管至少使用常規硬體仍然是可能的(我寫這篇文章時剛剛在我的筆記本電腦上同步了一個節點!)。因此,我們即將遭遇瓶頸。核心開發者最關心的問題是存儲大小。因此,目前在解決計算和數據瓶頸方面的巨大努力,甚至對共識演算法的改變,都不太可能帶來gaslimit的大幅提升。即使解決了以太坊最大的DoS弱點,也只能將gaslimit提高20%。
對於存儲大小的問題,唯一解決方案是無狀態和狀態逾期。無狀態使得節點群能夠在不維護永久存儲的情況下進行驗證。狀態逾期會使最近未訪問過的狀態失活,用戶需要手動提供證明來更新。這兩條路徑已經研究了很長時間,並且已經開始了關於無狀態的概念驗證實現。這兩項改進相結合可以大大緩解這些擔憂,並為顯著提升gaslimit開辟空間。但即使在實施無狀態和狀態逾期之後,gaslimit也可能只會安全地提升約3倍,直到其他限制開始發揮作用。
另一個可能的中期解決方案使使用ZK-SNARKs來驗證交易。ZK-SNARKs能夠保證普通用戶無需個人存儲狀態或是驗證區塊,即使他們仍然需要下載區塊中的所有數據來抵禦數據不可用攻擊。另外,即使攻擊者不能強行提交無效區塊,但是如果運行一個共識節點的難度過高,依然會有協調審查攻擊的風險。因此,ZK-SNARKs不能無限地提升節點能力,但是仍然能夠對其進行大幅提升(或許是1-2個數量級)。一些區塊鏈在layer1上探索該形式,以太坊則通過layer2協議(也叫ZKrollups)來獲益,例如zksync,Loopring和Starknet。
分片之後又會如何?
分片從根本上解決了上述限制,因為它將區塊鏈上包含的數據與單個節點需要處理和存儲的數據解耦了。節點驗證區塊不是通過親自下載和執行,而是使用先進的數學和密碼學技術來間接驗證區塊。
因此,分片區塊鏈可以安全地擁有非分片區塊鏈無法實現的非常高水平的吞吐量。這確實需要大量的密碼學技術來有效替代樸素完整驗證,以拒絕無效區塊,但這是可以做到的:該理論已經具備了基礎,並且基於草案規范的概念驗證已經在進行中。
以太坊計劃採用二次方分片(quadraticsharding),其中總可擴展性受到以下事實的限制:節點必須能夠同時處理單個分片和信標鏈,而信標鏈必須為每個分片執行一些固定的管理工作。如果分片太大,節點就不能再處理單個分片,如果分片太多,節點就不能再處理信標鏈。這兩個約束的乘積構成了上限。
可以想像,通過三次方分片甚至指數分片,我們可以走得更遠。在這樣的設計中,數據可用性采樣肯定會變得更加復雜,但這是可以實現的。但以太坊並沒有超越二次方,原因在於,從交易分片到交易分片的分片所獲得的額外可擴展性收益實際上無法在其他風險程度可接受的前提下實現。
那麼這些風險是什麼呢?
最低用戶數量
可以想像,只要有一個用戶願意參與,非分片區塊鏈就可以運行。但分片區塊鏈並非如此:單個節點無法處理整條鏈,因此需要足夠的節點以共同處理區塊鏈。如果每個節點可以處理50TPS,而鏈可以處理10000TPS,那麼鏈至少需要200個節點才能存續。如果鏈在任何時候都少於200個節點,那可能會出現節點無法再保持同步,或者節點停止檢測無效區塊,或者還可能會發生許多其他壞事,具體取決於節點軟體的設置。
在實踐中,由於需要冗餘(包括數據可用性采樣),安全的最低數量比簡單的「鏈TPS除以節點TPS」高幾倍,對於上面的例子,我們將其設置位1000個節點。
如果分片區塊鏈的容量增加10倍,則最低用戶數也增加10倍。現在大家可能會問:為什麼我們不從較低的容量開始,當用戶很多時再增加,因為這是我們的實際需要,用戶數量回落再降低容量?
這里有幾個問題:
區塊鏈本身無法可靠地檢測到其上有多少唯一用戶,因此需要某種治理來檢測和設置分片數量。對容量限制的治理很容易成為分裂和沖突的根源。
如果許多用戶突然同時意外掉線怎麼辦?
增加啟動分叉所需的最低用戶數量,使得防禦惡意控制更加艱難。
最低用戶數為1,000,這幾乎可以說是沒問題的。另一方面,最低用戶數設為100萬,這肯定是不行。即使最低用戶數為10,000也可以說開始變得有風險。因此,似乎很難證明超過幾百個分片的分片區塊鏈是合理的。
歷史可檢索性
用戶真正珍視的區塊鏈重要屬性是永久性。當公司破產或是維護該生態系統不再產生利益時,存儲在伺服器上的數字資產將在10年內不再存在。而以太坊上的NFT是永久的。
是的,到2372年人們仍能夠下載並查閱你的加密貓。
但是一旦區塊鏈的容量過高,存儲所有這些數據就會變得更加困難,直到某時出現巨大風險,某些歷史數據最終將……沒人存儲。
要量化這種風險很容易。以區塊鏈的數據容量(MB/sec)為單位,乘以~30得到每年存儲的數據量(TB)。當前的分片計劃的數據容量約為1.3MB/秒,因此約為40TB/年。如果增加10倍,則為400TB/年。如果我們不僅希望可以訪問數據,而且是以一種便捷的方式,我們還需要元數據(例如解壓縮匯總交易),因此每年達到4PB,或十年後達到40PB。InternetArchive(互聯網檔案館)使用50PB。所以這可以說是分片區塊鏈的安全大小上限。
因此,看起來在這兩個維度上,以太坊分片設計實際上已經非常接近合理的最大安全值。常數可以增加一點,但不能增加太多。
結語
嘗試擴容區塊鏈的方法有兩種:基礎的技術改進和簡單地提升參數。首先,提升參數聽起來很有吸引力:如果您是在餐紙上進行數學運算,這就很容易讓自己相信消費級筆記本電腦每秒可以處理數千筆交易,不需要ZK-SNARK、rollups或分片。不幸的是,有很多微妙的理由可以解釋為什麼這種方法是有根本缺陷的。
運行區塊鏈節點的計算機無法使用100%的CPU來驗證區塊鏈;他們需要很大的安全邊際來抵抗意外的DoS攻擊,他們需要備用容量來執行諸如在內存池中處理交易之類的任務,並且用戶不希望在計算機上運行節點的時候無法同時用於任何其他應用。帶寬也會受限:10MB/s的連接並不意味著每秒可以處理10MB的區塊!也許每12秒才能處理1-5MB的塊。存儲也是一樣,提高運行節點的硬體要求並且限制專門的節點運行者並不是解決方案。對於去中心化的區塊鏈而言,普通用戶能夠運行節點並形成一種文化,即運行節點是一種普遍行為,這一點至關重要。
區塊鏈網路擁堵怎麼辦1
什麼是網路擁堵
通常指的是一種網路故障現象:某辦公區域網計算機使用一個帶路由功能的ADSLModem+HUB共享上網。當同一時間上網人數較少的時候網路比較通暢,上網人數多了以後網路會時斷時通,並且HUB的Collision指示燈會閃爍不停。
而在區塊鏈的應用程序中,無論是數字貨幣、智能合約、去中心的交易系統等,它們的網路都是由一個個獨立的節點組成的,發生在節點中的各種操作,比如轉賬交易、合約狀態的變更等,都會以交易事務的數據形式廣播到網路中,通過礦工打包到新的區塊,作為主鏈的一部分而最終確認所有的這些操作。
當節點很多,使用量很多的時候,大量發生的交易就會來不及在正常期望的時間內被打包,因為它們都擁堵在網路中,這些等待的被確認的交易數據通常會維持在節點的內存池中。這個就是區塊鏈的擁堵。
2
網路擁堵是怎麼發生的
目前比特幣區塊大小為1M,每秒大約只能處理7個交易。隨著交易量不斷增長,比特幣網路已經難以迅速地進行轉賬交易確認,區塊鏈網路時常出現擁堵。
區塊鏈網路上最高時有上萬筆交易積壓,某些轉賬交易手續費高達幾十美元,網路擁堵時,交易甚至需要花費好幾天才能被打包。
實際上對於每一類區塊鏈應用來說,這個問題都是存在的,造成不斷有用戶抱怨交易延遲的問題,但也側面證明了應用的廣泛,以及用戶體量的增加。
那麼發生這些問題,我們應該怎麼辦呢?
3
網路擁堵怎麼解決
解決的方法,無非有如下幾種。
第一種擴容,提高處理能力。
第二種截流,限制區塊鏈包的數量。
通過將上述兩種方法進行綜合。
悉尼大學研究者研發了一種新型的區塊鏈系統,在100台機器中能夠實現每秒44萬筆交易的吞吐量,而Visa每秒的交易處理器是5.6萬筆。相比之下,比特幣每秒的交易限制在7筆,以太坊區塊鏈則為20筆。
JadeChain公鏈系統上線後,將徹底解決JADE生態應用中的網路擁堵問題。