A. 以太幣挖礦,用什麼來挖
以太幣挖礦教程
1、在硬碟上新建文件夾,比C:Eth。之後所有挖礦軟體就存放在這里。
2、下載以下軟體
1)Geth——選擇Geth-Win下載然後解壓
2)Ethminer——下載解壓到同一個文件夾,重命名為「miner」
3)Ethereum Wallet(以太坊錢包)——下載Win以太坊錢包,解壓之後重命名「wallet」
安裝好所有軟體
3、打開命令提示符(同時點擊Win和R鍵或者點擊開始菜單然後輸入cmd)。命令提示符是命令行解析器,讓你在操作系統中執行命令輸入的軟體。
之後你就擁有以太坊錢包了。但是沒有餘額,所以接下來你需要建立ethminer。暫時可以最小化錢包了。
挖礦
B. 浠ュお鍧婃寲鐭塊渶瑕佸摢浜涚‖浠惰懼
浠ュお鍧婃寲鐭塊渶瑕佺殑涓昏佺‖浠惰懼囧寘鎷楂樻ц兘鍥懼艦澶勭悊鍣錛圙PU錛夈佷笓鐢ㄦ寲鐭胯姱鐗囷紙ASIC錛夋垨涓澶澶勭悊鍣錛圕PU錛夛紝浠ュ強紼沖畾鐨勭綉緇滆繛鎺ュ拰瓚沖熺殑鐢靛姏渚涘簲銆
楂樻ц兘鍥懼艦澶勭悊鍣錛圙PU錛夛細鍦ㄤ互澶鍧婃寲鐭跨殑鍒濇湡錛岃稿氱熆宸ヤ嬌鐢–PU榪涜屾寲鐭匡紝浣嗛殢鐫闅懼害鐨勫炲姞錛孋PU鐨勭畻鍔涘凡緇忔棤娉曟弧瓚抽渶奼傘傚洜姝わ紝楂樻ц兘鐨凣PU鎴愪負浜嗕富嫻侀夋嫨銆侴PU鎿呴暱澶勭悊澶ч噺騫惰岃$畻浠誨姟錛岃繖瀵逛簬鎵ц屾寲鐭跨畻娉曢潪甯告湁鍒┿備緥濡傦紝NVIDIA鍜孉MD絳夊叕鍙哥敓浜х殑鏄懼崱鍦ㄤ互澶鍧婃寲鐭誇腑寰楀埌浜嗗箍娉涘簲鐢ㄣ
涓撶敤鎸栫熆鑺鐗囷紙ASIC錛夛細闅忕潃鍔犲瘑璐у竵鎸栫熆鐨勪笉鏂鍙戝睍錛屽嚭鐜頒簡涓撻棬鐢ㄤ簬鎸栫熆鐨勯泦鎴愮數璺鑺鐗囷紝鍗矨SIC銆備笌GPU鐩告瘮錛孉SIC鍦ㄧ畻鍔涘拰鑳芥晥姣旀柟闈㈡湁鐫鏄捐憲浼樺娍銆傜劧鑰岋紝鍦ㄤ互澶鍧婄綉緇滀腑錛孉SIC鐨勪嬌鐢ㄦ浘涓搴﹀彈鍒伴檺鍒訛紝鍥犱負浠ュお鍧婄殑鍒涘嬩漢甯屾湜淇濇寔鎸栫熆鐨勫幓涓蹇冨寲銆備絾闅忕潃鏃墮棿鐨勬帹縐伙紝涓浜涢拡瀵逛互澶鍧婄殑ASIC鐭挎満涔熼愭笎鍑虹幇錛屽侭itmain鐢熶駭鐨凙ntminer E3絳夈
涓澶澶勭悊鍣錛圕PU錛夛細鉶界劧CPU鍦ㄧ畻鍔涗笂鏃犳硶涓嶨PU鍜孉SIC鐩告瘮錛屼絾鍦ㄦ煇浜涙儏鍐典笅錛屽畠浠嶇劧鏄涓縐嶅彲琛岀殑鎸栫熆閫夋嫨銆備緥濡傦紝瀵逛簬涓浜涙嫢鏈夊ぇ閲忛棽緗瓹PU璧勬簮鐨勭敤鎴鋒潵璇達紝浣跨敤CPU榪涜屾寲鐭垮彲浠ュ厖鍒嗗埄鐢ㄨ繖浜涜祫婧愩傛ゅ栵紝涓浜涙柊鍨婥PU鍦ㄨ兘鏁堟瘮鏂歸潰涔熸湁鎵鎻愬崌錛屼嬌寰椾嬌鐢–PU鎸栫熆鍙樺緱鏇村姞緇忔祹楂樻晥銆
闄や簡浠ヤ笂紜浠惰懼囧栵紝紼沖畾鐨勭綉緇滆繛鎺ュ拰瓚沖熺殑鐢靛姏渚涘簲涔熸槸浠ュお鍧婃寲鐭挎墍蹇呴渶鐨勩傜綉緇滆繛鎺ョ殑紼沖畾鎬х洿鎺ュ獎鍝嶅埌鐭挎満涓庝互澶鍧婄綉緇滅殑鍚屾ラ熷害浠ュ強鎻愪氦宸ヤ綔閲忕殑鏁堢巼錛涜岃凍澶熺殑鐢靛姏渚涘簲鍒欐槸紜淇濈熆鏈鴻兘澶熸寔緇紼沖畾榪愯岀殑鍩虹銆傚洜姝わ紝鍦ㄩ夋嫨鎸栫熆紜浠惰懼囨椂錛岃繖浜涘洜緔犱篃闇瑕佺患鍚堣冭檻銆
C. 浠ュお鍧婃庝箞鎸栫熆錛
涓庢墍鏈夊尯鍧楅摼鎶鏈涓鏍鳳紝浠ュお鍧婁嬌鐢ㄥ熀浜庢縺鍔辯殑瀹夊叏妯″瀷銆備換浣曞0縐版槸緗戠粶涓鐨勭熆宸ョ殑鑺傜偣閮藉彲浠ュ皾璇曞壋寤哄苟楠岃瘉鍖哄潡銆備笘鐣屽悇鍦扮殑璁稿氱熆宸ュ悓鏃跺壋寤哄拰楠岃瘉鍖哄潡銆備互涓嬫槸鍏充簬浠ュお鍧婃寲鐭跨殑璇︾粏璇存槑銆
涓銆佷互澶鍧婇噰鐭跨殑鍩烘湰鍘熷垯
1. 涓庢墍鏈夊尯鍧楅摼鎶鏈涓鏍鳳紝浠ュお鍧婁嬌鐢ㄥ熀浜庢縺鍔辯殑瀹夊叏妯″瀷銆備換浣曞0縐版槸緗戠粶涓鐨勭熆宸ョ殑鑺傜偣閮藉彲浠ュ皾璇曞壋寤哄苟楠岃瘉鍖哄潡銆備笘鐣屽悇鍦扮殑璁稿氱熆宸ュ悓鏃跺壋寤哄拰楠岃瘉鍖哄潡銆傛瘡涓鐭垮伐閫氳繃鍚戝尯鍧楅摼鍙戦佸潡鏉ユ彁渚涙暟瀛︽満鍒剁殑鈥滆瘉鎹鈥濄傛ゆ祴璇曠被浼間簬淇濊瘉錛氬傛灉姝ゆ祴璇曞瓨鍦錛屽垯姝ゅ潡蹇呴』鏈夋晥銆
浜屻佷互澶鍧婂拰姣旂壒甯佺殑鍖哄埆
1. 鐩稿悓鐐癸細姣旂壒甯佸拰浠ュお鍧婇兘鏄鎴愬姛鐨勫尯鍧楅摼鎶鏈搴旂敤銆備漢浠閫氳繃姣旂壒甯佽よ瘑鍖哄潡閾炬妧鏈銆傞氳繃浠ュお鍧婏紝浜轟滑鎰忚瘑鍒板尯鍧楅摼鍙浠ユ槸鐙絝嬬殑銆傛墍鏈夎繖浜涢兘鍩轟簬鍖哄潡閾撅紝鍏朵腑浜ゆ槗鏄鍏寮璁板綍鐨勶紝璐у竵鍜岃祫浜т氦鏄撴洿鏂逛究鍜岃╂ワ紝騫朵笖娑堥櫎浜嗙箒鐞愮殑涓闂翠漢銆
2. 宸寮傦細姣旂壒甯佹槸涓縐嶅垎鏁g殑鐐瑰圭偣鏁板瓧鏀浠樼郴緇燂紝綾諱技浜庡叏鐞冩竻綆楅摱琛屻傝屼笖榪欏墮摱琛屼笉鏄涓涓闆嗕腑寮忕粍緇囩殑鎴愬憳錛屽畠娌℃湁CEO錛屽畠娌℃湁綆$悊鍛橈紝鍙鏈変唬鐮佺殑鍩烘湰鍘熷垯鍜屽叡璇嗐備粠鍚岃岃漿縐諱環鍊礆紝娌℃湁鍏朵粬絎涓夋柟鎴栦俊鎵樻満鏋勩傛瘮鐗瑰竵鎬婚噺涓2100W銆傚逛簬姣忕敓鎴21W鐨勫潡鍋氳侊紝鍧楃敓鎴愮殑姣旂壒甯佹暟閲忓噺灝戜竴鍗婏紝姣10鍒嗛挓鐢熸垚涓涓鍧椼備竴鑸鑰岃█錛屽畠鏄涓縐嶉氳揣緔х緝鐨勭數瀛愯揣甯併
涓夈佹櫤鑳藉悎綰﹀拰鍗忚
1. 鏅鴻兘鍚堢害棣栧厛鏄鍚堝悓錛屽畠浠ヤ唬鐮佺殑褰㈠紡瑙勫畾浜ゆ槗鎵ц岀殑鍙屾柟錛屽苟瑙勫畾浜嗘墽琛屽悎鍚岀殑鏌愪簺嬋媧繪潯浠躲備竴鏃﹁繖浜涙潯浠惰嬋媧伙紝鍟嗗畾鐨勪氦鏄撳氨浼氳嚜鍔ㄦ墽琛岋紝閫氬父鏄涓浜涗氦鏄撱傝繖浜涗氦鏄撳皢鐢辯熆宸ユ寲鎺樺嚭鏉ワ紝騫舵渶緇堝悎騫跺埌鍏鍏遍摼涓錛岃繖鏄涓嶅彲鍚﹁ょ殑錛屼笉鍙閫嗚漿銆
2. 浠ュお鍧婁腑鐨勬櫤鑳藉悎綰﹀熀鏈涓婃槸浜掕仈緗戜笂鐨勫紑婧愩備換浣曠敤鎴烽兘鍙浠ョ湅鍒扮浉鍏蟲帴鍙g殑瀹氫箟鍜屾縺媧繪椂闂淬傚傛灉娌℃湁緇熶竴鐨勬爣鍑嗭紝璁稿氭櫤鑳藉悎綰﹀皢浣挎瘡涓浜洪兘闅句互鐞嗚В錛岃繖浠芥櫤鑳藉悎綰︾┒絝熷仛浜嗕粈涔堬紵姝ゆ椂錛孍RC20鍗忚宸插惎鍔ㄣ
3. 寮鍙戜漢鍛樺彲浠ラ氳繃鏌ョ湅鍏朵粬鏅鴻兘鍚堢害鐒跺悗璋冪敤鑷宸辯殑鍚堝悓杞繪澗浜嗚В鐩稿叧鐣岄潰鐨勮掕壊銆傛爣鍑嗗寲鏄闈炲父鏈夌泭鐨勶紝榪欐剰鍛崇潃榪欎簺璧勪駭鍙浠ュ湪涓嶅悓鐨勫鉤鍙板拰欏圭洰涓浣跨敤錛屽惁鍒欏畠浠鍙鑳藉湪鐗瑰畾鎯呭喌涓嬩嬌鐢ㄣ
鍥涖佷負浠涔堜互澶鍧婂彲浠ョ敤鏉ュ彂閫佺‖甯
鍥犱負鏅鴻兘鍚堝悓鐨勫瓨鍦ㄧ殑錛屽悎鍚屽彲浠ヨ鐢ㄦ潵瀹夋帓璐у竵闆嗚祫鏈鍚庡瓨鍏ュ笎鎴風殑鐢ㄦ埛錛屽苟涓斿洜涓0x7D0浣跨敤鐩稿悓鐨勬爣鍑咵RC20濡傜洿鎺ヤ氦鎹0x7D0鍜孎AD鏀鎸佷互澶鍧婄敓鎬佺郴緇熻繖灝嗘洿瀹規槗銆
浜斻佷互澶鍧婁氦鏄撻檺鍒
1. 瀵逛簬姣忕瑪浜ゆ槗錛屼氦鏄撶殑鍙戣搗浜哄繀欏昏懼畾浜ゆ槗鐨凣as闄愪環鍜孏as浠鋒牸銆備笉鍚岀殑鎿嶄綔灝嗕駭鐢熶笉鍚岀殑Gas錛孏as鎴愭湰褰撶熆宸ュ畬鎴愬悗錛岀熆宸ュ皢鍋滄㈣繍琛屽苟涓旂敤榪囩殑Gas灝嗚濂栧姳緇欑熆宸ャ
2. 濡傛灉鏌愪簺姘斾綋浠嶇劧瀛樺湪錛屽傛灉鐢ㄦ埛澹版槑闄愬埗鍊煎お紓ㄧ墿浣庢垨鑰呬腑闂寸殑甯愬彿Eth涓嶈凍浠ユ敮浠楪as娑堣楋紝瀹冨皢榪斿洖鍒頒氦鏄撶殑鍙戣搗浜烘垨鏅鴻兘鍚堢害鐨勫壋寤鴻咃紝鐢變簬Gas涓嶈凍錛屽崗璁灝嗚鍙栨秷錛岀敤浜庤$畻鐨凣as灝嗕笉浼氶鍥炶處鎴楓
鍏銆佺綉緇滆$畻鑳藉姏
緗戠粶璁$畻鑳藉姏涓轟互澶鍧婂叏緗戠粶涓鎵鏈夊綋鍓嶆寲鐭挎満鍣ㄧ殑鎬昏$畻鑳藉姏錛屽綋鍓嶆寲鐭塊泦緹ゆ槸鏍規嵁璇ュ艱$畻鐨勫綋鍓嶅潡鐨勯毦搴︺
涓冦佷互澶鍧婃彁鍙栭毦搴
鍧楃殑闅懼害鐢ㄤ簬鎻愰珮鍧楅獙璇佸尯鐨勪竴鑷存с侴enesis鍧楃殑闅懼害鏄131,072錛屽苟涓旀湁涓涓鐗規畩鐨勫叕寮忕敤浜庤$畻涔嬪悗姣忎釜鍧楃殑闅懼害銆傚傛灉媯鏌ュ潡姣斿墠涓涓鍧楁洿蹇錛屽垯浠ュお鍧婂崗璁灝嗗炲姞鍧楃殑闅懼害銆傞氳繃璋冩暣鍧楃殑闅懼害錛屾偍鍙浠ヨ皟鏁撮獙璇佸尯鍧楁墍闇鐨勬椂闂達紝鍗崇獊鍙戦熷害銆傛鏌ユ椂闂寸殑鑷鎴戣皟鏁翠互緇х畫浠ユ亽瀹氶熺巼鐢熸垚鏂板揩銆
鍏銆佸崟寮犲崱鐨勮$畻鑳藉姏涓庢寲鐭挎敹鍏ヤ箣闂寸殑鍏崇郴
鍗曞紶鍗$殑璁$畻鑳藉姏瓚婂ぇ錛屽彲浠ヨ繘琛岀殑媯鏌ヨ秺澶氾紝鑾峰緱鍏寮忕粨鏋滅殑姒傜巼瓚婂ぇ錛屾儏鍐佃秺澶э紝濡傛灉浣跨敤鐭挎満緇勶紝鎵鎻愪緵鐨勮偂浠芥暟閲忚秺澶э紝鎸栫熆涓氱殑鏀跺叆灝辮秺澶с
D. 以太坊是如何挖礦的
以太坊的代幣是通過采礦過程中產生的,每塊采礦率為 5 個以太幣。以太坊的采礦過程幾乎與比特幣相同,對於每一筆交易,礦工都可以使用計算機通過散列函數運行該塊的唯一標題元數據,反復,快速地猜出答案,直到其中一人獲勝。
許多新用戶認為,采礦的唯一目的是以不需要中央發行人的方式生成醚(參見我們的指南「 什麼是以太? 」)。這是真的。以太坊的代幣是通過采礦過程中產生的,每塊采礦率為 5 個以太幣。但是,采礦還有至少同樣重要的作用。通常,銀行負責保持交易的准確記錄。他們確保資金不是憑空創造的,用戶不會多次欺騙和花錢。不過,區塊鏈引入了一種全新的記錄保存方式,整個網路而不是中介,驗證交易並將其添加到公共分類賬。
Ethereum Mining
盡管「無信任」或「信任最小化」貨幣體系是目標,但仍有人需要確保財務記錄的安全,確保沒有人作弊。采礦是使分散記錄成為可能的創新之一。礦工們在防止欺詐行為(特別是醚的雙重支出)方面達成了關於交易歷史的共識 – 這是一個有趣的問題,在分散化的貨幣未在工作區塊鏈之前解決。雖然以太坊正在研究其他方法來就交易的有效性達成共識,但采礦目前將平台保持在一起。
挖礦如何工作
今天,以太坊的采礦過程幾乎與比特幣相同。對於每一筆交易,礦工都可以使用計算機反復,快速地猜出答案,直到其中一人獲勝。更具體地說,礦工將通過散列函數(它將返回一個固定長度,亂序的數字和字母串,它看起來是隨機的)運行該塊的唯一標題元數據(包括時間戳和軟體版本),只改變』nonce 值』 ,這會影響結果散列值。
如果礦工發現與當前目標相匹配的散列,礦工將被授予乙醚並在整個網路上廣播該塊,以便每個節點驗證並添加到他們自己的分類賬副本中。如果礦工 B 找到散列,礦工 A 將停止對當前塊的工作,並為下一個塊重復該過程。礦工很難在這場比賽中作弊。沒有辦法偽造這項工作,並拿出正確的謎題答案。這就是為什麼解謎方法被稱為「工作證明」。
另一方面,其他人幾乎沒有時間驗證散列值是否正確,這正是每個節點所做的。大約每 12-15 秒,一名礦工發現一塊石塊。如果礦工開始比這更快或更慢地解決謎題,演算法會自動重新調整問題的難度,以便礦工回彈到大約 12 秒鍾的解決時間。
礦工們隨機賺取這些乙醚,他們的盈利能力取決於運氣和他們投入的計算能力。以太坊使用的具體工作量驗證演算法被稱為』ethash』,旨在需要更多的內存,使得使用昂貴的 ASIC 難以開采 – 特殊的采礦晶元,現在是唯一可以盈利的比特幣開采方式。
從某種意義上講,ethash 可能已經成功實現了這一目的,因為專用 ASIC 不可用於以太坊(至少目前還沒有)。此外,由於以太坊旨在從工作證明挖掘轉變為「股權證明」(我們將在下面討論),購買 ASIC 可能不是一個明智的選擇,因為它可能無法長久證明有用。
轉移到股權證明
不過,以太坊可能永遠不需要礦工。開發人員計劃放棄工作證明,即網路當前使用的演算法來確定哪些交易是有效的,並保護其免受篡改,以支持股權證明,網路由代幣所有者擔保。如果並且當該演算法推出時,股權證明可以成為實現分布式共識的一種手段,而該共識使用更少的資源。
E. 浠ュお鍧婃寲鐭跨殑綆楁硶鏄浠涔
浠ュお鍧婃寲鐭跨殑綆楁硶鏄浠涔堬紵
浠ュお鍧婃寲鐭跨殑綆楁硶鏄浠涔堬紵
浠ュお鍧婃槸涓縐嶅尯鍧楅摼鎶鏈錛屽彲鐢ㄤ簬鍒涘緩鍒嗗竷寮忓簲鐢ㄧ▼搴忥紙DApps錛夈傛寲鎺樹互澶鍧婄殑榪囩▼娑夊強閫氳繃璁$畻瑙e喅鏁板﹂棶棰樻潵娣誨姞鏂板潡錛岃繖琚璁や負鏄鈥滃伐浣滆瘉鏄庘濈畻娉曪紝浠ヤ繚鎸佸尯鍧楅摼鐨勫畨鍏ㄦу拰瀹屾暣鎬с傝繖涓綆楁硶鍚嶄負鈥淓thash鈥濓紝騫跺湪2015騫村彂甯冧簡浠ュお鍧婄殑絎涓鐗堛
Ethash綆楁硶鏄涓縐嶆暎鍒楀嚱鏁扮畻娉曪紝瀹冨熀浜庡搱甯岀巼錛圚ashrate錛夊拰綆楃姸鎬佹牴錛圫tateRoot錛変駭鐢熸棤瑙勫緥涓斿滻瀹氶毦搴︾殑闂棰樸傝繖涓綆楁硶鐨勭嫭鐗逛箣澶勫湪浜庡畠闇瑕佸ぇ閲忕殑鍐呭瓨錛屼笉鍒╀簬ASIC錛堜笓鐢ㄩ泦鎴愮數璺錛夌殑瀹炵幇鎸栨帢錛岄槻姝涓浜轟互鍙婂皯鏁扮熆宸ヨ幏寰楁洿楂樼殑絝炰簤鍔涳紝浠庤屽炲姞浜嗗幓涓蹇冨寲鐨勭綉緇滃畨鍏ㄦс
鎸栨帢浠ュお鍧婇渶瑕佺殑紜浠朵篃鏈変竴浜涚壒孌婅佹眰銆傞櫎浜咷PU錛堝浘褰㈠勭悊鍣錛夎兘澶熸樉鐫鎻愰珮鎬ц兘澶栵紝鍐呭瓨閲忎篃闇瑕佽凍澶熷ぇ浠ュ圭撼寮閲囪繃紼嬩腑浣跨敤鐨勬暟鎹鍧椼傛ゅ栵紝浠ュお鍧婅繕瑕佹眰浣跨敤楂橀熶簰鑱旂綉榪炴帴銆
鍦ㄦ寲鎺樹互澶鍧婃椂錛岀熆宸ュ繀欏繪壘鍒頒竴涓鈥渘once鈥濓紙涓涓鐢ㄤ簬璁$畻鏁e垪鍑芥暟鐨勪換鎰忔暟瀛楋級錛屼嬌寰楀潡澶寸殑鍝堝笇鍊兼弧瓚崇綉緇滅殑闅懼害瑕佹眰銆傝繖縐嶉毦搴︽槸鍔ㄦ佺殑錛屽彇鍐充簬鐭垮伐鐨勬諱綋綆楀姏鍜岀綉緇滀笂鐨勮妭鐐規暟閲忋傚洜姝わ紝鎸栨帢浠ュお鍧婇渶瑕佸ぇ閲忕殑璁$畻鑳藉姏鍜岀數鍔涳紝浠ュ強蹇閫熺殑浜掕仈緗戣繛鎺ワ紝浠ヤ究涓庣綉緇滆繘琛屽悓姝ャ
鎬葷粨涓涓嬶紝浠ュお鍧婄殑鎸栫熆綆楁硶Ethash鏄涓縐嶆暎鍒楀嚱鏁扮畻娉曪紝闇瑕佸ぇ閲忕殑鍐呭瓨鏉ラ槻姝ASIC鎸栨帢錛屼粠鑰屽炲姞浜嗗幓涓蹇冨寲鐨勭綉緇滃畨鍏ㄦс傛寲鎺樹互澶鍧婇渶瑕佸ぇ閲忕殑璁$畻鑳藉姏銆佸唴瀛樺拰緗戠粶榪炴帴銆
F. 以太坊是什麼丨以太坊開發入門指南
以太坊是什麼丨以太坊開發入門指南
很多同學已經躍躍欲試投入到區塊鏈開發隊伍當中來,可是又感覺無從下手,本文將基於以太坊平台,以通俗的方式介紹以太坊開發中涉及的各晦澀的概念,輕松帶大家入門。
以太坊是什麼
以太坊(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來搭建一個測試網路。
註:本文中為了方便大家理解,對一些概念做了類比,有些嚴格來不是准確,不過我也認為對於初學者,也沒有必要把每一個概念掌握的很細致和准確,學習是一個逐步深入的過程,很多時候我們會發現,過一段後,我們會對同一個東西有不一樣的理解。
G. 浠ュお鍧婄殑鎸栫熆鏂瑰紡鏄浠涔
浠ュお鍧婄殑鎸栫熆鏂瑰紡鏄浠涔堬紵
浠ュお鍧婄殑鎸栫熆鏂瑰紡鏄浠涔堬紵
浠ュお鍧婃槸涓縐嶅熀浜庡尯鍧楅摼鎶鏈鐨勫姞瀵嗚揣甯侊紝鏃ㄥ湪涓哄幓涓蹇冨寲搴旂敤鎻愪緵騫沖彴銆備笌姣旂壒甯佷竴鏍鳳紝浠ュお鍧婄殑浜ゆ槗闇瑕侀氳繃鎸栫熆鎵嶈兘寰楀埌楠岃瘉鍜岀『璁ゃ傞偅涔堜互澶鍧婄殑鎸栫熆鏂瑰紡鏄浠涔堝憿錛
浠ュお鍧婄殑鎸栫熆鏂瑰紡涓庢瘮鐗瑰竵鏈夊緢澶氱浉浼間箣澶勶紝閮芥槸閫氳繃瑙e喅鏁板﹂棶棰樻潵鑾峰緱姣旂壒甯佹垨浠ュお甯併傝繖浜涢棶棰橀渶瑕佺殑璁$畻璧勬簮闈炲父楂橈紝鍥犳ら渶瑕佸ぇ閲忕殑鐢靛姏鍜岃$畻鑳藉姏銆
浠ュお鍧婇噰鐢ㄧ殑鏄宸ヤ綔閲忚瘉鏄庯紙ProofofWork錛夌殑綆楁硶錛屽嵆ETHash銆備笌姣旂壒甯佹寲鐭跨殑SHA-256綆楁硶涓嶅悓錛孍THash綆楁硶鏄鍩轟簬DAG鍥懼艦鐨勮$畻銆侱AG鍥炬槸涓縐嶆湁鍚戞棤鐜鍥撅紝鐢變互澶鍧婂垵濮嬪潡鐢熸垚錛屾瘡涓鏂扮殑鍖哄潡閮藉熀浜庡墠涓涓鍖哄潡鐨凞AG榪涜岃$畻銆傚洜姝わ紝綆鍗曞湴璇達紝浠ュお鍧婃寲鐭塊渶瑕佽В鍐矰AG鍥懼艦鐨勮$畻闂棰樸
鍏蜂綋鏉ヨ達紝浠ュお鍧婄殑鎸栫熆榪囩▼鏄榪欐牱鐨勶細
1.鎸栫熆鑺傜偣鍦ㄧ綉緇滀笂鑾峰緱鏂扮殑浜ゆ槗淇℃伅銆
2.鎸栫熆鑺傜偣灝嗚繖浜涗氦鏄撲俊鎮鎵撳寘鎴愪竴涓鍖哄潡銆
3.鎸栫熆鑺傜偣浠庝互澶鍧婄綉緇滆幏鍙栧埌鍓嶄竴鍖哄潡鐨凞AG鍥俱
4.鎸栫熆鑺傜偣浣跨敤DAG鍥句笂鐨勮妭鐐硅繘琛岃$畻錛屼互鐢熸垚鏂扮殑鍖哄潡銆
5.鎸栫熆鑺傜偣閫氳繃緗戠粶灝嗘柊鐨勫尯鍧楀彂閫佸埌鍏朵粬鑺傜偣榪涜岀『璁ゃ
6.鍏朵粬鑺傜偣涔熼渶瑕佽В鍐矰AG鍥懼艦鐨勮$畻闂棰橈紝浠ョ『璁よ繖涓鏂扮殑鍖哄潡鏄鍚﹀悎娉曘
7.濡傛灉鍏朵粬鑺傜偣楠岃瘉閫氳繃錛屽垯榪欎釜鏂扮殑鍖哄潡灝變細琚娣誨姞鍒頒互澶鍧婄殑鍖哄潡閾句笂銆
浠ュお鍧婄殑鎸栫熆榪囩▼鍙鑳芥瘮姣旂壒甯佹洿涓哄嶆潅錛屽洜涓哄畠闇瑕佽В鍐矰AG鍥懼艦鐨勮$畻闂棰樸傝繖涔熸剰鍛崇潃浠ュお鍧婄殑鎸栫熆闇瑕佹洿楂樼殑綆楀姏鍜屾洿澶х殑鐢靛姏鏀鎸併備絾涓庢ゅ悓鏃訛紝浠ュお鍧婄綉緇滀篃鍏峰囦簡鏇撮珮鐨勫畨鍏ㄦу拰鍙闈犳э紝鍥犱負瀹冮渶瑕佹洿澶氱殑鑺傜偣鍙備笌瑙e喅璁$畻闂棰樸
鎬葷殑鏉ヨ達紝浠ュお鍧婄殑鎸栫熆鏂瑰紡鏄宸ヤ綔閲忚瘉鏄庣畻娉曪紝浣跨敤鐨勬槸ETHash綆楁硶錛岄渶瑕佽В鍐矰AG鍥懼艦鐨勮$畻闂棰樸傝繖縐嶆寲鐭挎柟寮忛渶瑕佹洿楂樼殑璁$畻鑳藉姏鍜岀數鍔涙敮鎸侊紝浣嗕篃涓轟互澶鍧婄綉緇滄彁渚涗簡鏇撮珮鐨勫畨鍏ㄦу拰鍙闈犳с
H. ETH的挖礦原理與機制
以太坊的挖礦過程與比特幣的幾乎是一樣的。ETH通過挖礦產生,平均每15秒產生1個塊,挖礦的時候,礦工使用計算機去計算一道函數計算題的答案,直到有礦工計算到正確答案即完成區塊的打包信息,而作為第一個計算出來的礦工將會得到3枚ETH的獎勵。
如果礦工A率先算出正確的答案,那麼礦工A將獲得以太幣作為獎勵,並在全網廣播告訴所有礦工「我已經把答案算出來了」並讓所有在答題的礦工們進行驗證並更新正確答案。如果礦工B算出正確答案,那麼其他礦工將會停止當前的解題過程,記錄正確答案,並開始做下一道題,直到算出正確答案,並一直重復此過程。
礦工在這個游戲中很難作弊。他們是沒法偽裝工作又得出正確答案。這就是為什麼這個解題的過程被稱為「工作量證明」(POW)。
解題的過程大約每12-15秒,礦工就會挖出一個區塊。如果礦工挖礦的速度過快或者過慢,演算法會自動調整題目的難度,把出塊速度保持在13秒左右。
礦工獲取這些ETH幣是有隨機性的,挖礦的收益取決於投入的算力,就相當你的計算機越多,你答題的正確的概率也就越高,更容易獲得區塊獎勵。
I. 一文了解以太坊礦機及挖礦原理
在以前的文章中,我們分別了解了比特幣挖礦和以太坊挖礦的區別。本文重點介紹以太坊挖礦及礦機部分。
以太坊是一個開源的有智能合約功能的公共區塊鏈平台,通過其專用加密貨幣ETH提供去中心化的以太虛擬機來處理點對點合約。目前ETH的挖礦主要是通過顯卡礦機,所謂顯卡礦機,其實就是類似家用台式機,只不過每台機器裡面有6-10張顯卡,並且沒有顯示器(如圖)。
圖:顯卡礦機
之所以以太坊沒有發展出類似於BTC一樣的ASIC礦機,主要是由於ETH的特殊挖礦機制決定的。
在ETH挖礦過程中,會產生一個DAG文件,該文件需要一直被調用,因此必須有專門的存儲空間放置。這個對於存儲空間的硬性需求會導致即使生產出來了ASIC晶元,也並不能大幅度降低單位算力的成本。簡單來說,就是性價比很差。
以太坊的DAG大小自2016年6月份引入Dagger-Hashimoto 演算法時的1GB開始,以每年約520MB的速度增大到了現在的 3.7G,預計2020年底以太坊的DAG大小將增加至4G。屆時,顯存小於4G的顯卡都將被陸續淘汰。
還需要介紹一點的是,由於顯卡礦機的體積通常是比特幣礦機的2-4倍,而消耗的電力卻只有比特幣礦機的1/2甚至更低,這就導致一般人不願意修建專門的顯卡礦機礦場(因為礦場主要賺取的是電費差價,同樣面積的場地,可以放置的顯卡數量少,消耗的電量更少)。即使有少量的顯卡礦場,收取的電費成本通常也比比特幣礦機礦場的高。
J. 2020騫翠互澶鍧婃寲鐭誇竴澶╄禋澶氬皯錛
浠ュお鍧婃寲鐭誇竴澶╄兘璧氱害鍑犲嶮鍒板嚑鐧劇編鍏冧笉絳銆
浠ュお鍧婃寲鐭跨殑鏀剁泭鍙楀埌澶氱嶅洜緔犵殑褰卞搷錛屽寘鎷浠ュお鍧婁環鏍箋佹寲鐭塊毦搴︺佺熆鏈烘ц兘絳夈傚叿浣撴潵璇達細
浠ュお鍧婁環鏍兼槸褰卞搷鎸栫熆鏀剁泭鐨勯噸瑕佸洜緔犮傚傛灉浠ュお鍧婁環鏍間笂娑錛屾寲鐭跨殑鏀剁泭涔熶細鐩稿簲澧炲姞銆傝繖鏄鍥犱負鎸栫熆鑾峰緱鐨勪互澶鍧婂彲浠ヤ綔涓烘姇璧勬垨浜ゆ槗璧勪駭錛屼環鏍間笂娑ㄦ剰鍛崇潃璧勪駭浠峰肩殑鎻愬崌銆
鎸栫熆闅懼害涔熸槸涓涓鍏抽敭鍥犵礌銆傞殢鐫瓚婃潵瓚婂氱殑鐭垮伐鍔犲叆浠ュお鍧婃寲鐭匡紝鎸栫熆鐨勯毦搴︿細閫愭笎澧炲姞銆傝繖鎰忓懗鐫鐭垮伐闇瑕佹洿澶氱殑璁$畻鑳藉姏鍜岀數鍔涙潵鎸栨帢浠ュお鍧婏紝浠庤屽炲姞浜嗘垚鏈銆傚洜姝わ紝鍦ㄩ毦搴﹁緝楂樼殑鎯呭喌涓嬶紝鐭垮伐闇瑕佹洿澶氱殑鏃墮棿鍜岃祫婧愭墠鑳借幏寰楃浉鍚岀殑鏀剁泭銆
鐭挎満鐨勬ц兘涔熸槸褰卞搷鎸栫熆鏀剁泭鐨勯噸瑕佸洜緔犱箣涓銆傛ц兘鏇村ソ鐨勭熆鏈哄彲浠ユ洿蹇鍦板勭悊浜ゆ槗騫舵寲鎺樺埌浠ュお鍧娿備笉鍚屽搧鐗屽拰鍨嬪彿鐨勭熆鏈烘ц兘宸寮傝緝澶э紝鍥犳わ紝鐭垮伐闇瑕佹牴鎹鑷宸辯殑闇奼傚拰棰勭畻閫夋嫨鍚堥傜殑鐭挎満榪涜屾寲鐭褲
緇煎悎浠ヤ笂鍥犵礌錛屼互澶鍧婃寲鐭誇竴澶╃殑鏀剁泭浼氬彈鍒板氱嶅洜緔犵殑褰卞搷錛屽叿浣撴敹鐩婂洜浜鴻屽紓銆備絾鏄錛岄氳繃鍚堢悊鐨勯厤緗鍜岀$悊錛岀熆宸ヤ粛鐒跺彲浠ラ氳繃浠ュお鍧婃寲鐭胯幏寰椾竴瀹氱殑鏀剁泭銆傝鋒敞鎰忥紝鐢變簬鏁板瓧璐у竵甯傚満鐨勬嘗鍔ㄦц緝澶э紝鍏蜂綋鐨勬敹鐩婃暟瀛楄繕闇瑕佹牴鎹甯傚満鎯呭喌榪涜岃瘎浼般
璇鋒敞鎰忥紝鎸栫熆鏄涓涓闀挎湡鐨勮繃紼嬶紝騫朵笖闇瑕佹姇鍏ュぇ閲忕殑紜浠惰祫婧愬拰鐢靛姏鎴愭湰銆傚湪鑰冭檻鎸栫熆涔嬪墠錛屽姟蹇呭圭浉鍏沖洜緔犺繘琛屽厖鍒嗕簡瑙e拰璇勪及錛岀『淇濊繖鏄涓涓鍙琛岀殑鎶曡祫欏圭洰銆