智能合約調(diào)用是實(shí)現(xiàn)一個(gè) DApp 的關(guān)鍵,一個(gè)完整的 DApp 包括前端、后端、智能合約及區(qū)塊 鏈系統(tǒng),智能合約的調(diào)用是連接區(qū)塊鏈與前后端的關(guān)鍵。
目前創(chuàng)新互聯(lián)建站已為1000+的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)、成都網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計(jì)、明溪網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
我們先來了解一下智能合約調(diào)用的基礎(chǔ)原理。智能合約運(yùn)行在以太坊節(jié)點(diǎn)的 EVM 中。因此要 想調(diào)用合約必須要訪問某個(gè)節(jié)點(diǎn)。
以后端程序?yàn)槔蠖朔?wù)若想連接節(jié)點(diǎn)有兩種可能,一種是雙 方在同一主機(jī),此時(shí)后端連接節(jié)點(diǎn)可以采用 本地 IPC(Inter-Process Communication,進(jìn) 程間通信)機(jī)制,也可以采用 RPC(Remote Procedure Call,遠(yuǎn)程過程調(diào)用)機(jī)制;另 一種情況是雙方不在同一臺主機(jī),此時(shí)只能采用 RPC 機(jī)制進(jìn)行通信。
提到 RPC, 讀者應(yīng)該對 Geth 啟動參數(shù)有點(diǎn)印象,Geth 啟動時(shí)可以選擇開啟 RPC 服務(wù),對應(yīng)的 默認(rèn)服務(wù)端口是 8545。。
接著,我們來了解一下智能合約運(yùn)行的過程。
智能合約的運(yùn)行過程是后端服務(wù)連接某節(jié)點(diǎn),將 智能合約的調(diào)用(交易)發(fā)送給節(jié)點(diǎn),節(jié)點(diǎn)在驗(yàn)證了交易的合法性后進(jìn)行全網(wǎng)廣播,被礦工打包到 區(qū)塊中代表此交易得到確認(rèn),至此交易才算完成。
就像數(shù)據(jù)庫一樣,每個(gè)區(qū)塊鏈平臺都會提供主流 開發(fā)語言的 SDK(Software Development Kit,軟件開發(fā)工具包),由于 Geth 本身就是用 Go 語言 編寫的,因此若想使用 Go 語言連接節(jié)點(diǎn)、發(fā)交易,直接在工程內(nèi)導(dǎo)入 go-ethereum(Geth 源碼) 包就可以了,剩下的問題就是流程和 API 的事情了。
總結(jié)一下,智能合約被調(diào)用的兩個(gè)關(guān)鍵點(diǎn)是節(jié)點(diǎn)和 SDK。
由于 IPC 要求后端與節(jié)點(diǎn)必須在同一主機(jī),所以很多時(shí)候開發(fā)者都會采用 RPC 模式。除了 RPC,以太坊也為開發(fā)者提供了 json- rpc 接口,本文就不展開討論了。
接下來介紹如何使用 Go 語言,借助 go-ethereum 源碼庫來實(shí)現(xiàn)智能合約的調(diào)用。這是有固定 步驟的,我們先來說一下總體步驟,以下面的合約為例。
步驟 01:編譯合約,獲取合約 ABI(Application Binary Interface,應(yīng)用二進(jìn)制接口)。 單擊【ABI】按鈕拷貝合約 ABI 信息,將其粘貼到文件 calldemo.abi 中(可使用 Go 語言IDE 創(chuàng)建該文件,文件名可自定義,后綴最好使用 abi)。
最好能將 calldemo.abi 單獨(dú)保存在一個(gè)目錄下,輸入“l(fā)s”命令只能看到 calldemo.abi 文件,參 考效果如下:
步驟 02:獲得合約地址。注意要將合約部署到 Geth 節(jié)點(diǎn)。因此 Environment 選擇為 Web3 Provider。
在【Environment】選項(xiàng)框中選擇“Web3 Provider”,然后單擊【Deploy】按鈕。
部署后,獲得合約地址為:0xa09209c28AEf59a4653b905792a9a910E78E7407。
步驟 03:利用 abigen 工具(Geth 工具包內(nèi)的可執(zhí)行程序)編譯智能合約為 Go 代碼。abigen 工具的作用是將 abi 文件轉(zhuǎn)換為 Go 代碼,命令如下:
其中各參數(shù)的含義如下。 (1)abi:是指定傳入的 abi 文件。 (2)type:是指定輸出文件中的基本結(jié)構(gòu)類型。 (3)pkg:指定輸出文件 package 名稱。 (4)out:指定輸出文件名。 執(zhí)行后,將在代碼目錄下看到 funcdemo.go 文件,讀者可以打開該文件欣賞一下,注意不要修改它。
步驟 04:創(chuàng)建 main.go,填入如下代碼。 注意代碼中 HexToAddress 函數(shù)內(nèi)要傳入該合約部署后的地址,此地址在步驟 01 中獲得。
步驟 04:設(shè)置 go mod,以便工程自動識別。
前面有所提及,若要使用 Go 語言調(diào)用智能合約,需要下載 go-ethereum 工程,可以使用下面 的指令:
該指令會自動將 go-ethereum 下載到“$GOPATH/src/github.com/ethereum/go-ethereum”,這樣還算 不錯(cuò)。不過,Go 語言自 1.11 版本后,增加了 module 管理工程的模式。只要設(shè)置好了 go mod,下載 依賴工程的事情就不必關(guān)心了。
接下來設(shè)置 module 生效和 GOPROXY,命令如下:
在項(xiàng)目工程內(nèi),執(zhí)行初始化,calldemo 可以自定義名稱。
步驟 05:運(yùn)行代碼。執(zhí)行代碼,將看到下面的效果,以及最終輸出的 2020。
上述輸出信息中,可以看到 Go 語言會自動下載依賴文件,這就是 go mod 的神奇之處??吹?2020,相信讀者也知道運(yùn)行結(jié)果是正確的了。
Fabric區(qū)塊鏈開發(fā)詳解,本課程面向初學(xué)者,內(nèi)容即包含Hyperledger Fabric的身份證書與MSP服務(wù)、權(quán)限策略、通道配置與啟動、鏈碼通信接口等核心概念,也包含F(xiàn)abric網(wǎng)絡(luò)設(shè)計(jì)、鏈碼與應(yīng)用開發(fā)的操作實(shí)踐,是學(xué)習(xí)Fabric區(qū)塊鏈開發(fā)的最佳選擇。
給你個(gè)免費(fèi)區(qū)塊鏈博客看看。
區(qū)塊鏈平臺,是要看區(qū)塊鏈資訊的嗎,這里安利個(gè) 密碼財(cái)經(jīng),一般鏈圈幣圈dapp等信息都能看到。
怎么設(shè)置區(qū)塊鏈的名字,分2步驟,第一是打開瀏覽器輸入?yún)^(qū)塊鏈網(wǎng),第二是再輸入你需要設(shè)置的名字。
鏈代碼(Chaincode)又稱為智能合約,是用Go語言編寫的程序,主要用于操作賬本上的數(shù)據(jù)。鏈代碼是運(yùn)行在區(qū)塊鏈上的、特定條件下自動執(zhí)行的代碼邏輯,是用戶利用區(qū)塊鏈實(shí)現(xiàn)業(yè)務(wù)邏輯的重要途徑?;趨^(qū)塊鏈特點(diǎn),智能合約的運(yùn)行結(jié)果是可信的,其結(jié)果是無法被偽造和篡改的。在使用區(qū)塊鏈服務(wù)時(shí),用戶需要開發(fā)自己的鏈代碼和應(yīng)用程序。用戶的應(yīng)用程序通過區(qū)塊
區(qū)塊鏈服務(wù)狀態(tài)為“彈性IP異常”。排查項(xiàng):彈性公網(wǎng)IP已“解綁”或被釋放。在BCS控制臺,服務(wù)管理頁面中的目標(biāo)服務(wù)卡片中,單擊“更多 更新訪問地址”查看彈性公網(wǎng)IP。登錄網(wǎng)絡(luò)控制臺,查找目標(biāo)彈性公網(wǎng)IP并查看其狀態(tài)。若彈性公網(wǎng)IP已“解綁”:登錄網(wǎng)絡(luò)控制臺,在目標(biāo)彈性公網(wǎng)IP的操作列單擊“綁定”,完成后刷新BCS控制臺的服務(wù)管理頁面。
區(qū)塊鏈技術(shù)概念
區(qū)塊鏈技術(shù)概念,現(xiàn)如今,區(qū)塊鏈已經(jīng)成為大部分人關(guān)注的領(lǐng)域,很多企業(yè)也早已深入其中研究該技術(shù)情況,但是還有人對于它不是很了解,下面我分享一篇關(guān)于區(qū)塊鏈技術(shù)概念的相關(guān)信息。
區(qū)塊鏈技術(shù)概念1
區(qū)塊鏈的基本概念和工作原理
1、基本概念
區(qū)塊鏈?zhǔn)欠植际綌?shù)據(jù)存儲、點(diǎn)對點(diǎn)傳輸、共識機(jī)制、加密算法等計(jì)算機(jī)技術(shù)的新型應(yīng)用模式。所謂共識機(jī)制是區(qū)塊鏈系統(tǒng)中實(shí)現(xiàn)不同節(jié)點(diǎn)之間建立信任、獲取權(quán)益的數(shù)學(xué)算法。
區(qū)塊鏈Blockchain、是比特幣的一個(gè)重要概念,它本質(zhì)上是一個(gè)去中心化的數(shù)據(jù)庫,同時(shí)作為比特幣的底層技術(shù)。區(qū)塊鏈?zhǔn)且淮褂妹艽a學(xué)方法相關(guān)聯(lián)產(chǎn)生的數(shù)據(jù)塊,每一個(gè)數(shù)據(jù)塊中包含了一次比特幣網(wǎng)絡(luò)交易的信息,用于驗(yàn)證其信息的有效性防偽、和生成下一個(gè)區(qū)塊。
狹義來講,區(qū)塊鏈?zhǔn)且环N按照時(shí)間順序?qū)?shù)據(jù)區(qū)塊以順序相連的方式組合成的一種鏈?zhǔn)綌?shù)據(jù)結(jié)構(gòu), 并以密碼學(xué)方式保證的不可篡改和不可偽造的分布式賬本。
廣義來講,區(qū)塊鏈技術(shù)是利用塊鏈?zhǔn)綌?shù)據(jù)結(jié)構(gòu)來驗(yàn)證與存儲數(shù)據(jù)、利用分布式節(jié)點(diǎn)共識算法來生成和更新數(shù)據(jù)、利用密碼學(xué)的方式保證數(shù)據(jù)傳輸和訪問的安全、利用由自動化腳本代碼組成的智能合約來編程和操作數(shù)據(jù)的一種全新的分布式基礎(chǔ)架構(gòu)與計(jì)算方式。
2、工作原理
區(qū)塊鏈系統(tǒng)由數(shù)據(jù)層、網(wǎng)絡(luò)層、共識層、激勵(lì)層、合約層和應(yīng)用層組成。 其中,數(shù)據(jù)層封裝了底層數(shù)據(jù)區(qū)塊以及相關(guān)的數(shù)據(jù)加密和時(shí)間戳等基礎(chǔ)數(shù)據(jù)和基本算法;網(wǎng)絡(luò)層則包括分布式組網(wǎng)機(jī)制、數(shù)據(jù)傳播機(jī)制和數(shù)據(jù)驗(yàn)證機(jī)制等;共識層主要封裝網(wǎng)絡(luò)節(jié)點(diǎn)的各類共識算法;激勵(lì)層將經(jīng)濟(jì)因素集成到區(qū)塊鏈技術(shù)體系中來,主要包括經(jīng)濟(jì)激勵(lì)的發(fā)行機(jī)制和分配機(jī)制等;合約層主要封裝各類腳本、算法和智能合約,是區(qū)塊鏈可編程特性的基礎(chǔ);應(yīng)用層則封裝了區(qū)塊鏈的各種應(yīng)用場景和案例。該模型中,基于時(shí)間戳的鏈?zhǔn)絽^(qū)塊結(jié)構(gòu)、分布式節(jié)點(diǎn)的共識機(jī)制、基于共識算力的經(jīng)濟(jì)激勵(lì)和靈活可編程的智能合約是區(qū)塊鏈技術(shù)最具代表性的創(chuàng)新點(diǎn)。
區(qū)塊鏈主要解決的交易的信任和安全問題,因此它針對這個(gè)問題提出了四個(gè)技術(shù)創(chuàng)新:
1、分布式賬本,就是交易記賬由分布在不同地方的多個(gè)節(jié)點(diǎn)共同完成,而且每一個(gè)節(jié)點(diǎn)都記錄的是完整的賬目,因此它們都可以參與監(jiān)督交易合法性,同時(shí)也可以共同為其作證。
跟傳統(tǒng)的分布式存儲有所不同,區(qū)塊鏈的分布式存儲的獨(dú)特性主要體現(xiàn)在兩個(gè)方面:一是區(qū)塊鏈每個(gè)節(jié)點(diǎn)都按照塊鏈?zhǔn)浇Y(jié)構(gòu)存儲完整的數(shù)據(jù),傳統(tǒng)分布式存儲一般是將數(shù)據(jù)按照一定的規(guī)則分成多份進(jìn)行存儲。二是區(qū)塊鏈每個(gè)節(jié)點(diǎn)存儲都是獨(dú)立的、地位等同的,依靠共識機(jī)制保證存儲的一致性,而傳統(tǒng)分布式存儲一般是通過中心節(jié)點(diǎn)往其他備份節(jié)點(diǎn)同步數(shù)據(jù)。 [8]
沒有任何一個(gè)節(jié)點(diǎn)可以單獨(dú)記錄賬本數(shù)據(jù),從而避免了單一記賬人被控制或者被賄賂而記假賬的可能性。也由于記賬節(jié)點(diǎn)足夠多,理論上講除非所有的節(jié)點(diǎn)被破壞,否則賬目就不會丟失,從而保證了賬目數(shù)據(jù)的安全性。
2、非對稱加密和授權(quán)技術(shù),存儲在區(qū)塊鏈上的交易信息是公開的,但是賬戶身份信息是高度加密的,只有在數(shù)據(jù)擁有者授權(quán)的情況下才能訪問到,從而保證了數(shù)據(jù)的安全和個(gè)人的隱私。
3、共識機(jī)制,就是所有記賬節(jié)點(diǎn)之間怎么達(dá)成共識,去認(rèn)定一個(gè)記錄的有效性,這既是認(rèn)定的手段,也是防止篡改的手段。區(qū)塊鏈提出了四種不同的共識機(jī)制,適用于不同的應(yīng)用場景,在效率和安全性之間取得平衡。
區(qū)塊鏈的共識機(jī)制具備“少數(shù)服從多數(shù)”以及“人人平等”的特點(diǎn),其中“少數(shù)服從多數(shù)”并不完全指節(jié)點(diǎn)個(gè)數(shù),也可以是計(jì)算能力、股權(quán)數(shù)或者其他的計(jì)算機(jī)可以比較的特征量?!叭巳似降取笔钱?dāng)節(jié)點(diǎn)滿足條件時(shí),所有節(jié)點(diǎn)都有權(quán)優(yōu)先提出共識結(jié)果、直接被其他節(jié)點(diǎn)認(rèn)同后并最后有可能成為最終共識結(jié)果。以比特幣為例,采用的是工作量證明,只有在控制了全網(wǎng)超過51%的記賬節(jié)點(diǎn)的情況下,才有可能偽造出一條不存在的記錄。當(dāng)加入?yún)^(qū)塊鏈的節(jié)點(diǎn)足夠多的時(shí)候,這基本上不可能,從而杜絕了造假的可能.
4、智能合約,智能合約是基于這些可信的不可篡改的數(shù)據(jù),可以自動化的執(zhí)行一些預(yù)先定義好的規(guī)則和條款。以保險(xiǎn)為例,如果說每個(gè)人的信息包括醫(yī)療信息和風(fēng)險(xiǎn)發(fā)生的信息、都是真實(shí)可信的,那就很容易的在一些標(biāo)準(zhǔn)化的保險(xiǎn)產(chǎn)品中,去進(jìn)行自動化的理賠.
3、其它
互聯(lián)網(wǎng)交換的是信息,區(qū)塊鏈交換的是價(jià)值。人類歷史和互聯(lián)網(wǎng)歷史可以用八個(gè)字理解:分久必合合久必分,到了分久必合的時(shí)代,網(wǎng)絡(luò)信息全部散在互聯(lián)網(wǎng)上面,大家要挖掘信息非常不容易,這時(shí)會出現(xiàn)像谷歌和臉 書等的平臺,它做的唯一的事情就是把我們所有的信息重新組合了一下?;ヂ?lián)網(wǎng)時(shí)代壟斷巨頭們重組的就是信息,并不是產(chǎn)生自己的信息,產(chǎn)生的信息完全是我們個(gè)人。一旦信息重組,就會出現(xiàn)一個(gè)新的壟斷巨人,所以就到了分久必合的時(shí)代。現(xiàn)在由于區(qū)塊鏈技術(shù)產(chǎn)生又到了合久必分時(shí)代,又是新的多中心化,新的多中心化之后賦能產(chǎn)生新的價(jià)值,這些數(shù)據(jù)會在我們自己的手上,個(gè)人數(shù)據(jù)產(chǎn)生價(jià)值是歸自己所有,這是這個(gè)時(shí)代最最激動人心的時(shí)代。
區(qū)塊鏈的價(jià)值有哪些?低成本建立信任的機(jī)制,確立數(shù)權(quán),解決數(shù)據(jù)的.產(chǎn)權(quán)。
目前區(qū)塊鏈技術(shù)不斷發(fā)展,包括現(xiàn)在的單鏈向多鏈發(fā)展,而且技術(shù)能夠在進(jìn)一步擴(kuò)展,我想未來還是可能會出現(xiàn),特別是在交易等方面出現(xiàn)顛覆性的,特別是對現(xiàn)有產(chǎn)業(yè)的很多顛覆性的場景。
區(qū)塊鏈的本質(zhì)是在不可信的網(wǎng)絡(luò)建立可信的信息交換。
一帶一路+一鏈。區(qū)塊鏈更大的不是制造信任,而是讓信任產(chǎn)生無損的傳遞,整個(gè)降低社會的摩擦成本,從而提高整個(gè)效益。
現(xiàn)在區(qū)塊鏈本身還是初始階段,所以包括區(qū)塊鏈的信息傳遞、加密,這個(gè)過程中出現(xiàn)量子加密和其他加密,實(shí)際上對區(qū)塊鏈本身所采用的加密算法攻擊現(xiàn)象也時(shí)有發(fā)生。包括區(qū)塊鏈也是作為一種資產(chǎn)的認(rèn)定,數(shù)字資產(chǎn)的一個(gè)認(rèn)定,但是現(xiàn)在我們很多都是用密碼算法,或者是作為我們來解密的鑰匙,但是如果密碼忘記了,很可能你現(xiàn)在的資產(chǎn)就丟掉了,你不能夠在得到你原來的這些資產(chǎn),所以在資產(chǎn)管理,包括信息傳遞和一些安全這些方面,應(yīng)該說都還是存在著一些隱患。當(dāng)然那么從技術(shù)角度,現(xiàn)在我們區(qū)塊鏈本身處理的速度,或者說本身的擴(kuò)展性,因?yàn)閺墓ぷ鳈C(jī)理的角度來看,是要把整個(gè)賬本要復(fù)制給所有的參與人員,所以在區(qū)塊鏈本身的運(yùn)作效率和擴(kuò)展性方面還是比較受限的。這些我們覺得都還是需要進(jìn)一步在技術(shù)方面有進(jìn)一步的發(fā)展。
區(qū)塊鏈平臺這些底層技術(shù),又形成包括區(qū)塊鏈錢包、區(qū)塊鏈瀏覽器、節(jié)點(diǎn)競選、礦機(jī)、礦池、開發(fā)組件、開發(fā)模塊、技術(shù)社區(qū)及項(xiàng)目社群等一系列的生態(tài)系統(tǒng),這些生態(tài)系統(tǒng)的完善程度直接決定著區(qū)塊鏈底層平臺的使用效率和效果。
4、蒙代爾的不可能三角
去中心化、高效、安全,不可能實(shí)現(xiàn)三者全部同時(shí)達(dá)到極致。
區(qū)塊鏈技術(shù)概念2
區(qū)塊鏈的本質(zhì)是一種分布式記賬技術(shù),與之相對的是中心式記賬技術(shù),中心式記賬技術(shù)在我們目前的生活中廣泛存在。區(qū)塊鏈?zhǔn)欠植际綌?shù)據(jù)存儲、點(diǎn)對點(diǎn)傳輸、共識機(jī)制、加密算法等計(jì)算機(jī)技術(shù)的新型應(yīng)用模式。
區(qū)塊鏈Blockchain、,是比特幣的一個(gè)重要概念,它本質(zhì)上是一個(gè)去中心化的數(shù)據(jù)庫,同時(shí)作為比特幣的底層技術(shù),是一串使用密碼學(xué)方法相關(guān)聯(lián)產(chǎn)生的數(shù)據(jù)塊,每一個(gè)數(shù)據(jù)塊中包含了一批次比特幣網(wǎng)絡(luò)交易的信息,用于驗(yàn)證e69da5e887aa7a6431333431343061其信息的有效性防偽、和生成下一個(gè)區(qū)塊。
狹義來講,區(qū)塊鏈?zhǔn)且环N按照時(shí)間順序?qū)?shù)據(jù)區(qū)塊以順序相連的方式組合成的一種鏈?zhǔn)綌?shù)據(jù)結(jié)構(gòu), 并以密碼學(xué)方式保證的不可篡改和不可偽造的分布式賬本。
廣義來講,區(qū)塊鏈技術(shù)是利用塊鏈?zhǔn)綌?shù)據(jù)結(jié)構(gòu)來驗(yàn)證與存儲數(shù)據(jù)、利用分布式節(jié)點(diǎn)共識算法來生成和更新數(shù)據(jù)、利用密碼學(xué)的方式保證數(shù)據(jù)傳輸和訪問的安全、利用由自動化腳本代碼組成的智能合約來編程和操作數(shù)據(jù)的一種全新的分布式基礎(chǔ)架構(gòu)與計(jì)算方式。
區(qū)塊鏈技術(shù)通俗的理解就是:把“物”的前、后、左、右區(qū)塊用一種技術(shù)連接成一個(gè)鏈條,但每個(gè)區(qū)塊的原始數(shù)據(jù)不可篡改,是一種物聯(lián)網(wǎng)范疇的、可以讓參與者信任的“各個(gè)模塊鏈動”的技術(shù)。區(qū)塊鏈技術(shù)的應(yīng)用,離不開互聯(lián)道網(wǎng),也離不開物聯(lián)網(wǎng),是建立在二者融合互動基礎(chǔ)上的、但又讓參與者各自保持獨(dú)回立的去中心化、、并共同擁有這套價(jià)值鏈共建共享、的技術(shù)。
區(qū)塊鏈的特征:去中心化、開放性、自治性、信息不可篡改,匿名性。
區(qū)塊鏈?zhǔn)且粋€(gè)能夠傳遞價(jià)值的網(wǎng)絡(luò),對可以傳遞價(jià)值的網(wǎng)絡(luò)的需求是推動區(qū)塊鏈技術(shù)產(chǎn)生的重要原因。在對于保護(hù)帶有所有權(quán)或者其他價(jià)值的信息需求的推動下,區(qū)塊鏈出現(xiàn)了。區(qū)塊鏈通過公私鑰密碼學(xué)、分布式存儲等技術(shù)手段,一方面保證了帶有價(jià)值的信息的高效傳遞,另一方面保證了這些信息在傳遞的過程中不會被輕易的復(fù)制篡改。
從區(qū)塊鏈誕生的必然性來理解區(qū)塊鏈的內(nèi)涵,區(qū)塊鏈?zhǔn)墙鉀Q了中心化記賬缺點(diǎn)、解決了分布式一致性問題的分布式記賬技術(shù),同時(shí)也是連接互聯(lián)網(wǎng)升級為保證帶有價(jià)值的信息安全高效傳遞的價(jià)值網(wǎng)絡(luò)。
區(qū)塊鏈技術(shù)概念3
區(qū)塊鏈: 區(qū)塊鏈就像是一個(gè)全球唯一的帳簿,或者說是數(shù)據(jù)庫,記錄了網(wǎng)絡(luò)中所有交易歷史。
以太坊虛擬機(jī)(EVM): 它讓你能在以太坊上寫出更強(qiáng)大的程序比特幣上也可以寫腳本程序、。它有時(shí)也用來指以太坊區(qū)塊鏈,負(fù)責(zé)執(zhí)行智能合約以及一切。
節(jié)點(diǎn):你可以運(yùn)行節(jié)點(diǎn),通過它讀寫以太坊區(qū)塊鏈,也即使用以太坊虛擬機(jī)。完全節(jié)點(diǎn)需要下載整個(gè)區(qū)塊鏈。輕節(jié)點(diǎn)仍在開發(fā)中。
礦工:挖礦,也就是處理區(qū)塊鏈上的區(qū)塊的節(jié)點(diǎn)。這個(gè)網(wǎng)頁可以看到當(dāng)前活躍的一部分以太坊礦工:stats.ethdev.com。
工作量證明:礦工們總是在競爭解決一些數(shù)學(xué)問題。第一個(gè)解出答案的(算出下一個(gè)區(qū)塊)將獲得以太幣作為獎(jiǎng)勵(lì)。然后所有節(jié)點(diǎn)都更新自己的區(qū)塊鏈。所有想要算出下一個(gè)區(qū)塊的礦工都有與其他節(jié)點(diǎn)保持同步,并且維護(hù)同一個(gè)區(qū)塊鏈的動力,因此整個(gè)網(wǎng)絡(luò)總是能達(dá)成共識。(注意:以太坊正計(jì)劃轉(zhuǎn)向沒有礦工的權(quán)益證明系統(tǒng)(POS),不過那不在本文討論范圍之內(nèi)。)
以太幣:縮寫ETH。一種你可以購買和使用的真正的數(shù)字貨幣。這里是可以交易以太幣的其中一家交易所的走勢圖。在寫這篇文章的時(shí)候,1個(gè)以太幣價(jià)值65美分。
Gas:在以太坊上執(zhí)行程序以及保存數(shù)據(jù)都要消耗一定量的以太幣,Gas是以太幣轉(zhuǎn)換而成。這個(gè)機(jī)制用來保證效率。
DApp: 以太坊社區(qū)把基于智能合約的應(yīng)用稱為去中心化的應(yīng)用程序(Decentralized App)。DApp的目標(biāo)是(或者應(yīng)該是)讓你的智能合約有一個(gè)友好的界面,外加一些額外的東西,例如IPFS可以存儲和讀取數(shù)據(jù)的去中心化網(wǎng)絡(luò),不是出自以太坊團(tuán)隊(duì)但有類似的精神)。DApp可以跑在一臺能與以太坊節(jié)點(diǎn)交互的中心化服務(wù)器上,也可以跑在任意一個(gè)以太坊平等節(jié)點(diǎn)上。(花一分鐘思考一下:與一般的網(wǎng)站不同,DApp不能跑在普通的服務(wù)器上。他們需要提交交易到區(qū)塊鏈并且從區(qū)塊鏈而不是中心化數(shù)據(jù)庫讀取重要數(shù)據(jù)。相對于典型的用戶登錄系統(tǒng),用戶有可能被表示成一個(gè)錢包地址而其它用戶數(shù)據(jù)保存在本地。許多事情都會與目前的web應(yīng)用有不同架構(gòu)。)
以太坊客戶端,智能合約語言
編寫和部署智能合約并不要求你運(yùn)行一個(gè)以太坊節(jié)點(diǎn)。下面有列出基于瀏覽器的IDE和API。但如果是為了學(xué)習(xí)的話,還是應(yīng)該運(yùn)行一個(gè)以太坊節(jié)點(diǎn),以便理解其中的基本組件,何況運(yùn)行節(jié)點(diǎn)也不難。
運(yùn)行以太坊節(jié)點(diǎn)可用的客戶端
以太坊有許多不同語言的客戶端實(shí)現(xiàn)即多種與以太坊網(wǎng)絡(luò)交互的方法、,包括C++, Go, Python, Java, Haskell等等。為什么需要這么多實(shí)現(xiàn)?不同的實(shí)現(xiàn)能滿足不同的需求例如Haskell實(shí)現(xiàn)的目標(biāo)是可以被數(shù)學(xué)驗(yàn)證、,能使以太坊更加安全,能豐富整個(gè)生態(tài)系統(tǒng)。
在寫作本文時(shí),我使用的是Go語言實(shí)現(xiàn)的客戶端geth (go-ethereum),其他時(shí)候還會使用一個(gè)叫testrpc的工具, 它使用了Python客戶端pyethereum。后面的例子會用到這些工具。
關(guān)于挖礦:挖礦很有趣,有點(diǎn)像精心照料你的室內(nèi)盆栽,同時(shí)又是一種了解整個(gè)系統(tǒng)的方法。雖然以太幣現(xiàn)在的價(jià)格可能連電費(fèi)都補(bǔ)不齊,但以后誰知道呢。人們正在創(chuàng)造許多酷酷的DApp, 可能會讓以太坊越來越流行。
交互式控制臺:客戶端運(yùn)行起來后,你就可以同步區(qū)塊鏈,建立錢包,收發(fā)以太幣了。使用geth的一種方式是通過Javascript控制臺。此外還可以使用類似cURL的命令通過JSON RPC來與客戶端交互。本文的目標(biāo)是帶大家過一邊DApp開發(fā)的流程,因此這塊就不多說了。但是我們應(yīng)該記住這些命令行工具是調(diào)試,配置節(jié)點(diǎn),以及使用錢包的利器。
在測試網(wǎng)絡(luò)運(yùn)行節(jié)點(diǎn): 如果你在正式網(wǎng)絡(luò)運(yùn)行g(shù)eth客戶端,下載整個(gè)區(qū)塊鏈與網(wǎng)絡(luò)同步會需要相當(dāng)時(shí)間。你可以通過比較節(jié)點(diǎn)日志中打印的最后一個(gè)塊號和stats.ethdev.com上列出的最新塊來確定是否已經(jīng)同步。) 另一個(gè)問題是在正式網(wǎng)絡(luò)上跑智能合約需要實(shí)實(shí)在在的以太幣。在測試網(wǎng)絡(luò)上運(yùn)行節(jié)點(diǎn)的話就沒有這個(gè)問題。此時(shí)也不需要同步整個(gè)區(qū)塊鏈,創(chuàng)建一個(gè)自己的私有鏈就勾了,對于開發(fā)來說更省時(shí)間。
Testrpc:用geth可以創(chuàng)建一個(gè)測試網(wǎng)絡(luò),另一種更快的創(chuàng)建測試網(wǎng)絡(luò)的方法是使用testrpc. Testrpc可以在啟動時(shí)幫你創(chuàng)建一堆存有資金的測試賬戶。它的運(yùn)行速度也更快因此更適合開發(fā)和測試。你可以從testrpc起步,然后隨著合約慢慢成型,轉(zhuǎn)移到geth創(chuàng)建的測試網(wǎng)絡(luò)上 - 啟動方法很簡單,只需要指定一個(gè)networkid:geth --networkid "12345"。這里是testrpc的代碼倉庫,下文我們還會再講到它。
接下來我們來談?wù)効捎玫木幊陶Z言,之后就可以開始真正的編程了。寫智能合約用的編程語言用Solidity就好。
要寫智能合約有好幾種語言可選:有點(diǎn)類似Javascript的Solidity, 文件擴(kuò)展名是.sol. 和Python接近的Serpent, 文件名以.se結(jié)尾。還有類似Lisp的LLL。Serpent曾經(jīng)流行過一段時(shí)間,但現(xiàn)在最流行而且最穩(wěn)定的要算是Solidity了,因此用Solidity就好。聽說你喜歡Python? 用Solidity。
solc編譯器: 用Solidity寫好智能合約之后,需要用solc來編譯。它是一個(gè)來自C++客戶端實(shí)現(xiàn)的組件又一次,不同的實(shí)現(xiàn)產(chǎn)生互補(bǔ)、,這里是安裝方法。如果你不想安裝solc也可以直接使用基于瀏覽器的編譯器,例如Solidity real-time compiler或者Cosmo。后文有關(guān)編程的部分會假設(shè)你安裝了solc。
web3.js API. 當(dāng)Solidity合約編譯好并且發(fā)送到網(wǎng)絡(luò)上之后,你可以使用以太坊的web3.js JavaScript API來調(diào)用它,構(gòu)建能與之交互的web應(yīng)用。
開發(fā)框架。level1編程項(xiàng)目這是一個(gè)基于go語言編寫的,自動化測試以太坊智能合約的開發(fā)框架,使用此框架,可以自動化的部署合約,自動測試合約內(nèi)的功能函數(shù)。