ethgas機制
以太坊區塊鏈目前暴露出三大問題,長時間以來其創始人Vitalik Buterin一直無力解讀。第一是以太坊區塊鏈整體很低的性能和TPS;第二是資源不隔離,CryptoKitties虛擬貓咪的事件,一度占據了整個以太坊 20% 的流量,直接造成以太坊網路用戶無法展開及時的交易,就是資源不隔離最大的痛點;第三個問題在於以太坊治理結構的體現,區塊鏈作為去中心化的分布式賬本,以太坊過去以來,創始人團隊主導了其網路發展,過於中心化的治理模式,讓目前的以太坊出現了ETH、ETC、ETF等分叉,以太坊社區目前進入四分五裂的治理狀態。而以太坊網路目前出現的各種弊病,在「aelf」創始人與CEO馬昊伯看來,這是無法接受的。於是,「aelf」定位,就是為對標以太坊的下一代去中心化底層計算平台,重點解決目前以太坊存在的性能不足、資源不隔離、治理結構三方面的問題而誕生的。
㈡ 墨客moac兩級挖礦機制是怎麼回事啊
墨客moac設計了兩級挖礦機制,其實涉及到了更深層次的考量。eth和比特幣的分配機制其實很單一,靠POW挖礦。但是POW挖礦的成本很高,普通的參與者除了從二級市場靠交易獲得eth或者btc,沒有其他的分配機制。無論是btc的手續費,還是eth的gas,是系統中唯一的一次分配途徑。墨客moac提出了兩級挖礦特別是上層挖礦提供了一個二次分配的功能。就是子鏈的部署者需要持續的付出MOAC,分配給參與的scs節點,以維持子鏈的正常運行。這個和eth的部署一次,無限使用是不一樣的。eth靠使用者支付gas給礦工維持合約的功能,墨客moac是讓合約的創建者或者社區支付子鏈合約的維持成本。而SCS節點參與挖礦的成本很低,只需要一定的MOAC保證金,對系統的要求很低。這樣的挖礦機制使得廣大的SCS節點都可以參與並獲得收益,從而使得MOAC的二次分配更加廣泛。這樣,可以極大的調動社區的積極性,形成一個開放的系統。子鏈的預設配置是用moac支付。子鏈的創建者可以設定每個block的時間間隔,以及每個block的reward。這些reward是由創建者支付。墨客moac提供一個動態的管理機制,使得即使MOAC本身的價值波動,但是仍然可以讓scs節點有收益,子鏈創建者也不至於負擔過重。
㈢ 如何看待以太坊ETH2.0
對於1559引入gas費燃燒模式,固然會迎合某些人追逐所謂通縮的口味,但是其背後的動機,卻不得不說,是Vitalik和以太坊基金會進一步推進PoS以至ETH 2.0的戰略思維。
現在以太坊引入燃燒機制,對沖了區塊獎勵的發行,因此我們會覺得這個機制讓以太坊變得更硬了。但是,以太坊燃燒銷毀的是存量S。存量S的持續消耗會減少硬度(類似於電子工業消耗黃金儲量),讓增量的沖擊變大,不利於幣值的穩定。

介紹
眾所周知,以太坊是沒有固定可預期的貨幣政策的,這是一種最糟糕的貨幣政策(從博弈論的角度講)。在1559實施後,增量F假設為固定的區塊獎勵,除非Vitalik和基金會決定變更它。
那麼,恆定增量的情況下持續消耗存量,將使得以太坊的抗沖擊能力下降,幣值更不穩定,波動性更大,從而更加不適合於作為價值存儲。
㈣ etr是什麼幣
以太坊區塊鏈上的代幣稱為以太幣(Ether),代碼為ETH,可在許多加密貨幣的外匯市場上交易,它也是以太坊上用來支付交易手續費和運算服務費的媒介 。
以太坊(英文Ethereum)是一個開源的有智能合約功能的公共區塊鏈平台,通過其專用加密貨幣以太幣(Ether)提供去中心化的虛擬機(「以太虛擬機」 Ethereum Virtual Machine)來處理點對點合約。
【拓展資料】
以太幣跟比特幣有什麼區別:
一、ETH與比特幣方向不同
首先,ETH與比特幣,這兩者背後區塊鏈系統的方向完全不同。比特幣的定位就是單純的數字貨幣,可以被認為是一種點對點的電子現金。它是為了取代法幣、解決金融危機而誕生,主要應用於付款和價值轉移。所以比特幣背後的整個區塊鏈網路方向都是以貨幣為主,解決交易、支付問題。而ETH則不同,它雖然也是數字貨幣,具備一定的交易屬性,但是ETH背後的以太坊區塊鏈網路定位是世界級的通用計算平台,它只是借用比特幣中的區塊鏈技術,以此為基礎,朝著偏向於互聯網的操作系統級應用方面發展。
二、ETH與比特幣作用不同
由於以太坊與比特幣的方向定位不同,導致兩者的數字貨幣作用也有所不同。比特幣的方向是貨幣,想要成為常規貨幣的替代品。所以,比特幣系統中,其數字貨幣BTC是極為重要的一環,可以說是整個系統的最終體現,它的作用就是作為支付交易的媒介和價值儲存的載體。而以太坊的目標是操作系統級別的計算平台,就比較偏向於互聯網服務方面,它的價值體現在於有多少用戶使用以太坊這個平台,以及你這個平台給我提供多優質的服務。所以,這就決定了ETH在以太坊平台中,只是一個重要環節,但卻不是全部平台的價值體現,它只是以太坊上提高服務質量、處理交易的一種貨幣工具,讓平台上發生的點對點交易和應用程序更加便捷化。所以,盡管比特幣和以太幣都是數字貨幣,但比特幣是想要成為法幣的替代品,作為一種去中心化的電子現金系統被大家使用,整個系統更像是使用區塊鏈技術支持的一個特定應用程序。
三、ETH與比特幣機制原理不同
比特幣與以太坊的共識機制不同。在比特幣區塊鏈網路中,起到數據維護作用的共識機制是PoW機制,即工作量證明機制。它的工作原理是,大家一起參與,誰處理得最快最好,誰就能獲得記錄數據的權力,進而獲得比特幣獎勵。因為比特幣的應用方向是貨幣,使用場景是沒有中心化機構參與的點對點支付與交易,所以,比特幣就強烈地需要去中心化與安全這兩個屬性,而PoW機制雖然處理交易的速度過慢,而且需要花費大量的資源,但是安全性和去中心化程度極高,故此與比特幣契合。
以太坊所採用的是PoS共識機制,即權益證明機制,它的工作原理是,大家一起參與,誰持有的以太幣多,誰就越容易獲得記錄數據的權力,進而獲得ETH獎勵。以太坊的應用方向是操作系統,它是想讓大家在它的系統上部署智能合約、開發去中心化應用。以太坊雖然也需要去中心化的屬性,但是比起比特幣,它更需要高效率與低成本,不然你平台數據處理的效率過慢,手續費還高,誰願意在你的平台上開發?所以,以太坊就採用了PoS機制,PoS的去中心化性雖然沒PoW機制強,但是效率更快,處理數據也不需要花費非常大的資源。
四、ETH與比特幣通證生態不同
ETH和比特幣通證生態不同。比特幣因為要做貨幣,其價值生態的支撐點在於共識價值,即有多少人認可它,並使用它進行交易。因此比特幣的通證設計實際是一個通貨收縮的經濟模型,限定了比特幣只有2100萬枚,這樣因為稀缺屬性,價格會越來越高,更容易取得共識價值。而以太幣不同,支撐它價值生態的點在於產品,即整個平台提供了什麼樣的服務,解決了什麼樣的痛點等服務價值,與安卓系統、微信等產品類似,以太幣是以太坊平台的一個工具,可以用來購買gas做手續費、募資等其他使用場景。因此以太坊的通證設計中,以太幣並沒有數量限制,發行量上限為每年1800萬,挖礦難度也會隨時間而上升,相對通貨膨脹率每年都會下降。總的來說,ETH和比特幣雖然都是數字貨幣,但各自背後代表的整個區塊鏈系統,在作用、原理、生態價值等都有不同,以太坊的本質是一個操作系統級別的計算中心,以太幣是打破了原有數字貨幣的定位,在比特幣的基礎上開創了新的方向,它除了自身的貨幣價值外,還包含了整個產品的價值,這是前所未有的,只有理解了這一點,才能理解為什麼以太坊是區塊鏈2.0的代表。
㈤ eth挖礦是什麼原理
凡是涉及到幣,就一定離不開挖礦。以太坊網路中,想要獲得以太坊,也要通過挖礦來實現。說到挖礦,就一定離不開共識機制。
不知道大家還記得比特幣的共識機制是什麼嗎?比特幣的共識機制是 PoW (這是英文 Proof of Work 的縮寫,意思是「工作量證明機制」)。簡單來說,就是多勞多得,你付出的計算工作越高,那麼你就越有可能第一個找到正確的哈希值,就越有可能得到比特幣獎勵。
但是,比特幣的PoW存在著一定的缺陷,就是它處理交易的速度太慢,礦工們需要不斷地通過計算來碰撞哈希值,這是勞民傷財且效率低下的。對區塊鏈知識有涉獵的朋友們應該看到這樣一種說法:
以太坊為了彌補比特幣的不足,提出了新的共識機制,名叫 PoS(這是英文的縮寫,意思是「權益證明」,也有翻譯成「股權證明」的)。
PoS 簡單來講,其實就跟它的字面意思一樣:權益嘛,股權嘛,你持有的幣越多相當於你的股權越多,你的權益越高。
以太坊的PoS就是說:你持幣越多,你持有幣的時間越久,你的計算難度就會降低,挖礦會容易一些。
在以太坊最初的設定中,以太坊希望能夠通過階段性的升級,在前期依舊採用PoW來構建一個相對穩定的系統,之後逐漸採用 PoW+PoS,最後完全過渡到 PoS。所以,說以太坊的共識機制是PoS,沒錯,但是PoS只是以太坊發布之初的一個計劃或者說目標,目前以太坊還沒有過渡到 PoS,以太坊採用的共識機制仍是 PoW,就是比特幣那個 PoW,但是又和比特幣的PoW稍稍不同。
這里的信息量有點大,
第一個信息點是:以太坊目前採用的共識機制也是PoW,但是和比特幣的PoW稍稍不同。那麼,和比特幣的PoW到底有什麼不同呢:簡單來說,就是以太坊挖礦難度可以調節,比特幣挖礦難度不能調節。就好比咱們高考,因為各個省份的教學情況、生源人數都不一樣,所以高考分為全國卷和各省自主命題。
以太坊說我贊成這樣分地區出題,比特幣說:不行,必須全國同一卷,大家難度都一樣!
通俗解釋,就是,比特幣是利用計算機算力做大量的哈希碰撞,列舉出各種可能性,來找到一個正確哈希值。而以太坊系統呢,它有一個特殊的公式用來計算之後的每個塊的難度。如果某個區塊比前一個區塊驗證的更快,以太坊協議就會增加區塊的難度。通過調整區塊難度,就可以調整驗證區塊所需的時間。
以太坊協議規定,難度的動態調整方式是使全網創建新區塊的時間間隔為 15 秒,網路用 15 秒時間創建區塊鏈,這樣一來,因為時間太快,系統的同步性就大大提升,惡意參與者很難在如此短的時間發動51%(也就是半數以上)的算力去修改歷史數據。
第二個信息點是:以太坊最初的設定中,希望通過階段性升級來最終實現由 PoW 向
PoS過渡的。
時間追溯到 2014 年,在以太坊發布之初,團隊宣布將項目的發布分為四個階段,即 Froniter(前沿)、Homestead(家園)、Metropolis(大都會)和 Serenity(寧靜)。前三個階段共識機制採用 PoW(工作量證明機制),第四個階段切換到 PoS(權益證明機制)。
2015年7月30號,以太坊第一個階段「前沿」正式發布,這個階段只適用於開發者使用,開發人員可於在以太坊網路上編寫智能合約和去中心化應用程序 DAPP,礦工開始進入以太坊網路維護網路安全並挖礦得到以太幣。前沿版本類似於測試版,證明以太坊網路到底是不是可靠的。
2016年3月14日,以太坊進入到第二個階段「家園」,這一階段,以太坊提供了錢包功能,讓普通用戶也可以方便體驗和使用以太坊。其他方面沒有什麼明顯的技術提升,只是表明以太坊網路已經可以平穩運行。
2017 年 9 月,以太坊已經進行到第三個階段「大都會」。「大都會」由拜占庭和君士坦丁堡兩次升級組成,這個階段的的目標是希望能夠引入 PoW 和 PoS 的混合鏈模式,為 PoW向PoS的順滑過渡做准備。最近比較熱門的「以太坊君士坦丁堡升級」升級的就是這個,在君士坦丁堡升級中呢,以太坊將對底層協議和演算法做一些改變,來為實現 PoW 和
PoS奠定良好的基礎。
以太坊挖礦會得到對多少獎勵呢?贏得區塊創建競爭成功的礦工會得到這么幾項收入:
1、 靜態獎勵,5個以太坊;
2、 區塊內所花費的燃料成本,也就是Gas,這部分我們上一期內容講過;
3、 作為區塊組成部分,包含「叔區塊」的額外獎勵,叔就是叔叔的叔,每個叔區塊可以得到挖礦報酬的1/32作為獎勵,也就是5乘以1/32,等於0.15625 個以太坊。這里我們簡單解釋一下「叔區塊」,「叔區塊」這個概念是以太坊提出來的,為什麼要引進叔塊的概念?這還要從比特幣說起。在比特幣協議中,最長的鏈被認為是絕對的正確。如果一個塊不是最長鏈的一部分,那麼它被稱為是「孤塊」。一個孤立的塊是一個塊,它也是合法的,但是可能發現的稍晚,或者是網路傳輸稍慢,而沒有能成為最長的鏈的一部分。在比特幣中,孤塊沒有意義,隨後將被拋棄掉,發現這個孤塊的礦工也拿不到采礦相關的獎勵。
但是,以太坊不認為孤塊是沒有價值的,以太坊系統也會給與發現孤塊的礦工回報。在以太坊中,孤塊被稱為「叔塊」(uncle block),它們可以為主鏈的安全作出貢獻。 以太坊十幾秒的出塊間隔太快了,會降低安全性,通過鼓勵引用叔塊,使引用主鏈獲得更多的安全保證(因為孤塊本身也是合法的) ,而且,支付報酬給叔塊,還能激發礦工積極挖礦,積極引用叔塊,所以,以太坊認為,它是有價值的。
㈥ 以太坊的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)
㈦ 以太坊存在的問題
1.擴展性不足:
以太坊社區的主要開發人員和研究人員始終認為區塊鏈技術要實現大規模採用,可擴展性是區塊鏈應用程序需要解決的唯一最重要的關鍵。
以太坊的底層設計,最大的問題是以太坊只有一條鏈,沒有側鏈,它把所有的程序對等的跑在全球所有節點的礦機上。這樣一個很耗資源的程序,會導致問題越來越嚴重。
2.合約程序漏洞,無法抵禦DDOS攻擊
據相關研究表明,在基於以太坊的近100萬個智能合約上,發現有34,200(約3%)個含有安全漏洞,將允許黑客竊取ETH、凍結資產或刪除合約。這幾年,以太坊面對合約程序漏洞和DDOS攻擊的問題,也一直無法找到很好的解決辦法。(更好用的數字貨幣交易平台「幣匯」)
3.對於ICO泡沫和項目方砸盤
目前的ETH下跌,很大程度上來自於項目方的砸盤套現,這個問題可以在ICO代幣融資上進行規則限制,不能像現在這樣毫無成本的就能發一個幣,而且還沒有任何監督懲罰機制。任何事情都需要有一套合理的演進規則,大家按規則辦事,所謂無規矩不成方圓。在規則的基礎上,各類ICO項目有效監督,有序進出,才是一個正常的市場,這樣才可能維系著代幣生態的持續、穩定發展。
4.智能合約費用過高
在以太坊上現在還是POW的挖礦模式,交易是有手續費的,用來激勵礦工來處理交易和保護網路,不同的是以太坊是以「gas」的形式來收費的。
在以太坊協議中規定,交易手續費=Gas 數量 x Gas 價格,其中 Gas 數量由智能合約的復雜程度決定,而 Gas 價格則由合約發起人決定。這對開發者和用戶意味著什麼呢?雖然讀取本地區塊鏈是免費的,但寫入和運算是花錢的,儲存更是尤其昂貴,因為任何寫入的信息都會被永久的儲存著。
5.社區對共識協議改變的分歧
以太坊計劃實現將 POW 機制改為 POW/POS 混合共識機制。但這個涉及到技術開發和礦工雙方能否達到利益共識的問題了。如果協議發生了變化,社區意見不合時,就會導致分叉,大家各自玩各自的。
㈧ ETH銷毀機制銷毀的是誰的ETH
ETH銷毀機制銷毀的是EIP-1559的ETH,EIP-1559改善提案旨在提升以太坊網路性能,降低過往高昂的GAS費用,減少鏈上擁堵情況,改善用戶體驗,EIP-1559本質上是關於以太坊網路交易定價機制的解決方案,它包括每區塊網路費用的固定部分base fee,也就是基礎費用,會被銷毀,礦工收不到這筆費用,同時還有動態的可伸縮的區塊大小設計,以應對瞬時的網路擁堵。
本次升級將直接影響以太坊礦工的收益,當EIP-1559提案實施後,礦工僅可以得到區塊獎勵和用戶的小費,但是EIP-1559 可以讓未來的以太坊 Gas 手續費更加可預測和穩定,同時未來以太坊網路中可能近一半的網路手續費將被直接銷毀,雖然當前行情相對低迷,但是 ETH 銷毀對 ETH 未來的長期價值支撐有著深遠影響,特別是未來以太坊過渡到 PoS 後,在以太坊生態繁榮的前提下,網路銷毀的 ETH 手續費甚至可以抵消網路新發行的 ETH 代幣,推動 ETH 進入通縮時代。
拓展資料
一、ETH的概述
Ethereum(以太坊)是一個平台和一種編程語言,使開發人員能夠建立和發布下一代分布式應用。 Ethereum可以用來編程,分散,擔保和交易任何事物:投票,域名,金融交易所,眾籌,公司管理, 合同和大部分的協議,知識產權,還有得益於硬體集成的智能資產。
二、、為什麼銷毀ETH
1、 一些項目採用PoB(Proof of Burn)燃燒證明機制,通過銷毀代幣來證明用戶對網路的投入,從而獲得「挖礦」以及驗證交易的權利。
2、減少流通量,從而提高代幣價值。比如某些通過銷毀代幣的方式,減少市場上的流通量,從而給代幣增加價值,如幣安、火幣都會定期銷毀一部分平台幣。
3、因其他原因進行的代幣銷毀,比如用戶錯誤操作或有意將代幣打入黑洞地址,或某些項目智能合約默認的Gas燃燒地址等。
㈨ 以太幣是什麼
以太坊Ethereum是一個區塊鏈。它與比特幣相比特點是可以增加智能合約,圖靈完備,網路速度更快。Etherem上有很多區中心化的區塊鏈產品,比如DigixDAO,黃金物聯網等等。
㈩ 以太坊是什麼丨以太坊開發入門指南
以太坊是什麼丨以太坊開發入門指南
很多同學已經躍躍欲試投入到區塊鏈開發隊伍當中來,可是又感覺無從下手,本文將基於以太坊平台,以通俗的方式介紹以太坊開發中涉及的各晦澀的概念,輕松帶大家入門。
以太坊是什麼
以太坊(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來搭建一個測試網路。
註:本文中為了方便大家理解,對一些概念做了類比,有些嚴格來不是准確,不過我也認為對於初學者,也沒有必要把每一個概念掌握的很細致和准確,學習是一個逐步深入的過程,很多時候我們會發現,過一段後,我們會對同一個東西有不一樣的理解。
