區(qū)塊鏈技術(shù)概念
創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、馬尾網(wǎng)絡(luò)推廣、成都微信小程序、馬尾網(wǎng)絡(luò)營(yíng)銷、馬尾企業(yè)策劃、馬尾品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供馬尾建站搭建服務(wù),24小時(shí)服務(wù)熱線:18980820575,官方網(wǎng)址:www.cdcxhl.com
區(qū)塊鏈技術(shù)概念,現(xiàn)如今,區(qū)塊鏈已經(jīng)成為大部分人關(guān)注的領(lǐng)域,很多企業(yè)也早已深入其中研究該技術(shù)情況,但是還有人對(duì)于它不是很了解,下面我分享一篇關(guān)于區(qū)塊鏈技術(shù)概念的相關(guān)信息。
區(qū)塊鏈技術(shù)概念1
區(qū)塊鏈的基本概念和工作原理
1、基本概念
區(qū)塊鏈?zhǔn)欠植际綌?shù)據(jù)存儲(chǔ)、點(diǎn)對(duì)點(diǎn)傳輸、共識(shí)機(jī)制、加密算法等計(jì)算機(jī)技術(shù)的新型應(yīng)用模式。所謂共識(shí)機(jī)制是區(qū)塊鏈系統(tǒng)中實(shí)現(xiàn)不同節(jié)點(diǎn)之間建立信任、獲取權(quán)益的數(shù)學(xué)算法。
區(qū)塊鏈Blockchain、是比特幣的一個(gè)重要概念,它本質(zhì)上是一個(gè)去中心化的數(shù)據(jù)庫(kù),同時(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ū)塊。
狹義來(lái)講,區(qū)塊鏈?zhǔn)且环N按照時(shí)間順序?qū)?shù)據(jù)區(qū)塊以順序相連的方式組合成的一種鏈?zhǔn)綌?shù)據(jù)結(jié)構(gòu), 并以密碼學(xué)方式保證的不可篡改和不可偽造的分布式賬本。
廣義來(lái)講,區(qū)塊鏈技術(shù)是利用塊鏈?zhǔn)綌?shù)據(jù)結(jié)構(gòu)來(lái)驗(yàn)證與存儲(chǔ)數(shù)據(jù)、利用分布式節(jié)點(diǎn)共識(shí)算法來(lái)生成和更新數(shù)據(jù)、利用密碼學(xué)的方式保證數(shù)據(jù)傳輸和訪問(wèn)的安全、利用由自動(dòng)化腳本代碼組成的智能合約來(lái)編程和操作數(shù)據(jù)的一種全新的分布式基礎(chǔ)架構(gòu)與計(jì)算方式。
2、工作原理
區(qū)塊鏈系統(tǒng)由數(shù)據(jù)層、網(wǎng)絡(luò)層、共識(shí)層、激勵(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ī)制等;共識(shí)層主要封裝網(wǎng)絡(luò)節(jié)點(diǎn)的各類共識(shí)算法;激勵(lì)層將經(jīng)濟(jì)因素集成到區(qū)塊鏈技術(shù)體系中來(lái),主要包括經(jīng)濟(jì)激勵(lì)的發(fā)行機(jī)制和分配機(jī)制等;合約層主要封裝各類腳本、算法和智能合約,是區(qū)塊鏈可編程特性的基礎(chǔ);應(yīng)用層則封裝了區(qū)塊鏈的各種應(yīng)用場(chǎng)景和案例。該模型中,基于時(shí)間戳的鏈?zhǔn)絽^(qū)塊結(jié)構(gòu)、分布式節(jié)點(diǎn)的共識(shí)機(jī)制、基于共識(shí)算力的經(jīng)濟(jì)激勵(lì)和靈活可編程的智能合約是區(qū)塊鏈技術(shù)最具代表性的創(chuàng)新點(diǎn)。
區(qū)塊鏈主要解決的交易的信任和安全問(wèn)題,因此它針對(duì)這個(gè)問(wèn)題提出了四個(gè)技術(shù)創(chuàng)新:
1、分布式賬本,就是交易記賬由分布在不同地方的多個(gè)節(jié)點(diǎn)共同完成,而且每一個(gè)節(jié)點(diǎn)都記錄的是完整的賬目,因此它們都可以參與監(jiān)督交易合法性,同時(shí)也可以共同為其作證。
跟傳統(tǒng)的分布式存儲(chǔ)有所不同,區(qū)塊鏈的分布式存儲(chǔ)的獨(dú)特性主要體現(xiàn)在兩個(gè)方面:一是區(qū)塊鏈每個(gè)節(jié)點(diǎn)都按照塊鏈?zhǔn)浇Y(jié)構(gòu)存儲(chǔ)完整的數(shù)據(jù),傳統(tǒng)分布式存儲(chǔ)一般是將數(shù)據(jù)按照一定的規(guī)則分成多份進(jìn)行存儲(chǔ)。二是區(qū)塊鏈每個(gè)節(jié)點(diǎn)存儲(chǔ)都是獨(dú)立的、地位等同的,依靠共識(shí)機(jī)制保證存儲(chǔ)的一致性,而傳統(tǒng)分布式存儲(chǔ)一般是通過(guò)中心節(jié)點(diǎn)往其他備份節(jié)點(diǎn)同步數(shù)據(jù)。 [8]
沒(méi)有任何一個(gè)節(jié)點(diǎn)可以單獨(dú)記錄賬本數(shù)據(jù),從而避免了單一記賬人被控制或者被賄賂而記假賬的可能性。也由于記賬節(jié)點(diǎn)足夠多,理論上講除非所有的節(jié)點(diǎn)被破壞,否則賬目就不會(huì)丟失,從而保證了賬目數(shù)據(jù)的安全性。
2、非對(duì)稱加密和授權(quán)技術(shù),存儲(chǔ)在區(qū)塊鏈上的交易信息是公開(kāi)的,但是賬戶身份信息是高度加密的,只有在數(shù)據(jù)擁有者授權(quán)的情況下才能訪問(wèn)到,從而保證了數(shù)據(jù)的安全和個(gè)人的隱私。
3、共識(shí)機(jī)制,就是所有記賬節(jié)點(diǎn)之間怎么達(dá)成共識(shí),去認(rèn)定一個(gè)記錄的有效性,這既是認(rèn)定的手段,也是防止篡改的手段。區(qū)塊鏈提出了四種不同的共識(shí)機(jī)制,適用于不同的應(yīng)用場(chǎng)景,在效率和安全性之間取得平衡。
區(qū)塊鏈的共識(shí)機(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)先提出共識(shí)結(jié)果、直接被其他節(jié)點(diǎn)認(rèn)同后并最后有可能成為最終共識(shí)結(jié)果。以比特幣為例,采用的是工作量證明,只有在控制了全網(wǎng)超過(guò)51%的記賬節(jié)點(diǎn)的情況下,才有可能偽造出一條不存在的記錄。當(dāng)加入?yún)^(qū)塊鏈的節(jié)點(diǎn)足夠多的時(shí)候,這基本上不可能,從而杜絕了造假的可能.
4、智能合約,智能合約是基于這些可信的不可篡改的數(shù)據(jù),可以自動(dòng)化的執(zhí)行一些預(yù)先定義好的規(guī)則和條款。以保險(xiǎn)為例,如果說(shuō)每個(gè)人的信息包括醫(yī)療信息和風(fēng)險(xiǎn)發(fā)生的信息、都是真實(shí)可信的,那就很容易的在一些標(biāo)準(zhǔn)化的保險(xiǎn)產(chǎn)品中,去進(jìn)行自動(dòng)化的理賠.
3、其它
互聯(lián)網(wǎng)交換的是信息,區(qū)塊鏈交換的是價(jià)值。人類歷史和互聯(lián)網(wǎng)歷史可以用八個(gè)字理解:分久必合合久必分,到了分久必合的時(shí)代,網(wǎng)絡(luò)信息全部散在互聯(lián)網(wǎng)上面,大家要挖掘信息非常不容易,這時(shí)會(huì)出現(xiàn)像谷歌和臉 書(shū)等的平臺(tái),它做的唯一的事情就是把我們所有的信息重新組合了一下。互聯(lián)網(wǎng)時(shí)代壟斷巨頭們重組的就是信息,并不是產(chǎn)生自己的信息,產(chǎn)生的信息完全是我們個(gè)人。一旦信息重組,就會(huì)出現(xiàn)一個(gè)新的壟斷巨人,所以就到了分久必合的時(shí)代?,F(xiàn)在由于區(qū)塊鏈技術(shù)產(chǎn)生又到了合久必分時(shí)代,又是新的多中心化,新的多中心化之后賦能產(chǎn)生新的價(jià)值,這些數(shù)據(jù)會(huì)在我們自己的手上,個(gè)人數(shù)據(jù)產(chǎn)生價(jià)值是歸自己所有,這是這個(gè)時(shí)代最最激動(dòng)人心的時(shí)代。
區(qū)塊鏈的價(jià)值有哪些?低成本建立信任的機(jī)制,確立數(shù)權(quán),解決數(shù)據(jù)的.產(chǎn)權(quán)。
目前區(qū)塊鏈技術(shù)不斷發(fā)展,包括現(xiàn)在的單鏈向多鏈發(fā)展,而且技術(shù)能夠在進(jìn)一步擴(kuò)展,我想未來(lái)還是可能會(huì)出現(xiàn),特別是在交易等方面出現(xiàn)顛覆性的,特別是對(duì)現(xiàn)有產(chǎn)業(yè)的很多顛覆性的場(chǎng)景。
區(qū)塊鏈的本質(zhì)是在不可信的網(wǎng)絡(luò)建立可信的信息交換。
一帶一路+一鏈。區(qū)塊鏈更大的不是制造信任,而是讓信任產(chǎn)生無(wú)損的傳遞,整個(gè)降低社會(huì)的摩擦成本,從而提高整個(gè)效益。
現(xiàn)在區(qū)塊鏈本身還是初始階段,所以包括區(qū)塊鏈的信息傳遞、加密,這個(gè)過(guò)程中出現(xiàn)量子加密和其他加密,實(shí)際上對(duì)區(qū)塊鏈本身所采用的加密算法攻擊現(xiàn)象也時(shí)有發(fā)生。包括區(qū)塊鏈也是作為一種資產(chǎn)的認(rèn)定,數(shù)字資產(chǎn)的一個(gè)認(rèn)定,但是現(xiàn)在我們很多都是用密碼算法,或者是作為我們來(lái)解密的鑰匙,但是如果密碼忘記了,很可能你現(xiàn)在的資產(chǎn)就丟掉了,你不能夠在得到你原來(lái)的這些資產(chǎn),所以在資產(chǎn)管理,包括信息傳遞和一些安全這些方面,應(yīng)該說(shuō)都還是存在著一些隱患。當(dāng)然那么從技術(shù)角度,現(xiàn)在我們區(qū)塊鏈本身處理的速度,或者說(shuō)本身的擴(kuò)展性,因?yàn)閺墓ぷ鳈C(jī)理的角度來(lái)看,是要把整個(gè)賬本要復(fù)制給所有的參與人員,所以在區(qū)塊鏈本身的運(yùn)作效率和擴(kuò)展性方面還是比較受限的。這些我們覺(jué)得都還是需要進(jìn)一步在技術(shù)方面有進(jìn)一步的發(fā)展。
區(qū)塊鏈平臺(tái)這些底層技術(shù),又形成包括區(qū)塊鏈錢包、區(qū)塊鏈瀏覽器、節(jié)點(diǎn)競(jìng)選、礦機(jī)、礦池、開(kāi)發(fā)組件、開(kāi)發(fā)模塊、技術(shù)社區(qū)及項(xiàng)目社群等一系列的生態(tài)系統(tǒng),這些生態(tài)系統(tǒng)的完善程度直接決定著區(qū)塊鏈底層平臺(tái)的使用效率和效果。
4、蒙代爾的不可能三角
去中心化、高效、安全,不可能實(shí)現(xiàn)三者全部同時(shí)達(dá)到極致。
區(qū)塊鏈技術(shù)概念2
區(qū)塊鏈的本質(zhì)是一種分布式記賬技術(shù),與之相對(duì)的是中心式記賬技術(shù),中心式記賬技術(shù)在我們目前的生活中廣泛存在。區(qū)塊鏈?zhǔn)欠植际綌?shù)據(jù)存儲(chǔ)、點(diǎn)對(duì)點(diǎn)傳輸、共識(shí)機(jī)制、加密算法等計(jì)算機(jī)技術(shù)的新型應(yīng)用模式。
區(qū)塊鏈Blockchain、,是比特幣的一個(gè)重要概念,它本質(zhì)上是一個(gè)去中心化的數(shù)據(jù)庫(kù),同時(shí)作為比特幣的底層技術(shù),是一串使用密碼學(xué)方法相關(guān)聯(lián)產(chǎn)生的數(shù)據(jù)塊,每一個(gè)數(shù)據(jù)塊中包含了一批次比特幣網(wǎng)絡(luò)交易的信息,用于驗(yàn)證e69da5e887aa7a6431333431343061其信息的有效性防偽、和生成下一個(gè)區(qū)塊。
狹義來(lái)講,區(qū)塊鏈?zhǔn)且环N按照時(shí)間順序?qū)?shù)據(jù)區(qū)塊以順序相連的方式組合成的一種鏈?zhǔn)綌?shù)據(jù)結(jié)構(gòu), 并以密碼學(xué)方式保證的不可篡改和不可偽造的分布式賬本。
廣義來(lái)講,區(qū)塊鏈技術(shù)是利用塊鏈?zhǔn)綌?shù)據(jù)結(jié)構(gòu)來(lái)驗(yàn)證與存儲(chǔ)數(shù)據(jù)、利用分布式節(jié)點(diǎn)共識(shí)算法來(lái)生成和更新數(shù)據(jù)、利用密碼學(xué)的方式保證數(shù)據(jù)傳輸和訪問(wèn)的安全、利用由自動(dòng)化腳本代碼組成的智能合約來(lái)編程和操作數(shù)據(jù)的一種全新的分布式基礎(chǔ)架構(gòu)與計(jì)算方式。
區(qū)塊鏈技術(shù)通俗的理解就是:把“物”的前、后、左、右區(qū)塊用一種技術(shù)連接成一個(gè)鏈條,但每個(gè)區(qū)塊的原始數(shù)據(jù)不可篡改,是一種物聯(lián)網(wǎng)范疇的、可以讓參與者信任的“各個(gè)模塊鏈動(dòng)”的技術(shù)。區(qū)塊鏈技術(shù)的應(yīng)用,離不開(kāi)互聯(lián)道網(wǎng),也離不開(kāi)物聯(lián)網(wǎng),是建立在二者融合互動(dòng)基礎(chǔ)上的、但又讓參與者各自保持獨(dú)回立的去中心化、、并共同擁有這套價(jià)值鏈共建共享、的技術(shù)。
區(qū)塊鏈的特征:去中心化、開(kāi)放性、自治性、信息不可篡改,匿名性。
區(qū)塊鏈?zhǔn)且粋€(gè)能夠傳遞價(jià)值的網(wǎng)絡(luò),對(duì)可以傳遞價(jià)值的網(wǎng)絡(luò)的需求是推動(dòng)區(qū)塊鏈技術(shù)產(chǎn)生的重要原因。在對(duì)于保護(hù)帶有所有權(quán)或者其他價(jià)值的信息需求的推動(dòng)下,區(qū)塊鏈出現(xiàn)了。區(qū)塊鏈通過(guò)公私鑰密碼學(xué)、分布式存儲(chǔ)等技術(shù)手段,一方面保證了帶有價(jià)值的信息的高效傳遞,另一方面保證了這些信息在傳遞的過(guò)程中不會(huì)被輕易的復(fù)制篡改。
從區(qū)塊鏈誕生的必然性來(lái)理解區(qū)塊鏈的內(nèi)涵,區(qū)塊鏈?zhǔn)墙鉀Q了中心化記賬缺點(diǎn)、解決了分布式一致性問(wèn)題的分布式記賬技術(shù),同時(shí)也是連接互聯(lián)網(wǎng)升級(jí)為保證帶有價(jià)值的信息安全高效傳遞的價(jià)值網(wǎng)絡(luò)。
區(qū)塊鏈技術(shù)概念3
區(qū)塊鏈: 區(qū)塊鏈就像是一個(gè)全球唯一的帳簿,或者說(shuō)是數(shù)據(jù)庫(kù),記錄了網(wǎng)絡(luò)中所有交易歷史。
以太坊虛擬機(jī)(EVM): 它讓你能在以太坊上寫出更強(qiáng)大的程序比特幣上也可以寫腳本程序、。它有時(shí)也用來(lái)指以太坊區(qū)塊鏈,負(fù)責(zé)執(zhí)行智能合約以及一切。
節(jié)點(diǎn):你可以運(yùn)行節(jié)點(diǎn),通過(guò)它讀寫以太坊區(qū)塊鏈,也即使用以太坊虛擬機(jī)。完全節(jié)點(diǎn)需要下載整個(gè)區(qū)塊鏈。輕節(jié)點(diǎn)仍在開(kāi)發(fā)中。
礦工:挖礦,也就是處理區(qū)塊鏈上的區(qū)塊的節(jié)點(diǎn)。這個(gè)網(wǎng)頁(yè)可以看到當(dāng)前活躍的一部分以太坊礦工:stats.ethdev.com。
工作量證明:礦工們總是在競(jìng)爭(zhēng)解決一些數(shù)學(xué)問(wèn)題。第一個(gè)解出答案的(算出下一個(gè)區(qū)塊)將獲得以太幣作為獎(jiǎng)勵(lì)。然后所有節(jié)點(diǎn)都更新自己的區(qū)塊鏈。所有想要算出下一個(gè)區(qū)塊的礦工都有與其他節(jié)點(diǎn)保持同步,并且維護(hù)同一個(gè)區(qū)塊鏈的動(dòng)力,因此整個(gè)網(wǎng)絡(luò)總是能達(dá)成共識(shí)。(注意:以太坊正計(jì)劃轉(zhuǎn)向沒(méi)有礦工的權(quán)益證明系統(tǒng)(POS),不過(guò)那不在本文討論范圍之內(nèi)。)
以太幣:縮寫ETH。一種你可以購(gòu)買和使用的真正的數(shù)字貨幣。這里是可以交易以太幣的其中一家交易所的走勢(shì)圖。在寫這篇文章的時(shí)候,1個(gè)以太幣價(jià)值65美分。
Gas:在以太坊上執(zhí)行程序以及保存數(shù)據(jù)都要消耗一定量的以太幣,Gas是以太幣轉(zhuǎn)換而成。這個(gè)機(jī)制用來(lái)保證效率。
DApp: 以太坊社區(qū)把基于智能合約的應(yīng)用稱為去中心化的應(yīng)用程序(Decentralized App)。DApp的目標(biāo)是(或者應(yīng)該是)讓你的智能合約有一個(gè)友好的界面,外加一些額外的東西,例如IPFS可以存儲(chǔ)和讀取數(shù)據(jù)的去中心化網(wǎng)絡(luò),不是出自以太坊團(tuán)隊(duì)但有類似的精神)。DApp可以跑在一臺(tái)能與以太坊節(jié)點(diǎn)交互的中心化服務(wù)器上,也可以跑在任意一個(gè)以太坊平等節(jié)點(diǎn)上。(花一分鐘思考一下:與一般的網(wǎng)站不同,DApp不能跑在普通的服務(wù)器上。他們需要提交交易到區(qū)塊鏈并且從區(qū)塊鏈而不是中心化數(shù)據(jù)庫(kù)讀取重要數(shù)據(jù)。相對(duì)于典型的用戶登錄系統(tǒng),用戶有可能被表示成一個(gè)錢包地址而其它用戶數(shù)據(jù)保存在本地。許多事情都會(huì)與目前的web應(yīng)用有不同架構(gòu)。)
以太坊客戶端,智能合約語(yǔ)言
編寫和部署智能合約并不要求你運(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)可用的客戶端
以太坊有許多不同語(yǔ)言的客戶端實(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語(yǔ)言實(shí)現(xiàn)的客戶端geth (go-ethereum),其他時(shí)候還會(huì)使用一個(gè)叫testrpc的工具, 它使用了Python客戶端pyethereum。后面的例子會(huì)用到這些工具。
關(guān)于挖礦:挖礦很有趣,有點(diǎn)像精心照料你的室內(nèi)盆栽,同時(shí)又是一種了解整個(gè)系統(tǒng)的方法。雖然以太幣現(xiàn)在的價(jià)格可能連電費(fèi)都補(bǔ)不齊,但以后誰(shuí)知道呢。人們正在創(chuàng)造許多酷酷的DApp, 可能會(huì)讓以太坊越來(lái)越流行。
交互式控制臺(tái):客戶端運(yùn)行起來(lái)后,你就可以同步區(qū)塊鏈,建立錢包,收發(fā)以太幣了。使用geth的一種方式是通過(guò)Javascript控制臺(tái)。此外還可以使用類似cURL的命令通過(guò)JSON RPC來(lái)與客戶端交互。本文的目標(biāo)是帶大家過(guò)一邊DApp開(kāi)發(fā)的流程,因此這塊就不多說(shuō)了。但是我們應(yīng)該記住這些命令行工具是調(diào)試,配置節(jié)點(diǎn),以及使用錢包的利器。
在測(cè)試網(wǎng)絡(luò)運(yùn)行節(jié)點(diǎn): 如果你在正式網(wǎng)絡(luò)運(yùn)行g(shù)eth客戶端,下載整個(gè)區(qū)塊鏈與網(wǎng)絡(luò)同步會(huì)需要相當(dāng)時(shí)間。你可以通過(guò)比較節(jié)點(diǎn)日志中打印的最后一個(gè)塊號(hào)和stats.ethdev.com上列出的最新塊來(lái)確定是否已經(jīng)同步。) 另一個(gè)問(wèn)題是在正式網(wǎng)絡(luò)上跑智能合約需要實(shí)實(shí)在在的以太幣。在測(cè)試網(wǎng)絡(luò)上運(yùn)行節(jié)點(diǎn)的話就沒(méi)有這個(gè)問(wèn)題。此時(shí)也不需要同步整個(gè)區(qū)塊鏈,創(chuàng)建一個(gè)自己的私有鏈就勾了,對(duì)于開(kāi)發(fā)來(lái)說(shuō)更省時(shí)間。
Testrpc:用geth可以創(chuàng)建一個(gè)測(cè)試網(wǎng)絡(luò),另一種更快的創(chuàng)建測(cè)試網(wǎng)絡(luò)的方法是使用testrpc. Testrpc可以在啟動(dòng)時(shí)幫你創(chuàng)建一堆存有資金的測(cè)試賬戶。它的運(yùn)行速度也更快因此更適合開(kāi)發(fā)和測(cè)試。你可以從testrpc起步,然后隨著合約慢慢成型,轉(zhuǎn)移到geth創(chuàng)建的測(cè)試網(wǎng)絡(luò)上 - 啟動(dòng)方法很簡(jiǎn)單,只需要指定一個(gè)networkid:geth --networkid "12345"。這里是testrpc的代碼倉(cāng)庫(kù),下文我們還會(huì)再講到它。
接下來(lái)我們來(lái)談?wù)効捎玫木幊陶Z(yǔ)言,之后就可以開(kāi)始真正的編程了。寫智能合約用的編程語(yǔ)言用Solidity就好。
要寫智能合約有好幾種語(yǔ)言可選:有點(diǎn)類似Javascript的Solidity, 文件擴(kuò)展名是.sol. 和Python接近的Serpent, 文件名以.se結(jié)尾。還有類似Lisp的LLL。Serpent曾經(jīng)流行過(guò)一段時(shí)間,但現(xiàn)在最流行而且最穩(wěn)定的要算是Solidity了,因此用Solidity就好。聽(tīng)說(shuō)你喜歡Python? 用Solidity。
solc編譯器: 用Solidity寫好智能合約之后,需要用solc來(lái)編譯。它是一個(gè)來(lái)自C++客戶端實(shí)現(xiàn)的組件又一次,不同的實(shí)現(xiàn)產(chǎn)生互補(bǔ)、,這里是安裝方法。如果你不想安裝solc也可以直接使用基于瀏覽器的編譯器,例如Solidity real-time compiler或者Cosmo。后文有關(guān)編程的部分會(huì)假設(shè)你安裝了solc。
web3.js API. 當(dāng)Solidity合約編譯好并且發(fā)送到網(wǎng)絡(luò)上之后,你可以使用以太坊的web3.js JavaScript API來(lái)調(diào)用它,構(gòu)建能與之交互的web應(yīng)用。
這是以太坊提供的一個(gè)可以讀取區(qū)塊鏈賬本中數(shù)據(jù)的接口,參數(shù)依次表示所要讀取存儲(chǔ)的賬戶地址、存儲(chǔ)相對(duì)索引位置、以及區(qū)塊號(hào)。可以參見(jiàn)web3.eth.getStorageAt接口以及以太坊ethapi/api.go對(duì)應(yīng)的GetStorageAt函數(shù)。
若解決了你的問(wèn)題,請(qǐng)采納
智能合約調(diào)用是實(shí)現(xiàn)一個(gè) DApp 的關(guān)鍵,一個(gè)完整的 DApp 包括前端、后端、智能合約及區(qū)塊 鏈系統(tǒng),智能合約的調(diào)用是連接區(qū)塊鏈與前后端的關(guān)鍵。
我們先來(lái)了解一下智能合約調(diào)用的基礎(chǔ)原理。智能合約運(yùn)行在以太坊節(jié)點(diǎn)的 EVM 中。因此要 想調(diào)用合約必須要訪問(wèn)某個(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)程過(guò)程調(diào)用)機(jī)制;另 一種情況是雙方不在同一臺(tái)主機(jī),此時(shí)只能采用 RPC 機(jī)制進(jìn)行通信。
提到 RPC, 讀者應(yīng)該對(duì) Geth 啟動(dòng)參數(shù)有點(diǎn)印象,Geth 啟動(dòng)時(shí)可以選擇開(kāi)啟 RPC 服務(wù),對(duì)應(yīng)的 默認(rèn)服務(wù)端口是 8545。。
接著,我們來(lái)了解一下智能合約運(yùn)行的過(guò)程。
智能合約的運(yùn)行過(guò)程是后端服務(wù)連接某節(jié)點(diǎn),將 智能合約的調(diào)用(交易)發(fā)送給節(jié)點(diǎn),節(jié)點(diǎn)在驗(yàn)證了交易的合法性后進(jìn)行全網(wǎng)廣播,被礦工打包到 區(qū)塊中代表此交易得到確認(rèn),至此交易才算完成。
就像數(shù)據(jù)庫(kù)一樣,每個(gè)區(qū)塊鏈平臺(tái)都會(huì)提供主流 開(kāi)發(fā)語(yǔ)言的 SDK(Software Development Kit,軟件開(kāi)發(fā)工具包),由于 Geth 本身就是用 Go 語(yǔ)言 編寫的,因此若想使用 Go 語(yǔ)言連接節(jié)點(diǎn)、發(fā)交易,直接在工程內(nèi)導(dǎo)入 go-ethereum(Geth 源碼) 包就可以了,剩下的問(wèn)題就是流程和 API 的事情了。
總結(jié)一下,智能合約被調(diào)用的兩個(gè)關(guān)鍵點(diǎn)是節(jié)點(diǎn)和 SDK。
由于 IPC 要求后端與節(jié)點(diǎn)必須在同一主機(jī),所以很多時(shí)候開(kāi)發(fā)者都會(huì)采用 RPC 模式。除了 RPC,以太坊也為開(kāi)發(fā)者提供了 json- rpc 接口,本文就不展開(kāi)討論了。
接下來(lái)介紹如何使用 Go 語(yǔ)言,借助 go-ethereum 源碼庫(kù)來(lái)實(shí)現(xiàn)智能合約的調(diào)用。這是有固定 步驟的,我們先來(lái)說(shuō)一下總體步驟,以下面的合約為例。
步驟 01:編譯合約,獲取合約 ABI(Application Binary Interface,應(yīng)用二進(jìn)制接口)。 單擊【ABI】按鈕拷貝合約 ABI 信息,將其粘貼到文件 calldemo.abi 中(可使用 Go 語(yǔ)言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 文件,讀者可以打開(kāi)該文件欣賞一下,注意不要修改它。
步驟 04:創(chuàng)建 main.go,填入如下代碼。 注意代碼中 HexToAddress 函數(shù)內(nèi)要傳入該合約部署后的地址,此地址在步驟 01 中獲得。
步驟 04:設(shè)置 go mod,以便工程自動(dòng)識(shí)別。
前面有所提及,若要使用 Go 語(yǔ)言調(diào)用智能合約,需要下載 go-ethereum 工程,可以使用下面 的指令:
該指令會(huì)自動(dòng)將 go-ethereum 下載到“$GOPATH/src/github.com/ethereum/go-ethereum”,這樣還算 不錯(cuò)。不過(guò),Go 語(yǔ)言自 1.11 版本后,增加了 module 管理工程的模式。只要設(shè)置好了 go mod,下載 依賴工程的事情就不必關(guān)心了。
接下來(lái)設(shè)置 module 生效和 GOPROXY,命令如下:
在項(xiàng)目工程內(nèi),執(zhí)行初始化,calldemo 可以自定義名稱。
步驟 05:運(yùn)行代碼。執(zhí)行代碼,將看到下面的效果,以及最終輸出的 2020。
上述輸出信息中,可以看到 Go 語(yǔ)言會(huì)自動(dòng)下載依賴文件,這就是 go mod 的神奇之處。看到 2020,相信讀者也知道運(yùn)行結(jié)果是正確的了。
智能合約具有在執(zhí)行期間“發(fā)出”事件的能力。 事件在以太坊中也稱為“日志”。 事件的輸出存儲(chǔ)在日志部分下的事務(wù)處理中。 事件已經(jīng)在以太坊智能合約中被廣泛使用,以便在發(fā)生相對(duì)重要的動(dòng)作時(shí)記錄,特別是在代幣合約(即ERC-20)中,以指示代幣轉(zhuǎn)賬已經(jīng)發(fā)生。 這些部分將引導(dǎo)您完成從區(qū)塊鏈中讀取事件以及訂閱事件的過(guò)程,以便交易事務(wù)被礦工打包入塊的時(shí)候及時(shí)收到通知。
為了訂閱事件日志,我們需要做的第一件事就是撥打啟用websocket的以太坊客戶端。 幸運(yùn)的是,Infura支持websockets。
下一步是創(chuàng)建篩選查詢。 在這個(gè)例子中,我們將閱讀來(lái)自我們?cè)谥罢n程中創(chuàng)建的示例合約中的所有事件。
我們接收事件的方式是通過(guò)Go channel。 讓我們從go-ethereum core/types 包創(chuàng)建一個(gè)類型為 Log 的channel。
現(xiàn)在我們所要做的就是通過(guò)從客戶端調(diào)用 SubscribeFilterLogs 來(lái)訂閱,它接收查詢選項(xiàng)和輸出通道。 這將返回包含unsubscribe和error方法的訂閱結(jié)構(gòu)。
最后,我們要做的就是使用select語(yǔ)句設(shè)置一個(gè)連續(xù)循環(huán)來(lái)讀入新的日志事件或訂閱錯(cuò)誤。
我們會(huì)在下個(gè)章節(jié)介紹如何解析日志。
Commands
Store.sol
event_subscribe.go
智能合約可以可選地釋放“事件”,其作為交易收據(jù)的一部分存儲(chǔ)日志。讀取這些事件相當(dāng)簡(jiǎn)單。首先我們需要構(gòu)造一個(gè)過(guò)濾查詢。我們從go-ethereum包中導(dǎo)入 FilterQuery 結(jié)構(gòu)體并用過(guò)濾選項(xiàng)初始化它。我們告訴它我們想過(guò)濾的區(qū)塊范圍并指定從中讀取此日志的合約地址。在示例中,我們將從在 智能合約章節(jié) 創(chuàng)建的智能合約中讀取特定區(qū)塊所有日志。
下一步是調(diào)用ethclient的 FilterLogs ,它接收我們的查詢并將返回所有的匹配事件日志。
返回的所有日志將是ABI編碼,因此它們本身不會(huì)非常易讀。為了解碼日志,我們需要導(dǎo)入我們智能合約的ABI。為此,我們導(dǎo)入編譯好的智能合約Go包,它將包含名稱格式為 ContractABI 的外部屬性。之后,我們使用go-ethereum中的 accounts/abi 包的 abi.JSON 函數(shù)返回一個(gè)我們可以在Go應(yīng)用程序中使用的解析過(guò)的ABI接口。
現(xiàn)在我們可以通過(guò)日志進(jìn)行迭代并將它們解碼為我么可以使用的類型。若您回憶起我們的樣例合約釋放的日志在Solidity中是類型為 bytes32 ,那么Go中的等價(jià)物將是 [32]byte 。我們可以使用這些類型創(chuàng)建一個(gè)匿名結(jié)構(gòu)體,并將指針作為第一個(gè)參數(shù)傳遞給解析后的ABI接口的 Unpack 函數(shù),以解碼原始的日志數(shù)據(jù)。第二個(gè)參數(shù)是我們嘗試解碼的事件名稱,最后一個(gè)參數(shù)是編碼的日志數(shù)據(jù)。
此外,日志結(jié)構(gòu)體包含附加信息,例如,區(qū)塊摘要,區(qū)塊號(hào)和交易摘要。
若您的solidity事件包含 indexed 事件類型,那么它們將成為 主題 而不是日志的數(shù)據(jù)屬性的一部分。在solidity中您最多只能有4個(gè)主題,但只有3個(gè)可索引的事件類型。第一個(gè)主題總是事件的簽名。我們的示例合約不包含可索引的事件,但如果它確實(shí)包含,這是如何讀取事件主題。
正如您所見(jiàn),首個(gè)主題只是被哈希過(guò)的事件簽名。
這就是閱讀和解析日志的全部?jī)?nèi)容。要學(xué)習(xí)如何訂閱日志,閱讀上個(gè)章節(jié)。
命令
Store.sol
event_read.go
首先,創(chuàng)建ERC-20智能合約的事件日志的interface文件 erc20.sol :
然后在給定abi使用 abigen 創(chuàng)建Go包
現(xiàn)在在我們的Go應(yīng)用程序中,讓我們創(chuàng)建與ERC-20事件日志簽名類型相匹配的結(jié)構(gòu)類型:
初始化以太坊客戶端
按照ERC-20智能合約地址和所需的塊范圍創(chuàng)建一個(gè)“FilterQuery”。這個(gè)例子我們會(huì)用 ZRX 代幣:
用 FilterLogs 來(lái)過(guò)濾日志:
接下來(lái)我們將解析JSON abi,稍后我們將使用解壓縮原始日志數(shù)據(jù):
為了按某種日志類型進(jìn)行過(guò)濾,我們需要弄清楚每個(gè)事件日志函數(shù)簽名的keccak256哈希值。 事件日志函數(shù)簽名哈希始終是 topic [0] ,我們很快就會(huì)看到。 以下是使用go-ethereum crypto 包計(jì)算keccak256哈希的方法:
現(xiàn)在我們將遍歷所有日志并設(shè)置switch語(yǔ)句以按事件日志類型進(jìn)行過(guò)濾:
現(xiàn)在要解析 Transfer 事件日志,我們將使用 abi.Unpack 將原始日志數(shù)據(jù)解析為我們的日志類型結(jié)構(gòu)。 解包不會(huì)解析 indexed 事件類型,因?yàn)樗鼈兇鎯?chǔ)在 topics 下,所以對(duì)于那些我們必須單獨(dú)解析,如下例所示:
Approval 日志也是類似的方法:
最后,把所有的步驟放一起:
我們可以把解析的日志與etherscan的數(shù)據(jù)對(duì)比:
Commands
erc20.sol
event_read_erc20.go
solc version used for these examples
要讀取 0x Protocol 事件日志,我們必須首先將solidity智能合約編譯為一個(gè)Go包。
安裝solc版本 0.4.11
為例如 Exchange.sol 的事件日志創(chuàng)建0x Protocol交易所智能合約接口:
Create the 0x protocol exchange smart contract interface for event logs as Exchange.sol :
接著給定abi,使用 abigen 來(lái)創(chuàng)建Go exchange 包:
Then use abigen to create the Go exchange package given the abi:
現(xiàn)在在我們的Go應(yīng)用程序中,讓我們創(chuàng)建與0xProtocol事件日志簽名類型匹配的結(jié)構(gòu)體類型:
初始化以太坊客戶端:
創(chuàng)建一個(gè) FilterQuery ,并為其傳遞0x Protocol智能合約地址和所需的區(qū)塊范圍:
用 FilterLogs 查詢?nèi)罩荆?/p>
接下來(lái)我們將解析JSON abi,我們后續(xù)將使用解壓縮原始日志數(shù)據(jù):
為了按某種日志類型過(guò)濾,我們需要知曉每個(gè)事件日志函數(shù)簽名的keccak256摘要。正如我們很快所見(jiàn)到的那樣,事件日志函數(shù)簽名摘要總是 topic[0] :
現(xiàn)在我們迭代所有的日志并設(shè)置一個(gè)switch語(yǔ)句來(lái)按事件日志類型過(guò)濾:
現(xiàn)在要解析 LogFill ,我們將使用 abi.Unpack 將原始數(shù)據(jù)類型解析為我們自定義的日志類型結(jié)構(gòu)體。Unpack不會(huì)解析 indexed 事件類型,因?yàn)檫@些它們存儲(chǔ)在 topics 下,所以對(duì)于那些我們必須單獨(dú)解析,如下例所示:
對(duì)于 LogCancel 類似:
最后是 LogError :
將它們放在一起并運(yùn)行我們將看到以下輸出:
將解析后的日志輸出與etherscan上的內(nèi)容進(jìn)行比較:
命令
Exchange.sol
event_read_0xprotocol.go
這些示例使用的solc版本
Go語(yǔ)言由Google公司開(kāi)發(fā),并于2009年開(kāi)源,相比Java/Python/C等語(yǔ)言,Go尤其擅長(zhǎng)并發(fā)編程,性能堪比C語(yǔ)言,開(kāi)發(fā)效率肩比Python,被譽(yù)為“21世紀(jì)的C語(yǔ)言”。
Go語(yǔ)言在云計(jì)算、大數(shù)據(jù)、微服務(wù)、高并發(fā)領(lǐng)域應(yīng)用應(yīng)用非常廣泛。BAT大廠正在把Go作為新項(xiàng)目開(kāi)發(fā)的首選語(yǔ)言。
Go語(yǔ)言應(yīng)用范圍:
1、服務(wù)端開(kāi)發(fā):以前你使用C或者C++做的那些事情,用Go來(lái)做很合適,例如日志處理、文件系統(tǒng)、監(jiān)控系統(tǒng)等;
2、DevOps:運(yùn)維生態(tài)中的Docker、K8s、prometheus、grafana、open-falcon等都是使用Go語(yǔ)言開(kāi)發(fā);
3、網(wǎng)絡(luò)編程:大量?jī)?yōu)秀的Web框架如Echo、Gin、Iris、beego等,而且Go內(nèi)置的 net/http包十分的優(yōu)秀;
4、Paas云平臺(tái)領(lǐng)域:Kubernetes和Docker Swarm等;
5、分布式存儲(chǔ)領(lǐng)域:etcd、Groupcache、TiDB、Cockroachdb、Influxdb等;
6、區(qū)塊鏈領(lǐng)域:區(qū)塊鏈里面有兩個(gè)明星項(xiàng)目以太坊和fabric都使用Go語(yǔ)言;
7、容器虛擬化:大名鼎鼎的Docker就是使用Go語(yǔ)言實(shí)現(xiàn)的;
8、爬蟲(chóng)及大數(shù)據(jù):Go語(yǔ)言天生支持并發(fā),所以十分適合編寫分布式爬蟲(chóng)及大數(shù)據(jù)處理。