A. 區塊鏈技術中的共識演算法
關於區塊鏈技術的一些講解和知識點分析我們已經給大家分享過很多次了。今天,天通苑java課程就再來了解一下,區塊鏈技術中的共識演算法的一些基本定義與特點。
簡單過一下區塊鏈
我們一般意識形態中的鏈是鐵鏈,由鐵鑄成,一環扣一環。形象地,區塊鏈的手中遲也可以這么理解,只不過它不是由鐵鑄成,而是由擁有一定數據結構的塊連接而成,這是一個簡單的雛形
通俗講解共識
所謂共識,通俗來說,就是我們大家對某種事物的理解達成一致的意思。比如說日常的開會討論問題,又比如判斷一個動物是不是貓,我們肉眼看了後覺得像貓,其滿足貓的特徵,那麼我們認為它是貓。共識,是一種規則。
繼續我們的會議例子。參與會議的人,通過開會的方式來達到談論解決問題。
對比區塊鏈中,參與挖礦的礦工通過某種共識方式(演算法)來解決讓自己的賬本跟其他節點的賬本保持一致。讓賬本保持一致的深入一層意思就是,讓鏈中區塊信息保持一致。
為什麼需要共識,不需要可不可以?當然不可以,生活中沒了共識的規則,一切亂套。區塊鏈沒了共識的規則,各個節點各干各的,失去一致的意義。
這兩個例子的對應的關系如下:
會議的人=挖礦的礦工
開會=共識方式(演算法)
談論解決問題=讓自己的賬本跟其他節點的賬本保持一致
如果你對節點的概念意思不懂,請先理解為礦工,一個節點內部包含很多培斗角色,礦工是其中之一。
共識演算法
目前常見的在區塊鏈中,節點們讓自己的賬本跟其他節點的賬本保持一致的共識方式(演算法)有如下幾種:
PoW,代表者是比特幣(BTC)
弊端:
礦池的出現,一定程度上違背了去中心化的初衷,同時也使得51%攻擊成為可能,影響其安全性。
存在巨大的算力浪費,看看礦池消耗大量的電力資源,隨著難度增加,挖出的不夠付電費
PoS,代表者是以太坊(ETH),從PoW過度到PoS
弊端:
破壞者對網路的攻擊成本很低,擁有代幣就能競爭
另外擁有代幣數畢李量大的節點獲得記賬權的概率會更大,會使得網路共識受少數富裕賬戶支配,從而失去公正性。
B. POC是真正公鏈嗎
假的。POC共識演算法是區塊鏈技術的核心要素。由於區塊鏈的快速發展,共識已經引起了社會各界的關注。它將人類帶入數學領域的信任時代。由於共識的存在,人類可以在沒有信用抵押的情況下進行大規模的合作。它不僅重構了生產關系,塑造了價值網路,改善了隱私保護,還以前所未有的規模降低了信任成本,使得每個人的發行權得以釋放。同時,數學的合理分布架構充分發揮了每個個體的理性力量和公平力量,使人性化的發行成為可能。 在資產私有化方面,共識演算法可以同時滿足數字資產全球流通、私有化權利確認和隱私保護三個需求,解決數據侵權、數據安全和數據壟斷三個問題。
拓展資料
1.到目前為止,研究者們在共識相關領域做了大量的研究工作。比特幣和以太坊的崛起極大地促進了其底層共識演算法的工作證明(POW)和股權證明(POS);然而,時代在進步。當大量的空幣項目使得區塊鏈在普通用戶心中的地位一再下降,當數字通流通冷時,礦工網和普通用戶對區塊鏈的落地提出了更高的要求,而逐漸發展起來的POC共識演算法正以其獨特的優勢迅速為區塊鏈的登陸打開大門。讓我們開始POC(容量證明)共識演算法。在POC中,要生成一個新的塊,需要提供一個有效的空間證明來證明它有一定的硬碟空間,這個證明應該由其他人驗證。流行的解釋是,如果區塊鏈網路是一個考官,平均來說,每個特定的時間給出一個問題,而礦工是應該參加考試的學生。每個人手邊都有一個答案庫。案例庫的大小取決於您參與挖掘的硬碟的大小。
2.每隔一段時間,考官都會提出一個問題。所有礦工在自己的答案庫中尋找正確答案,並提交他們認為接近考官的答案。最接近正確答案的提交者將獲得塊獎勵。學生提交的答案的命中率取決於你的答案庫的大小,你的答案庫越大,你得到最高分數的機會就越多。如何使一個功能系統中的所有參與者產生商業博弈,各方都有利於自己的利益需求,同時又使整個系統積極發展,是所有系統都要考慮的問題。第一個解決方案是基於數學的反作弊共識。只有不讓任何人成為權力的主體,才能避免利用權力謀取利益。因此,設計共識是設計防止作弊的數學程序和經濟系統。在區塊鏈共識領域有一個誤解。結果,每個人都認為去中心化。事實上,去中心化是一個過程,而不是目標。區塊鏈解決了人類的問題,防止中央集權做壞事。
C. 011:Ethash演算法|《ETH原理與智能合約開發》筆記
待字閨中開發了一門區塊鏈方面的課程:《深入淺出ETH原理與智能合約開發》,馬良老師講授。此文集記錄我的學習筆記。
課程共8節課。其中,前四課講ETH原理,後四課講智能合約。
第四課分為三部分:
這篇文章是第四課第一部分的學習筆記:Ethash演算法。
這節課介紹的是以太坊非常核心的挖礦演算法。
在介紹Ethash演算法之前,先講一些背景知識。其實區塊鏈技術主要是解決一個共識的問題,而共識是一個層次很豐富的概念,這里把范疇縮小,只討論區塊鏈中的共識。
什麼是共識?
在區塊鏈中,共識是指哪個節點有記賬權。網路中有多個節點,理論上都有記賬權,首先面臨的問題就是,到底誰來記帳。另一個問題,交易一定是有順序的,即誰在前,前在後。這樣可以解決雙花問題。區塊鏈中的共識機制就是解決這兩個問題,誰記帳和交易的順序。
什麼是工作量證明演算法
為了決定眾多節點中誰來記帳,可以有多種方案。其中,工作量證明就讓節點去算一個哈希值,滿足難度目標值的勝出。這個過程只能通過枚舉計算,誰算的快,誰獲勝的概率大。收益跟節點的工作量有關,這就是工作量證明演算法。
為什麼要引入工作量證明演算法?
Hash Cash 由Adam Back 在1997年發表,中本聰首次在比特幣中應用來解決共識問題。
它最初用來解決垃圾郵件問題。
其主要設計思想是通過暴力搜索,找到一種Block頭部組合(通過調整nonce)使得嵌套的SHA256單向散列值輸出小於一個特定的值(Target)。
這個演算法是計算密集型演算法,一開始從CPU挖礦,轉而為GPU,轉而為FPGA,轉而為ASIC,從而使得算力變得非常集中。
算力集中就會帶來一個問題,若有一個礦池的算力達到51%,則它就會有作惡的風險。這是比特幣等使用工作量證明演算法的系統的弊端。而以太坊則吸取了這個教訓,進行了一些改進,誕生了Ethash演算法。
Ethash演算法吸取了比特幣的教訓,專門設計了非常不利用計算的模型,它採用了I/O密集的模型,I/O慢,計算再快也沒用。這樣,對專用集成電路則不是那麼有效。
該演算法對GPU友好。一是考慮如果只支持CPU,擔心易被木馬攻擊;二是現在的顯存都很大。
輕型客戶端的演算法不適於挖礦,易於驗證;快速啟動
演算法中,主要依賴於Keccake256 。
數據源除了傳統的Block頭部,還引入了隨機數陣列DAG(有向非循環圖)(Vitalik提出)
種子值很小。根據種子值生成緩存值,緩存層的初始值為16M,每個世代增加128K。
在緩存層之下是礦工使用的數據值,數據層的初始值是1G,每個世代增加8M。整個數據層的大小是128Bytes的素數倍。
框架主要分為兩個部分,一是DAG的生成,二是用Hashimoto來計算最終的結果。
DAG分為三個層次,種子層,緩存層,數據層。三個層次是逐漸增大的。
種子層很小,依賴上個世代的種子層。
緩存層的第一個數據是根據種子層生成的,後面的根據前面的一個來生成,它是一個串列化的過程。其初始大小是16M,每個世代增加128K。每個元素64位元組。
數據層就是要用到的數據,其初始大小1G,現在約2個G,每個元素128位元組。數據層的元素依賴緩存層的256個元素。
整個流程是內存密集型。
首先是頭部信息和隨機數結合在一起,做一個Keccak運算,獲得初始的單向散列值Mix[0],128位元組。然後,通過另外一個函數,映射到DAG上,獲取一個值,再與Mix[0]混合得到Mix[1],如此循環64次,得到Mix[64],128位元組。
接下來經過後處理過程,得到 mix final 值,32位元組。(這個值在前面兩個小節《 009:GHOST協議 》、《 010:搭建測試網路 》都出現過)
再經過計算,得出結果。把它和目標值相比較,小於則挖礦成功。
難度值大,目標值小,就越難(前面需要的 0 越多)。
這個過程也是挖礦難,驗證容易。
為防止礦機,mix function函數也有更新過。
難度公式見課件截圖。
根據上一個區塊的難度,來推算下一個。
從公式看出,難度由三部分組成,首先是上一區塊的難度,然後是線性部分,最後是非線性部分。
非線性部分也叫難度炸彈,在過了一個特定的時間節點後,難度是指數上升。如此設計,其背後的目的是,在以太坊的項目周期中,在大都會版本後的下一個版本中,要轉換共識,由POW變為POW、POS混合型的協議。基金會的意思可能是使得挖礦變得沒意思。
難度曲線圖顯示,2017年10月,難度有一個大的下降,獎勵也由5個變為3個。
本節主要介紹了Ethash演算法,不足之處,請批評指正。
D. 區塊鏈共識演算法——(二)PoS共識(Proof of Stake)
2011 年 7 月, 一 位 名 為 Quantum Mechanic 的 數 字 貨 幣 愛 好 者 在 比 特 幣 論 壇 首次提出了權益證明 PoS 共識演算法. 隨後, Sunny King 在 2012 年 8 月發布的點點幣 (Peercoin, PPC) 中首次實現. PoS 由 系統中具有最高權益而非最高算力的節點獲得記賬 權, 其中權益體現為節點對特定數量貨幣的所有權, 稱為幣齡或幣天數 (Coin days)
PoS是考慮到PoW的最大缺陷:浪費資源而提出的,簡單來說就是 誰的權益大,誰說了算 。
PoS共識機制(Proof of Stake 權益證明)通過權益記賬的方式,解決效率低下、資源浪費、節點一致性等問題。
各個節點需要滿足一定的條件(如抵押一定的代幣)才能成為驗證節點(權益提高),系統通過演算法在其中選擇一部分作為出塊節點(礦工),每隔一段時間重新選擇,演算法會保證完全隨機,不可被操控。只有出塊節點才能進行數據處理,爭奪記賬權。
權益主要由權益因子決定,可以是持幣數量,也可以是幣齡及兩者的結合。
以太坊在之後很有可能會改用PoS進行共識,其更加符合以太坊高效率的特點。
E. 以太坊共識協議Casper原理是怎樣的
Casper(投注共識)是一種以太坊下一代的共識機制,屬於PoS。Casper的共識是按塊達成的而不是像PoS那樣按鏈達成的。數字貨幣交易所幣匯
F. 一文了解以太坊挖礦演算法及算力規模2020-09-09
以太坊網路中,想要獲得以太坊,也要通過挖礦來實現。當前以太坊也是採用POW共識機制,但是與比特幣的POW挖礦有點不一樣,以太坊挖礦難度是可以調節的。以太坊系統有一個特殊的公式用來計算之後的每個塊的難度。如果某個區塊比前一個區塊驗證的更快,以太坊協議就會增加區塊的難度。通過調整區塊難度,就可以調整驗證區塊所需的時間。
以太坊採用的是Ethash 加密演算法,在挖礦的過程中,需要讀取內存並存儲 DAG 文件。由於每一次讀取內寸的帶寬都是有限的,而現有的計算機技術又很難在這個問題上有質的突破,所以無論如何提高計算機的運算效率,內存讀取效率仍然不會有很大的改觀。因此,從某種意義上來說,以太坊的Ethash加密演算法具有「抗ASIC性」。
加密演算法的不同,導致了比特幣和以太坊的挖礦設備、算力規模差異很大。
目前,比特幣挖礦設備主要是專業化程度非常高的ASIC 礦機,單台礦機的算力最高達到了 112T/s(神馬M30S++礦機),全網算力的規模達到139.92EH/s。
以太坊的挖礦設備主要是顯卡礦機和定製GPU礦機,專業化的ASIC礦機非常少,一方面是因為以太坊挖礦演算法的「抗 ASIC 性」提高了研發ASIC礦機的門檻,另一方面是因為以太坊升級到2.0之後共識機制會轉型為PoS,礦機無法繼續挖。
和ASIC礦機相比,顯卡礦機在算力上相差了2個量級。目前,主流的顯卡礦機(8卡)算力約為420MH/s,比較領先的定製GPU礦機算力約在500M~750M,以太坊全網算力約為235.39TH/s。
從過去兩年的時間維度上看,以太坊的全網算力增長相對緩慢。
以太坊協議規定,難度的動態調整方式是使全網創建新區塊的時間間隔為15秒,網路用15秒時間創建區塊鏈,這樣一來,因為時間太快,系統的同步性就大大提升,惡意參與者很難在如此短的時間發動51%(也就是半數以上)的算力去修改歷史數據。
G. 共識演算法(分布式下的一致性演算法)
共識演算法(分布式下的一致性演算法)
業務場景:
達到的效果:可以保證在過半節點正常的情況下,所有的寫入操作不會丟失。
Zab協議並不保證強一致性,也不是弱一致性,而是在一定限度內的強一致性。
缺點:
缺點:
區塊鏈1.0時代:比特幣,作用就是去中心化的貨幣,無國界的貨幣,並且可以匿名性的洗錢
區塊鏈2.0時代:代表以太坊,引入了智能合約的概念,發揮其 去中心化和不可篡改的特性,可以實現類似於 追溯、拍賣、投票等業務場景。
區塊鏈技術的實用價值:
無國界虛擬貨幣:比如比特幣
模擬一個拍賣(盲拍)的業務場景(發布一個智能合約):
https://solidity.readthedocs.io/en/latest/solidity-by-example.html#simple-open-auction
普通拍賣可能存在的問題:
商家A對一件商品公開自己要拍賣,智能合約在規定的時間會開始接收競拍(參與競拍的人需要支付保證金(以太幣)),在競拍結束之後,價格最高的人會完成支付,其它的買家的保證金會全額退回。
然後成功競拍者可以線下去找賣家,證明自己的身份,然後獲得競拍品
優點:
工作量證明( PoW )通過計算一個數值( nonce ),使得拼揍上交易數據後內容的 Hash 值滿足規定的上限。在節點成功找到滿足的Hash值之後,會馬上對全網進行廣播打包區塊,網路的節點收到廣播打包區塊,會立刻對其進行驗證
舉個例子,給定的一個基本的字元串」Hello, world!」,我們給出的工作量要求是,可以在這個字元串後面添加一個叫做nonce的整數值,對變更後(添加nonce)的字元串進行SHA256哈希運算,
如果得到的哈希結果(以16進制的形式表示)是以」0000」開頭的,則驗證通過。為了達到這個工作量證明的目標。我們需要不停的遞增nonce值,對得到的新字元串進行SHA256哈希運算。
按照這個規則,我們需要經過4251次計算才能找到恰好前4位為0的哈希散列。計算完之後,然後廣播到臨近的節點,臨近的節點會先驗算交易是否合法(金額是否異常),再驗證hash值是否滿足要求,都滿足的話,就會把這個數據塊添加到自己的賬本中。
優點:
缺點:
計算難度值會因為 股東持有的 幣齡而降低,為挖礦無形之中提升了壁壘,股東更容易算出結果值(難度更低),從而避免過度的算力競爭,節省電力,提升系統的穩定性。
因為從人性的角度,股東更不願意讓不安全的現象發生(比如攻擊主鏈),因為會造成信用降低,從而自己的礦幣貶值。讓股東擁有更多的記賬權,讓主鏈更安全。
擴展可以參考我之前寫過的zab專欄博客
https://www.jianshu.com/nb/32551354
H. 以太坊是什麼
隨著區塊鏈技術的創新,一個新的平台誕生了,它就是以太坊。以太坊不像比特幣那樣只是一種加密貨幣,它還存在其它特徵,使其成為了一個巨大的分布式計算機。
那麼,到底什麼是以太坊?
具體來說,以太坊(Ethereum)是一個可編程、可視化、更易用的區塊鏈,它允許任何人編寫智能合約和發行代幣。就像比特幣一樣,以太坊是去中心化的,由全網共同記賬,賬本公開透明且不可竄改。
與比特幣不同的是,以太坊是可編程的區塊鏈,它提供了一套圖靈完備的腳本語言,因此,開發人員可以直接用C語言等高級語言編程,轉換成匯編語言,大大降低了區塊鏈應用的開發難度。
為了更易理解,打個比方,以太坊就像是區塊鏈里的Android,它是一個開發平台,讓我們可以像基於Android Framework一樣基於區塊鏈技術寫應用。它上面提供各種模塊讓用戶來搭建應用,如果將搭建應用比作造房子,那麼以太坊就提供了牆面、屋頂、地板等模塊,用戶只需像搭積木一樣把房子搭起來,因此在以太坊上建立應用的成本和速度都大大改善。
事實上,在沒有以太坊之前,寫區塊鏈應用是這樣的:拷貝一份比特幣代碼,然後去改底層代碼如加密演算法,共識機制,網路協議等等(很多山寨幣就是這樣,改改就出來一個新幣)。
至於以太坊如何運作?
與其它區塊鏈一樣,以太坊需要幾千人在自己的計算機上運行一個軟體,為該網路提供動力。網路中的每個節點(計算機)運行一個叫做以太坊虛擬機(EVM)的軟體。如果將以太坊虛擬機想像成一個操作系統,它能理解並執行通過以太坊特定編程語言編寫的軟體,由以太坊虛擬機執行的軟體/應用程序被稱為「智能合約」。
不過,在這台計算機上操作並不是免費的,需要支付該網路自帶的加密貨幣,叫做以太幣(Ether)。以太幣與比特幣大致相同,除了一點,即以太幣可以為在以太坊上執行智能合約而付費。
回到以太坊的發展史,以太坊的概念首次在2013至2014年間由程序員Vitalik Buterin受比特幣啟發後提出,大意為「下一代加密貨幣與去中心化應用平台」,在2014年通過ICO眾籌開始得以發展。
截至2018年2月,以太幣是市值第二高的加密貨幣,僅次於比特幣。
對於許多程序工程師和投資人而言,2015年7月30號這一天是一個大日子,經過18個月的醞釀期後,以太坊區塊鏈平台終於正式誕生了,當天在位於布魯克林的辦公室上午11:45左右,當以太坊區塊鏈產生第一個創世區塊,隨即有很多狂熱的礦工在後頭想要贏得第一個區塊,也就是以太坊專屬電子貨幣,以太幣的所有權。當時整個辦公室掌聲雷動,那一天天氣很糟糕,紐約一帶下了大雷雨,每個人的智能手機不時傳來嘈雜的洪水警告訊號。
根據該公司網站資料的說明,以太坊是一個去中心化的應用平台,以智能合約為例,設計師可以完全排除死機被監控,被詐騙或者是被第三方橫加干預的可能,跟比特幣一樣,以太坊利用以太幣吸引參加者,建立驗證交易平台的網路架構,維持網路架構的運作,並且以共識決定哪些是真正發生過存在的事件,但是以太坊和比特幣也有所不同,以太坊提供一些功能強大的工具,讓投入開發的人創造出去,具有去中心化的軟體服務,使用范圍可以從線上 游戲 橫跨到股票交易。
以太坊的構想源自於2013年,當時才19歲的俄裔加拿大人為例,維塔利克布特林,他當時跟比特幣的核心開發者爭論,區塊鏈網路架構需要有更穩固的手稿語言才能發展其他的應用軟體,不過他的想法沒有被採納,促成了他打定主意要開發一套符合自己理念的區塊鏈網路架構共識,這家公司可以說是他跨出的第一步,在以太坊區塊鏈上推出了應用軟體,如果我們把時間往回倒轉幾年,就會發現一個很有趣的對照。
有位大師托瓦茲推出Linux作業系統的舉動,正如布特林推出以太坊一樣如出一轍。共識系統公司的聯合創始人約瑟夫魯賓談到區塊鏈以太坊的興起時表示,我愈發覺得走上街頭去貼海報訴求是很浪費時間的一件事,倒不如一起合作,在這個失衡的 社會 的經濟體制帶來要比較實際得改變。
跟許多創業者一樣,魯賓提出的願望也很有企圖心,他不只想要創立一家了不起的公司,也想借機克服這個世界上難解的問題。這個公司的應用程序會對十多個其他領域的產業帶來震撼力十足的效果,他們的計劃包括分布式的三重記賬會計體系,針對原本廣受好評,但是後來卻因為集中管控兒而遭受爭議的reddit論壇推出分布式的新版本,自動執行的文件格式進行管理,系統現在叫智能合約,涵蓋商務 體育 和 娛樂 領域的預測市場、公開競標的能源市場、足以和蘋果電腦分庭抗禮的一整套可以供大規模協作集體創造,實現無管理階層公司之共同管理機制的商務工具。
以太坊Ethereum由V神(Vitalik Buterin)在2014年創辦,它是一個區塊鏈底層系統,類似於互聯網的操作系統,基於它開發的DAPP(去中心化應用)類似於基於互聯網操作系統開發的軟體APP。
它的出現主要是彌補比特幣的不足,比特幣只能實現點對點的電子現金交易系統,但是區塊鏈技術在其他場景的應用卻無法實現。如果每用於一個場景,就搭建一個底層基礎系統,再進行開發,太耗時間和精力,成本也很高。為此,以太坊就建了一個底層系統供開發者使用,開發者只需要在其基礎上開發自己的DAPP應用就可以了。去年5月數據顯示,全球就已有200多個以太坊應用。
此外,以太坊也是區塊鏈比較優秀的公鏈之一。不過,它的交易速度太慢令眾多開發者詬病,以太坊開發者正在不斷嘗試研發分片技術對此現象進行改變。
以太坊的本質是一個可編程可視化而且操作簡單的區塊鏈,允許任何人編寫智能合約和發行代幣(這也是為什麼市面上各類空氣幣、傳銷幣如此之多的一個原因之一)。和比特幣一樣,以太坊也是去中心化的,全網共同記錄以太坊的所有情況,而且公開透明不可篡改。
那你想問,以太坊和比特幣的不同之處在哪?通俗地講,你可以把以太坊理解成為能夠編程的區塊鏈,它提供了一套圖靈完備的腳本語言,後續的開發人員可以直接在這個基礎上進行c語言等語言編程,之後轉變成匯編語言,由此降低了區塊鏈的應用的開發難度。就好像安卓系統上,准備好了api和介面,用戶直接開發app就可以這樣的邏輯。從以太坊誕生之初到現在,以太坊上已經誕生了幾百個應用,俄羅斯政府甚至也與以太坊基金會合作。
希望我的回答能夠幫助你!
在基礎層面上,以太坊是基於區塊鏈技術的軟體平台。該平台允許構建和部署分散式應用程序。以太坊里的「以太」是什麼?對Ethereum感興趣的人們經常會問「以太是什麼?」
了解以太是非常重要的,因為它是以太坊功能的基礎。就像所有機器使用某種燃料一樣,區塊鏈也是如此。以太坊使用乙太網,這是一種獨特的代碼,可用作支付運行應用程序或程序的方式。就像老虎機需要硬幣(或者現在的預付卡)來運行硬幣一樣,客戶必須使用乙醚作為付款才能在以太坊運行他們所要求的操作。
大家其他人的答案真的都是太麻煩了
講得太復雜了
以太坊
簡單來說就是這么一個結論:
以太坊等於 BTC+智能合約+合同自由+通縮資產+使用價值
這個結論其實不難理解的
官方定義更加詭詐:
開源的有智能合約功能的公共區塊鏈平台。通過其專用加密貨幣以太幣(Ether,又稱「以太幣」)提供去中心化的虛擬機
以太坊簡單來說就是這么一個結論:
以太坊等於 BTC+智能合約+合同自由+通縮資產+使用價值
我給大家簡單地來說說吧
首先先來看下面這個視頻:也就是以太坊創始人V神的視頻 特別好的解釋
以太坊簡單來說就是這么一個結論:
以太坊等於 BTC+智能合約+合同自由+通縮資產+使用價值
官方定義更加詭詐:
以太坊是一個可編程,可視化的區塊鏈平台。其操作功能非常多,計算匯總各類數據等等。
以太坊是區塊鏈技術的一個質的飛躍!就好比http是互聯網底層支撐技術而以太坊就是可以基於以太坊智能合約做各種生態dapp
以太坊是什麼?
以太坊是互聯網新時代的基礎:
內建貨幣與支付。
用戶擁有個人數據主權,且不會被各類應用監聽或竊取數據。
人人都有權使用開放金融系統。
基於中立且開源的基礎架構,不受任何組織或個人控制。
以太坊的創建以太坊主網於 2015 年上線,是世界領先的可編程區塊鏈。
和其它區塊鏈一樣,以太坊也擁有原生加密貨幣,叫作 Ether (ETH)。 ETH 是一種數字貨幣, 和比特幣有許多相同的功能。 它是一種純數字貨幣,可以即時發送給世界上任何地方的任何人。 ETH 的供應不受任何政府或組織控制,它是去中心化且具稀缺性的。 全世界的人們都在使用 ETH 進行支付,或將其作為價值存儲和抵押品。
但與其它區塊鏈不同的是,以太坊可以做更多的工作。 以太坊是可編程的,開發者可以用它來構建不同於以往的應用程序。
以太坊的作用這些去中心化的應用程序(或稱「dapps」)基於加密貨幣與區塊鏈技術, 因而值得信任,也就是說 dapps 一旦被「上傳」到以太坊,它們將始終按照編好的程序運行。 這些應用程序可以控制數字資產,以便創造新的金融應用; 同時還是去中心化的,這意味著沒有任何單一實體或個人可以控制它們。
目前,全世界有成千上萬名開發者正在以太坊上構建應用程序、發明新的應用程序,其中有許多現在已經可以使用:
1.加密貨幣錢包:讓你可以使用 ETH 或其他數字資產進行低成本的即時支付
2.金融應用程序:讓你可以借貸、投資數字資產
3.去中心化市場:讓你可以交易數字資產,甚至就現實世界事件的「預測」進行交易
4. 游戲 :你可以擁有 游戲 內的資產,甚至可以由此獲得現實收益以及更多。
以太坊社區以太坊社區是世界上最大最活躍的區塊鏈社區。它包括核心協議開發者、加密經濟研究員、密碼朋克、挖礦組織、ETH 持有者、應用開發者、普通用戶、無政府主義者、財富 500 強公司。
沒有公司或中心化的組織能夠控制以太坊。 一直以來,以太坊由多元化的全球性社區貢獻者來協同進行維護和改善,社區成員耕耘於以太坊的方方面面,從核心協議到應用程序。
以太坊擁堵的元兇找到了,竟然是它!
I. 以太坊是什麼丨以太坊開發入門指南
以太坊是什麼丨以太坊開發入門指南
很多同學已經躍躍欲試投入到區塊鏈開發隊伍當中來,可是又感覺無從下手,本文將基於以太坊平台,以通俗的方式介紹以太坊開發中涉及的各晦澀的概念,輕松帶大家入門。
以太坊是什麼
以太坊(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來搭建一個測試網路。
註:本文中為了方便大家理解,對一些概念做了類比,有些嚴格來不是准確,不過我也認為對於初學者,也沒有必要把每一個概念掌握的很細致和准確,學習是一個逐步深入的過程,很多時候我們會發現,過一段後,我們會對同一個東西有不一樣的理解。
J. 以太坊通俗解釋
以太坊(Ethereum)是一個建立在區塊鏈技術之上的、圖靈完備的去中心化應用平台。它允許任何人在平台中通過智能合約技術開發、部署和使用去中心化應用。有沒有感到和 iOS、Android 平台有點類似?在區塊鏈1.0時代,我們如果需要編寫區塊鏈應用需要先從 Github 上 Download 一份比特幣源碼,然後修改底層代碼如網路協議、共識機制、加密演算法等等,再發布到網路中。2013、2014年的很多山寨幣就是這樣產生的,改一改比特幣的代碼,甚至是調整其中的某些參數就造出了一個新的應用、新的幣種。而以太坊平台,是對底層區塊鏈技術進行了封裝,讓區塊鏈應用開發者可以直接基於以太坊平台進行開發,開發者只需專注於應用本身,而不用關注底層技術的具體實現,從而大大降