導航:首頁 > 以太坊區 > 以太坊技術詳解與實戰pdf

以太坊技術詳解與實戰pdf

發布時間:2023-08-28 09:22:06

A. 《區塊鏈原理、設計與應用》pdf下載在線閱讀,求百度網盤雲資源

《區塊鏈原理、設計與應用》(楊保華)電子書網盤下載免費在線閱讀

資源鏈接:

鏈接:https://pan..com/s/1DdjQcCL5D84cnoqm-HcBjg 提取碼:8u8b

書名:區塊鏈原理、設計與應用

作者:楊保華

豆瓣評分:7.2

出版社:機械工業出版社

出版年份:2017-8-21

頁數:366

內容簡介:

本書由超級賬本核心設計和開發者撰寫,是區塊鏈開發落地專業指南。由淺入深,系統化介紹超級賬本Fabric設計精華、應用開發等。全書分為理論篇和實踐篇兩大部分;第1~3章介紹區塊鏈技術的由來、核心思想及典型的應用場景;第4~5章重點介紹區塊鏈技術中大量出現的分布式系統技術和密碼學安全技術;第6~8章介紹區塊鏈領域的三個典型開源項目:比特幣以太坊以及超級賬本;第9~11章以超級賬本 Fabric 項目為例,具體講解了安裝部署、配置管理,以及使用 Fabric CA 進行證書管理的實踐經驗;第12章重點剖析超級賬本 Fabric 項目的核心架構設計;第13章介紹區塊鏈應用開發的相關技巧和示例;第14章介紹區塊鏈服務平台的設計與開發,並講解應用超級賬本 Cello 項目構建服務平台的相關知識。本書覆蓋了區塊鏈和分布式賬本領域的最新技術,可幫助讀者深入理解區塊鏈核心原理和典型設計實現,以及高效地開發基於區塊鏈平台的分布式應用。

作者簡介:

楊保華

博士,畢業於清華大學。超級賬本(Hyperledger)大中華區技術工作組主席,IBM 大中華區Blockchain技術社區首席顧問,資深研究員。曾主持多個大規模系統平台的架構設計和研發實施,是區塊鏈、雲計算、大數據等技術的早期研究者和實踐者。他熱愛開源技術,曾貢獻於OpenStack、OpenDaylight 等開源項目,是超級賬本Fabric項目的核心設計和開發者,Cello和Fabric-SDK-Py項目的發起人。個人主頁為https://yeasy.github.com。

陳昌

畢業於清華大學。紙貴科技 CTO,曾任 IBM 高級研究員。技術方向包括雲計算、區塊鏈、機器學習等。他是區塊鏈技術的早期研究和推動者,是超級賬本(Hyperledger)項目的核心開發者。他有豐富的區塊鏈應用實踐經驗,曾負責金融行業區塊鏈解決方案的架構設計和實施,並主導開發了若干區塊鏈服務平台。

B. 《以太坊技術詳解與實戰》pdf下載在線閱讀全文,求百度網盤雲資源

《以太坊技術詳解與實戰》(閆鶯)電子書網盤下載免費在線閱讀

鏈接:

提取碼: vcdy

書名:以太坊技術詳解與實戰

作者:閆鶯

豆瓣評分:7.7

出版社:機械工業出版社

出版年份:2018-4-3

頁數:226

內容簡介:

以太坊創始人、首席科學家Vitalik Buterin傾力推薦,工業界與學術界區塊鏈專家聯合撰寫,權威性和實用性毋庸置疑。本書深入剖析以太坊架構、核心部件、智能合約編寫與開發案例等關鍵技術,並涵蓋以太坊數據分析、性能優化、隱私與數據安全等前沿實踐與進展。

作者簡介:

閆鶯 (博士),微軟亞洲研究院主管研究員,區塊鏈領域負責人,微軟Coco區塊鏈平台中國負責人。中國軟體協會區塊鏈創業學院及區塊鏈專委會專家、中國電子學會區塊鏈專家委員。專注與區塊鏈技術、大數據分析、資料庫以及雲計算的研究。在區塊鏈領域獲得多項國際專利,並在資料庫和雲計算 領域國際頂級會議和期刊發表論文30餘篇。參與翻譯《區塊鏈項目開發指南》。

鄭凱 (博士),電子科技大學教授,博士生導師,澳大利亞昆士蘭大學計算機科學博士。主要研究領域為區塊鏈數據管理,以及時空數據挖掘、不確定資料庫、內存資料庫、圖資料庫等。在資料庫、數據挖掘等領域的重要會議和期刊發表論文100餘篇,被累積引用1500餘次。2013年獲澳大利亞優秀青年基金,2015年獲資料庫頂級會議ICDE最佳論文獎。擔任資料庫領域知名國際會議的程序主席和聯合執行主席,國際SCI期刊客座編委,以及數十個國際等級會議的程序委員。

郭眾鑫 微軟亞洲研究院研發工程師,微軟Coco區塊鏈平台核心開發者。專注於區塊鏈技術、大數據分析、分布式系統等方面的研究和開發。

C. 求《以太坊技術詳解與實戰》全文免費下載百度網盤資源,謝謝~

《以太坊技術詳解與實戰》網路網盤pdf最新全集下載:
鏈接:https://pan..com/s/1HmyD7a7cRfM4ICqhAk3PeA

?pwd=vpub 提取碼:vpub
簡介:本書得到以太坊創始人、首席科學家Vitalik Buterin認可與推薦,是為數不多系統性介紹以太坊的書籍,涵蓋架構、核心概念、部署、智能合約實踐等,並涵蓋多個讀者關心的熱點主題。

D. 以太坊是什麼丨以太坊開發入門指南

以太坊是什麼丨以太坊開發入門指南
很多同學已經躍躍欲試投入到區塊鏈開發隊伍當中來,可是又感覺無從下手,本文將基於以太坊平台,以通俗的方式介紹以太坊開發中涉及的各晦澀的概念,輕松帶大家入門。
以太坊是什麼
以太坊(Ethereum)是一個建立在區塊鏈技術之上, 去中心化應用平台。它允許任何人在平台中建立和使用通過區塊鏈技術運行的去中心化應用。
對這句話不理解的同學,姑且可以理解為以太坊是區塊鏈里的Android,它是一個開發平台,讓我們就可以像基於Android Framework一樣基於區塊鏈技術寫應用。
在沒有以太坊之前,寫區塊鏈應用是這樣的:拷貝一份比特幣代碼,然後去改底層代碼如加密演算法,共識機制,網路協議等等(很多山寨幣就是這樣,改改就出來一個新幣)。
以太坊平台對底層區塊鏈技術進行了封裝,讓區塊鏈應用開發者可以直接基於以太坊平台進行開發,開發者只要專注於應用本身的開發,從而大大降低了難度。
目前圍繞以太坊已經形成了一個較為完善的開發生態圈:有社區的支持,有很多開發框架、工具可以選擇。
智能合約
什麼是智能合約
以太坊上的程序稱之為智能合約, 它是代碼和數據(狀態)的集合。
智能合約可以理解為在區塊鏈上可以自動執行的(由事件驅動的)、以代碼形式編寫的合同(特殊的交易)。
在比特幣腳本中,我們講到過比特幣的交易是可以編程的,但是比特幣腳本有很多的限制,能夠編寫的程序也有限,而以太坊則更加完備(在計算機科學術語中,稱它為是「圖靈完備的」),讓我們就像使用任何高級語言一樣來編寫幾乎可以做任何事情的程序(智能合約)。
智能合約非常適合對信任、安全和持久性要求較高的應用場景,比如:數字貨幣、數字資產、投票、保險、金融應用、預測市場、產權所有權管理、物聯網、點對點交易等等。
目前除數字貨幣之外,真正落地的應用還不多(就像移動平台剛開始出來一樣),相信1到3年內,各種殺手級會慢慢出現。
編程語言:Solidity
智能合約的默認的編程語言是Solidity,文件擴展名以.sol結尾。
Solidity是和JavaScript相似的語言,用它來開發合約並編譯成以太坊虛擬機位元組代碼。
還有長像Python的智能合約開發語言:Serpent,不過建議大家還是使用Solidity。
Browser-Solidity是一個瀏覽器的Solidity IDE, 大家可以點進去看看,以後我們更多文章介紹Solidity這個語言。
運行環境:EVM
EVM(Ethereum Virtual Machine)以太坊虛擬機是以太坊中智能合約的運行環境。
Solidity之於EVM,就像之於跟JVM的關系一樣,這樣大家就容易理解了。
以太坊虛擬機是一個隔離的環境,在EVM內部運行的代碼不能跟外部有聯系。
而EVM運行在以太坊節點上,當我們把合約部署到以太坊網路上之後,合約就可以在以太坊網路中運行了。
合約的編譯
以太坊虛擬機上運行的是合約的位元組碼形式,需要我們在部署之前先對合約進行編譯,可以選擇Browser-Solidity Web IDE或solc編譯器。
合約的部署
在以太坊上開發應用時,常常要使用到以太坊客戶端(錢包)。平時我們在開發中,一般不接觸到客戶端或錢包的概念,它是什麼呢?
以太坊客戶端(錢包)
以太坊客戶端,其實我們可以把它理解為一個開發者工具,它提供賬戶管理、挖礦、轉賬、智能合約的部署和執行等等功能。
EVM是由以太坊客戶端提供的。
Geth是典型的開發以太坊時使用的客戶端,基於Go語言開發。 Geth提供了一個互動式命令控制台,通過命令控制台中包含了以太坊的各種功能(API)。Geth的使用我們之後會有文章介紹,這里大家先有個概念。
Geth控制台和Chrome瀏覽器開發者工具里的面的控制台是類似,不過是跑在終端里。
相對於Geth,Mist則是圖形化操作界面的以太坊客戶端。
如何部署
智能合約的部署是指把合約位元組碼發布到區塊鏈上,並使用一個特定的地址來標示這個合約,這個地址稱為合約賬戶。
以太坊中有兩類賬戶:
· 外部賬戶
該類賬戶被私鑰控制(由人控制),沒有關聯任何代碼。
· 合約賬戶
該類賬戶被它們的合約代碼控制且有代碼與之關聯。
和比特幣使用UTXO的設計不一樣,以太坊使用更為簡單的賬戶概念。
兩類賬戶對於EVM來說是一樣的。
外部賬戶與合約賬戶的區別和關系是這樣的:一個外部賬戶可以通過創建和用自己的私鑰來對交易進行簽名,來發送消息給另一個外部賬戶或合約賬戶。
在兩個外部賬戶之間傳送消息是價值轉移的過程。但從外部賬戶到合約賬戶的消息會激活合約賬戶的代碼,允許它執行各種動作(比如轉移代幣,寫入內部存儲,挖出一個新代幣,執行一些運算,創建一個新的合約等等)。
只有當外部賬戶發出指令時,合同賬戶才會執行相應的操作。
合約部署就是將編譯好的合約位元組碼通過外部賬號發送交易的形式部署到以太坊區塊鏈上(由實際礦工出塊之後,才真正部署成功)。
運行
合約部署之後,當需要調用這個智能合約的方法時只需要向這個合約賬戶發送消息(交易)即可,通過消息觸發後智能合約的代碼就會在EVM中執行了。
Gas
和雲計算相似,佔用區塊鏈的資源(不管是簡單的轉賬交易,還是合約的部署和執行)同樣需要付出相應的費用(天下沒有免費的午餐對不對!)。
以太坊上用Gas機制來計費,Gas也可以認為是一個工作量單位,智能合約越復雜(計算步驟的數量和類型,佔用的內存等),用來完成運行就需要越多Gas。
任何特定的合約所需的運行合約的Gas數量是固定的,由合約的復雜度決定。
而Gas價格由運行合約的人在提交運行合約請求的時候規定,以確定他願意為這次交易願意付出的費用:Gas價格(用以太幣計價) * Gas數量。
Gas的目的是限制執行交易所需的工作量,同時為執行支付費用。當EVM執行交易時,Gas將按照特定規則被逐漸消耗,無論執行到什麼位置,一旦Gas被耗盡,將會觸發異常。當前調用幀所做的所有狀態修改都將被回滾, 如果執行結束還有Gas剩餘,這些Gas將被返還給發送賬戶。
如果沒有這個限制,就會有人寫出無法停止(如:死循環)的合約來阻塞網路。
因此實際上(把前面的內容串起來),我們需要一個有以太幣余額的外部賬戶,來發起一個交易(普通交易或部署、運行一個合約),運行時,礦工收取相應的工作量費用。
以太坊網路
有些著急的同學要問了,沒有以太幣,要怎麼進行智能合約的開發?可以選擇以下方式:
選擇以太坊官網測試網路Testnet
測試網路中,我們可以很容易獲得免費的以太幣,缺點是需要發很長時間初始化節點。
使用私有鏈
創建自己的以太幣私有測試網路,通常也稱為私有鏈,我們可以用它來作為一個測試環境來開發、調試和測試智能合約。
通過上面提到的Geth很容易就可以創建一個屬於自己的測試網路,以太幣想挖多少挖多少,也免去了同步正式網路的整個區塊鏈數據。
使用開發者網路(模式)
相比私有鏈,開發者網路(模式)下,會自動分配一個有大量余額的開發者賬戶給我們使用。
使用模擬環境
另一個創建測試網路的方法是使用testrpc,testrpc是在本地使用內存模擬的一個以太坊環境,對於開發調試來說,更方便快捷。而且testrpc可以在啟動時幫我們創建10個存有資金的測試賬戶。
進行合約開發時,可以在testrpc中測試通過後,再部署到Geth節點中去。
更新:testrpc 現在已經並入到Truffle 開發框架中,現在名字是Ganache CLI。
Dapp:去中心化的應用程序
以太坊社區把基於智能合約的應用稱為去中心化的應用程序(DecentralizedApp)。如果我們把區塊鏈理解為一個不可篡改的資料庫,智能合約理解為和資料庫打交道的程序,那就很容易理解Dapp了,一個Dapp不單單有智能合約,比如還需要有一個友好的用戶界面和其他的東西。
Truffle
Truffle是Dapp開發框架,他可以幫我們處理掉大量無關緊要的小事情,讓我們可以迅速開始寫代碼-編譯-部署-測試-打包DApp這個流程。
總結
我們現在來總結一下,以太坊是平台,它讓我們方便的使用區塊鏈技術開發去中心化的應用,在這個應用中,使用Solidity來編寫和區塊鏈交互的智能合約,合約編寫好後之後,我們需要用以太坊客戶端用一個有餘額的賬戶去部署及運行合約(使用Truffle框架可以更好的幫助我們做這些事情了)。為了開發方便,我們可以用Geth或testrpc來搭建一個測試網路。
註:本文中為了方便大家理解,對一些概念做了類比,有些嚴格來不是准確,不過我也認為對於初學者,也沒有必要把每一個概念掌握的很細致和准確,學習是一個逐步深入的過程,很多時候我們會發現,過一段後,我們會對同一個東西有不一樣的理解。

E. 《區塊鏈項目開發指南》pdf下載在線閱讀,求百度網盤雲資源

《區塊鏈項目開發指南》(納拉揚·普魯斯蒂 (Narayan Prusty))電子書網盤下載免費在線閱讀

資源鏈接:

鏈接:

提取碼:qcqe

書名:區塊鏈項目開發指南

作者:納拉揚·普魯斯蒂 (Narayan Prusty)

譯者:朱軒彤

豆瓣評分:5.7

出版社:機械工業出版社

出版年份:2017-12-8

頁數:198

內容簡介:

區塊鏈是近十年來頗具顛覆性的新興信息技術之一,它正以一種全新的方式建立人類交易過程的信任、仲裁和記錄基礎。本書共9章,首先介紹去中心化應用、DApp等基本概念,並據此展開對比特幣、以太坊、超級賬本等熱門DApp的闡釋。其次在解析以太坊工作原理的基礎上介紹智能合約的編寫方法,並介紹web3.js的應用方法。後利用上述知識進行錢包服務、智能合約部署平台、投注App、企業級智能合約以及聯盟區塊鏈等具體應用程序的創建。

作者簡介:

作者:(印度)納拉揚·普魯斯蒂 譯者:朱軒彤 譯者:閆鶯 譯者:董寧

納拉揚·普魯斯蒂,在18歲時就創建了一個MP3搜索引擎,他是一位身兼多職的開發人員,主攻區塊鏈和JavaScript,傾向於使用以太坊、比特幣、超級分類、IPFS等構建去中心化的應用程序。其所編寫的可擴展應用程序廣泛應用於印度、新加坡、美國等國家的初創公司、企業以及政府部門。Narayan Prusty目前供職於迪拜的阿聯酋國家銀行的區塊鏈企業。他著有《Learning ECMAScript 6》和《Modern JavaScript Applications》。朱軒彤,清華大學碩士,中國社科院數量經濟與技術經濟研究所博士生,專注於技術經濟及管理研究。在政府及國際組織有豐富的工作經驗。閆鶯,復旦大學博士,微軟亞洲研究院主管研究員,Coco區塊鏈中國負責人,專注於區塊鏈技術、大數據分析、資料庫以及雲計算的研究。董寧,智鏈ChainNova CEO,北京大學新一代信息技術研究院金融科技研究中心主任,原IBM大中華區lT經濟學負責人,IBM區塊鏈社區發起人。

F. 《區塊鏈核心技術與應用》pdf下載在線閱讀全文,求百度網盤雲資源

《區塊鏈核心技術與應用》(鄒均)電子書網盤下載免費在線閱讀

鏈接:

提取碼: r1fw

書名:區塊鏈核心技術與應用

作者:鄒均

豆瓣評分:8.6

出版社:機械工業出版社

出版年份:2018-8-1

頁數:388

內容簡介:

知名專家聯袂推薦,實力專家聯合撰寫,權威性、全面性、透徹性毋庸置疑。深度講解區塊鏈核心技術、平台與應用開發,涵蓋架構、共識、加密、P2P、比特幣、以太坊、Hyperledger、EOS、潛力框架、問題與測評等。本書分為三篇,內容解讀如下。

基礎篇(第1~6章),著重講解區塊鏈技術思想、通用架構和核心技術。該部分寫作時注意通俗易懂且兼顧全局,是學習基石與藍圖,涵蓋區塊鏈思想與價值、通用架構模型、基礎概念與核心技術(加密、共識、P2P網路等)。

實戰篇(第7~9章),講解主流的區塊鏈開發平台比特幣、以太坊、Hyperledger Fabric的核心機制、技術細節,並給出點對點的電子現金系統、智能合約開發、完整的Fabric網路構建與應用開發三個案例。

進階篇(10~12章),為進一步提升讀者開發能力、眼界與研究方向,涵蓋三個方面:① 可能的發展方向,以及一些富有潛力、特色的區塊鏈平台(EOS、Cardano、IOTA等);② 區塊鏈開發需要考慮的各種問題,包括技術局限、各種安全問題與漏洞、應對措施;③區塊鏈測評,從6個層面和8大類質量指標來設計區塊鏈項目評測點和測試用例。

作者簡介:

鄒均 於斌 庄鵬 邢春曉 等著:鄒均,廣電運通區塊鏈科技有限公司CEO、中關村區塊鏈聯盟副秘書長。主編技術暢銷書《區塊鏈技術指南》,在領先的國際會議和期刊上發表論文20餘篇,其中區塊鏈論文獲IEEE ICWS最佳論文獎,共識演算法論文由國際頂級期刊《Transaction on Service Computing》收錄並刊登。曾榮獲澳中校友會「傑出校友獎」、麥考瑞大學「校長獎」。

於斌,現任北郵在線教育投資集團總裁、中國電子學會區塊鏈專委會委員、中關村區塊鏈產業聯盟專家,是上海財經大學,亞洲財經商學院特聘教授。北京郵電大學通信與信息系統專業博士,主編《金融科技概論》等專著4本,曾獲得國家科技進步二等獎,教育部一等獎。網路教育、金融科技、區塊鏈等領域專家。

庄鵬, IBM全球服務金融服務部高級顧問經理、資深架構師。14年金融行業架構設計與戰略咨詢規劃經驗。擁有豐富的服務轉型、大型企業級分布式系統架構設計、大數據分析、金融支付方面的豐富實施經驗。最近三年專注於區塊鏈和分布式賬本架構研究,區塊鏈相關應用和數字貨幣咨詢研究,多次作為區塊鏈峰會的講師、培訓專家。

邢春曉,清華大學信息技術研究院和互聯網產業研究院副院長,主要研究領域:計算機軟體與理論,資料庫和數據倉庫、大數據管理和分析,知識工程和軟體工程、區塊鏈與數字經濟、智慧城市(政務,商務,文化和醫療健康)等領域。發表學術論文350餘篇,其中SCI 40餘篇、EI 150餘篇,發明專利40項。

G. 以太坊技術系列-以太坊數據結構

本篇文章和大家介紹一下以太坊的數據結構,上篇文章我們提到,以太坊為了實現智能合約這一功能,使用了基於賬戶的模型。我們來看看以太坊中數據結構。

既然是基於賬戶的模型,我們需要通過賬戶地址找到賬戶的狀態。就像通過銀行卡號可以找到你在銀行中的各種信息一樣。最簡單的想法當然是一個簡單的哈希表 key是賬戶地址 value是賬戶狀態。但這里有個問題解決不了。

輕節點如何校驗賬戶合法性?

上篇我們說過,區塊鏈中有2類節點,全節點和輕節點,輕節點只會存儲block header,所以輕節點如何才能校驗賬號是否合法呢?

這個思路和我們平時用的md5校驗一致,我們會對區塊內的信息進行hash運算從而得出區塊內信息唯一確定的值,區塊鏈所有節點中這個值都是相同的。

在這個過程中我們用到了一種數據結構Merkle Tree(哈希樹),我們先看下Merkle Tree(哈希樹)的示意圖。

上篇文章說到區塊鏈中的鏈表(哈希鏈)和我們平時常見鏈表不同的是將指針從地址改為了hash指,這里也一樣,哈希樹和二叉樹的區別有2個

1.將地址改為了哈希值

2.只有葉子節點存儲數據

回到之前的問題輕節點是如何校驗1個賬戶或交易是否是在鏈上的呢?

整個流程如上圖所示

1.輕節點需要判斷1個賬號是否合法

2.輕節點由於只存儲block header,所以拿到1個賬號的時候會向全節點發出請求

3.全節點存儲了所有賬戶狀態,將賬戶路徑中的需要計算用到的hash值返回給輕節點

4.輕節點本地進行計算根hash值,如果計算結果和自己存儲一致則賬戶合法,不一致則不合法。

那以太坊中的賬戶信息的數據結構就是這樣嗎?

直接用這樣的數據結構來存儲賬戶信息會有2個問題

查找困難

生成hash值不確定

第1個問題應該比較容易發現,在這個樹中尋找1個賬號需要的復雜度是O(n),因為沒有任何順序。

第2個問題其實也是因為無序導致的,無序的組合每個節點針對同一批賬戶生成的hash值不一致,這就導致無法達成共識。

既然2個問題都和順序有關,那我們類似二叉排序樹一樣,使用哈希排序樹是不是就可以解決問題了呢?

使用排序樹後會帶來另外1個問題

插入困難

因為要維持樹是有序的,很可能帶來樹結構的很大變動。

以太坊中使用了另外一種數據結構字典樹。和哈希樹不同,字典樹應該是很多地方都有使用。我們簡單來看下字典樹的結構。

字典樹能夠較好地解決哈希樹的2個缺點1.查找困難 2.生成的hash值不確定以及排序二叉樹的1個缺點 插入困難。

但字典樹我們可以看到可能樹的深度可能由於部分元素導致整棵樹深度非常深。

這時我們可以進一步優化,將相同路徑進行壓縮。這就是壓縮字典樹。

將哈希樹和壓縮字典樹結合,就可以得到以太坊存儲賬戶的最終數據結構-MPT。

將壓縮字典樹裡面的指針從地址改為指針,並且將數據存儲在葉子節點中即可。

介紹完狀態樹的數據結構,我們接下來討論1個問題,區塊中存儲的賬戶狀態是什麼樣的范圍。有2種選擇。

只保存當時區塊中產生交易的賬戶狀態。

保存全局所有的賬戶。

我們可以看下這2種方式,無非就是空間和時間的平衡,只保存當前區塊產生的交易意味著是做懶載入(需要的時候才去尋找賬戶),在區塊鏈中這個代價是非常大的,因為尋找的賬戶之前從未交易過,這樣會遍歷整個區塊鏈。另外一種保存全局的賬戶方式雖然看起來空間消耗較大,但查找快捷,而且空間的問題我們可以通過其他方式優化。所以最終以太坊選擇了第2種每個區塊都報錯全局所有賬戶的方式。

我們來看下以太坊中是如何保存狀態樹的。

可以看到以太坊中雖然每個區塊都保存了全部賬戶,但是會將未發生變化的賬戶狀態指向前1個節點,本身只存儲發生變化的狀態,這樣可以較大程度優化空間佔用。

介紹完以太坊中比較復雜的狀態樹後,我們繼續來看看以太坊中的另外兩棵樹,交易樹和收據樹。

首先介紹一下,為什麼需要交易樹&收據樹。

1.交易樹

雖然以太坊是基於賬戶的模型,但是就像銀行不僅會存儲銀行卡的余額,還會存儲卡中的每筆錢怎麼來的以及怎麼花的。交易樹中就存儲著當前區塊中的包含的所有交易。

2.收據樹

由於智能合約的引入增加了不少復雜性,所以以太坊用收據樹存儲著一些交易操作的額外信息。比如交易過程中執行日誌就包含在收據樹中方便查詢。收據樹和交易樹是一一對應的。每發生一次交易就會有一次收據。

和狀態樹不同交易樹和收據樹只維護當前區塊內發生的交易,因為當時區塊發生交易時不需要再去查找另外1個交易,也就之前需要可能遍歷整個區塊鏈的查找操作了。

由於以太坊中的出塊速度較快,我們進行一些查詢一些符合條件交易的時候會面臨大量數據遍歷困難的問題。收據樹中引入了布隆過濾器可以幫助我們有效緩解這一困難。

布隆過濾器將大集合中每個元素進行hash運算映射到1個較小的集合,這時再來1個元素要判斷是否在大集合的時候,不需要遍歷整個大集合,而是去進行hash運算去小集合中尋找是否存在,如果不存在,肯定不在大集合中,如果存在則不能說明任何問題。

如上圖所示,布隆過濾器只能證明某1個元素不在集合中,不能證明1個元素在結合中。

以太坊中如果我們要在較多區塊中尋找某1個交易,則可以利用布隆過濾器,過濾掉肯定不存在目標交易的區塊,然後進入收據樹內繼續利用布隆過濾器篩選,剩下的才是可能的目標交易的交易,進行一一比對即可。

我們介紹了以太坊的核心數據結構,狀態樹&交易樹&收據樹,他們都是使用相同的數據結構-哈希壓縮字典樹。但狀態樹是維護1顆全局賬戶樹,交易樹和收據樹則是維護本區塊內的交易或收據。

介紹完數據結構後,後面我們會用幾篇文章來介紹以太坊中的一些核心演算法,比如共識機制,挖礦演算法等。

閱讀全文

與以太坊技術詳解與實戰pdf相關的資料

熱點內容
區塊鏈場景落地 瀏覽:648
小礦工挖比特幣是真的嗎 瀏覽:981
世界虛擬貨幣排行榜2019 瀏覽:509
虛擬貨幣屬於詐騙嗎 瀏覽:754
比特幣中國現況 瀏覽:559
區塊鏈教育最新消息 瀏覽:203
以太坊合約數量 瀏覽:2
區塊鏈做社區 瀏覽:303
人民幣比索比特幣 瀏覽:833
比特幣在中國匯率 瀏覽:149
買以太坊好還是比特幣好 瀏覽:328
比特幣的各國政策 瀏覽:975
挖礦機算力板 瀏覽:56
外圍比特幣價格 瀏覽:385
新聞今日以太坊20關閉了 瀏覽:491
比特幣低頻量化交易 瀏覽:715
比特幣的重大事件 瀏覽:477
主板數字貨幣 瀏覽:803
長沙虛擬貨幣被抓 瀏覽:139
比特幣通過美國elf 瀏覽:137