❶ Truechain之初探
從剛開始接觸以太坊的時候,就覺得單一共識模型實在是有些寡力,因其自身的設計初衷(安全)使得性能不高,實際使用時某些場景已經滿足了一定的安全,從而造成算力的浪費。
最近因truechain混合共識的名頭開始了解這一新的公鏈,確實有了一些不一樣的感覺。
下面來簡單對比下:
1、安全性。上面也已提到,POW共識因為是時間爭先的原則,節點的惡意操作基本能夠被發現,而PBFT共識,則需要保證不超過⅓的節點作惡,其安全性不能被保證,尤其是在網路不穩定的時候。而混合共識,則取兩者之長,避二者之短,「保留 PBFT 快速高效達成共識的特性不變,將 PBFT 節點的選舉、監督權交給 PoW 節點,同
時快速的驗證 PBFT 給出的交易記錄集合,從而保證了整個網路的安全性。」
而我在最初設想的混合共識,僅僅是根據實際的場景需要,選用不同的共識機制,顯然,truechain想的更遠。
2、挖礦與激勵。這與共識是相輔相成的,水果鏈的原理還沒有完全看明白,但是與我簡單理解來說,就是將每次鏈上的交易行為,增加時間屬性,並行,分片計算與驗證交易,減少串列挖礦造成的時間損耗。(個人理解,如有不對的地方還請指出)
3、存儲。鑒於現在公鏈上劇增的歷史交易數據,truechain引入IPFS分布式網路存儲,解決全節點需要存儲全部數據的痛點,有效利用節點的存儲能力,並能夠帶動普通用戶獲取激勵的熱情,這也是我認為相對區塊鏈2.0最有效的改進。(當然,目前的大多數公鏈應該都會意識到這一點)
4、智能合約。合約所能兼容的語言更加豐富,降低開發門檻,這也許會帶給區塊鏈一個契機,為實際場景增加更多的選擇。
總結,其實,在讀了truechain的白皮書黃皮書之後,給我的印象是,它是Ethereum+Hyperledger Fabric結合的產物,它有fabric的許可權許可(Daily委員會),也有Ethereum的無限可接入的特點。
至於究竟怎樣,還是要上手操作一番才知道~
附框架圖(大家可以感受一下)
❷ V神的遺憾
DavidHoffman.eth :你如何定義元宇宙?
V 神: 據我所知,人們用它來指代互聯網+超級沉浸式虛擬現實,或者互聯網+共享狀態 (這樣事物就可以在平台之間移動)。
santi.eth :你如何想像以太坊維持一個普遍的基本收入機制,有助於為每個人創造公平的競爭環境?
V 神: PoH 已經這么做了! 挑戰在於,UBI 代幣需要「匯」,而不僅僅是發行。歸根結底,它歸結為與公共產品融資同樣的問題:我們需要超越個人捐贈,通過機制實現持久承諾。
在後一種情況下,以太坊當然是令人驚訝的中心部分。
三箭資本 CEO Zhu Su:對於 ETH/Doge 合作有什麼好的想法,你對 Doge 這個項目哪些方面感興趣?
V 神: 就我個人而言,我希望 Doge 能盡快切換到 PoS,或許使用以太坊代碼。我也希望他們不要取消 50 億/年的 PoW 發行,而是將其放入某種為全球公共事務提供資金的 DAO 中。這將會很適合 Doge 的精神。
以太坊核心開發者、EIP-1559 聯合作者 eric.eth:我知道 eth1 主節點的位置,但合並後,您是否打算將 eth2 主節點保留在同一位置?如果沒有,你能透露它的位置嗎?
V 神: 是的,有一個計劃是將主節點從 Moria 礦區轉移到 Cirith Ungol,但不幸的是,這個計劃被推遲了,因為 Moria 仍然有 14 天的隔離期。
Taylor Monahan:有什麼事情是你曾經無比自信的,結果卻發現你大錯特錯了?
V 神:「 以太坊將在 1-2 年內轉向 PoS」。
Mo Dong:隨著區塊鏈越來越依賴於中心化控制資產 (如 USDC),將分叉作為最後手段的治理在經濟上變得不可能。這是好還是壞?
V 神: 博弈論看起來越來越不像是和平分裂,而更像是相互毀滅。我想說,這是一個很好的理由,L1 會隨著時間的推移變得更加僵化,L2 也會隨著時間的推移出現更積極的治理。
MyCrypto 創始人兼首席執行官 Taylor Monahan:以太坊哪個應用最讓你吃驚?
V 神: NFT。
Michelle Rempel Garner:政府在保護加密貨幣不受操縱交易行為 (例如社交媒體炒作)?
V 神: 我認為,最好的監管策略需要避免「你必須獲得一個高質量的執照才能參與」的機制,而是在更大的規模中提出更多的要求(我認為現有的社交媒體 KOL 監管制度好像已經這么做了吧?)
另外,如果要在加密領域更難存在和加密領域更難獲得「主流」用戶之間進行權衡,我寧願選擇後者而不是前者,至少在中短期內。
Ian Miers:你認為所有的國家都會擁抱私人電子支付嗎?如果他們不接受的話,我們該怎麼辦?
V 神: 沒有官方「擁抱」torrent 網路,但它們卻依然蓬勃發展。官方們在制裁 torrent 方面付出的努力遠遠少於他們所能做的,部分是因為 torrent 網路還是具有很大的合法性。我認為處於這樣一種灰色地帶是很容易出現的事情。
作家 Bruno Maçães:什麼是加密的本質?一方面,它關於確定的真理。另一方面,它似乎是虛擬的,與物質現實脫節。是無中生有的創造。那麼...... 它是依賴於真理和現實的形而上學還是超越它們?
V 神: 我認為 Lootproject 的哲學是對的:幾乎任何人創造的任何東西都是「存在」的,重要的是其他人在它之上建立的東西有多大范圍、能達到什麼樣的程度。
Osmosis 聯合創始人 Sunny Aggarwal:你在以太坊旅程中最大的遺憾(非技術性的)是什麼?
V 神: 「8 位聯合創始人」的事情,我選擇了他們的時候過於急迫和一視同仁了。
Ava Labs 創始人 Emin Gün Sirer:你從以太坊經歷中學到最難的一課是什麼?
V 神: 在小團體中的人們比我想的更難緊密協調。你沒辦法讓大家圍坐成一圈,然後審視著彼此與生俱來的善良這樣去相處,更不要說還是在面臨著巨大激勵沖突的同時了。
以太坊共有 8 位聯合創始人,分別是 Vitalik Buterin、Mihai Alisie、Anthony Di Iorio、Amir Chetrit、Charles Hoskinson、Gavin Wood、Jeffrey Wilcke、Joseph Lubin,但是目前只剩 Vitalik 還在直接為以太坊工作。導致聯合創始人之間出現裂痕的主要原因是關於以太坊應該成為一家營利性公司還是保持非營利的一次激烈爭吵。當時以太坊很接近成為一家公司,僅剩下最關鍵的文件沒有簽署。這次事件直接導致 Charles Hoskinson 被逐出聯合創始人小組,後來他轉而支持硬分叉產生的以太坊經典,再後來發布了「以太坊殺手」Cardano。
2014年6月7日,在八位聯合創始人的見證下,以太坊的構想在瑞士樹林中被稱為「太空飛船」的出租屋中誕生。如今,8位聯合創始人構想中的這個區塊鏈平台市值,已經高達4000億美元。
今天,八位聯合創始人中,或許只有一位還常被人們冠以「以太坊創始人」的標簽,而另外幾人的名字都不為人所知,而這也是本文將要分享的關於他們的故事。
Vitalik Buterin
以太坊最早是來自於19歲的俄羅斯加拿大計算機天才和比特幣專欄作家——Vitalik Buterin於2013年11月的構想。在 探索 新興的加密行業三年後,Buterin完成了白皮書,指出了比特幣系統的局限性,並提出了一個新平台,使任何可以想像到的去中心化、抗審查應用程序成為可能。
Buterin的神童形象對以太坊的推廣起到了非常大的幫助,同時他對以太坊的技術貢獻也是毋庸置疑的。
近年來,他試圖退居二線,專注於以太坊2.0,也是唯一仍在從事以太坊相關工作的聯合創始人。
Mihai Alisie
Mihai Alisie學的是控制論經濟學專業,在參與以太坊之前,曾與Vitalik Buterin一起為比特幣雜志工作。2011年Alisie與Buterin取得了聯系,他們決定成立比特幣雜志。
Alisie幫助建立了以太坊在瑞士的基地,合並了最初的初創公司,為這家剛起步的加密公司開設了一個銀行帳戶(這不是一個容易的過程),並就預售活動至關重要的法律框架與律師和瑞士官員打交道。
Alisie一直擔任以太坊基金會的副主席,直到2015年底,他將注意力轉向以太坊的社交框架Akasha。
Anthony Di Iorio
Anthony Di Iorio與Buterin一樣,來自多倫多。他曾涉足營銷和風險投資,在地熱鑽探業務上投資超過100萬英鎊。2012年11月,他組織了一次比特幣聚會,並在現場上認識了Buterin。在以太坊確立了非盈利的運營模式後,Di Iorio退居二線。在以太坊之後,Di Iorio短暫地擔任了多倫多證券交易所的首席數字官,但隨後離開了Decentral——Jaxx數字錢包的開發公司,該錢包於2018年5月首次推出。同年,Di Iorio入選《福布斯》雜志排名前20位的加密貨幣最富有人士,估計凈資產為7.5億至10億美元。
Amir Chetrit
2013年9月在阿姆斯特丹舉行的比特幣活動上,Buterin遇到了Amir Chetrit。後者在2008年以前選擇了退學,然後涉足房地產,也在當時開始對傳統金融體系產生懷疑。後來他開始涉足比特幣,在遇到Buterin時,他正在與以色列初創公司Colored Coins合作,該項目旨在管理作為比特幣網路頂部代幣的現實資產。Buterin在提出以太坊之前,也曾參與過該項目。2013年12月,Chetrit受Buterin邀請加入組織。
在2014年6月的聯合創始人會議上,Chetrit因缺乏對以太坊的投入而受到以太坊開發人員和其他聯合創始人的抨擊,並選擇辭職。
Charles Hoskinson
出生於夏威夷的Charles Hoskinson本來想成為一名數學家,但後來卻對比特幣越來越感興趣。在被Anthony Di Iorio介紹給以太坊和巴特林時,已經有過為早期版本的去中心化交易所籌集資金的經驗。
2013年12月Hoskinson被任命為首席執行官,在建立瑞士基金會及其法律框架方面發揮領導作用。後來以太坊迎來硬分叉,Hoskinson選擇支持以太坊經典。與此同時,他推出了Cardano,目前Cardano的市值已躍升為第六大加密貨幣。
Gavin Wood
英國計算機程序員Gavin Wood是被比特幣佈道者Amir Taaki和Johnny Bitcoin帶入加密領域的。他認識了Buterin後,提出了用C++編程語言編寫一個以太坊的想法。2014年4月,他發布了以太坊黃皮書,隨後又發布了以太坊的本機編程語言Solidity。
在以太坊之後,Gavin Wood與Jutta Steiner合夥創立Parity公司,從事以太坊代碼的開發。但是現在,他更專注於Web3 Foundation及其互操作性區塊鏈項目Polkadot(以太坊的競爭對手)。
Jeffrey Wilcke
計算機程序員Jeffrey Wilcke第一次聽說以太坊時,正在荷蘭進行Mastercoin的工作。2014年初,他與Gavin Wood一起加入了創始人團隊。
在Wood開始使用C++編寫以太坊的同一時間,Wilcke也開始了他的開發工作——使用Go語言來編寫以太坊,後來該項目更名為Go Ethereum,簡稱為「Geth」。
在經歷了以太坊硬分叉、一系列黑客事件,以及兒子出生後,Wilcke將Geth的監督權交給了他的得力助手Peter Szilagyi。現在,他與哥哥Joey一起經營著一間 游戲 開發工作室Grid Games,並開始出售一些ETH以資助Grid Games招募開發人員。
Joseph Lubin
Joseph Lubin是八位創始人中經驗最豐富的一位,1987年Lubin從普林斯頓大學畢業,獲得了電子工程和計算機科學的學位。
畢業後,Lubin從事過軟體工程、音樂製作、商業和金融領域的多元化職業。後來,Lubin對加密貨幣產生了興趣,並通過加拿大比特幣聯盟與加拿大同胞Di Iorio取得了聯系。
後來,他被介紹給Buterin,並被邀請加入聯合創始人小組。Di Iorio和Lubin的財力雄厚,使剛起步的以太坊得以生存。
當決定使以太坊成為非盈利組織時,Lubin已經在計劃一家盈利性公司來構建平台的應用程序層。
他創立的公司Consensys已成為其他區塊鏈初創公司的孵化器,在招募有影響力的以太坊合作夥伴方面也發揮了關鍵作用。
❸ 波卡幣為什麼這么火幣圈新寵
說到含著金鑰匙出生的項目,波卡一定榜上有名。其創始人是區塊鏈領域的專家。他就是以太坊的核心開發者,《以太坊黃皮書》的作者,以太坊前CTO——Gavin Wood博士。
要說V神是以太坊概念的發起者,Gavin Wood 才是實現以太坊的人,可謂是以太坊的開山鼻祖。後來他意識到以太坊本身有其缺陷,無法實現他的web3.0願景,無法推動重建。因此,他從以太坊社區走出來,創立了一個新的區塊鏈項目——波卡。所以很多人認為波卡卡是以太坊的挑戰者。
除了創始人,波卡團隊也是一大亮點。波卡背後的Web3基金會委託5個團隊和100多名開發者共同打造波卡。除了技術團隊,還有專門的團隊負責社區與成長、商業合作、教育培訓、基金分配等。今年7月,波卡還宣布,領導團隊增加了三名新高管,其中許多人曾在微軟工作過。所以可以說波卡是含著金鑰匙出生的。
什麼是波卡?波卡幣也叫點幣,英文全稱是Polkadot。它是Web3.0和新公鏈熱潮的頂點,被稱為未來潛力最大的公鏈。
DOT於2019年5月發行。到目前為止,它已經在103個交易所上市,流通市值為101.51億美元。長期處於幣圈前十的貨幣,現在已經超過dogecoin,排名第八。
波卡幣為什麼能大火?
1.創始領導團隊很牛逼。就像剛才分析的那樣,波卡的領導團隊來自以太坊社區,項目開發團隊很華麗,由30名頂級開發人員組成,包括系統編程、密碼學和分布式系統的各類專家。技術和運營領導團隊分工明確,都是加密貨幣行業的佼佼者,所以一下子就借著Web3.0的東風發展起來了。
2.技術過硬。波卡是一個去中心化的互聯網,用戶擁有完全的控制權。它所構想的互聯網是每個人的身份和數據都由自己掌控,不受任何一個中心化組織的影響。波卡旨在連接私有鏈、聯盟鏈、公有鏈、開放網路、預言機和尚未被創造的未來技術。
3.波卡可以鏈接多個區塊鏈。卡在結構里,是一個可以無限擴展的項目。波卡的結構核心是有一個中繼鏈,然後通過插槽連接多個並行鏈和中轉橋(中轉橋可以鏈接來自波卡的其他具有不同共識機制的鏈,比如比特幣和以太坊)。但是一個中繼鏈只能鏈接100個插槽,但是其中一個插槽可以鏈接另一個並行的中繼鏈,這個新的中繼鏈可以鏈接100個插槽,所以可以實現無限的可擴展性,類似於它可以有多個分叉。
4.波卡發展的時機很合適。PokCard是基於Web3.0方向開發的,作為共識引擎,PokCard將連接其他面向Web3.0的項目,充當底層連接器。例如,作為一個去中心化和加密的信息發布系統,著名的分布式存儲項目IPFS也將與PokCard結合。可以說,波卡符合Web3.0的趨勢,符合時代的發展趨勢。
5.波卡有一個可行的資金來源。波卡設計了一套精緻的機制,可以把生態建設的資金留在一起。這個機制就是財政部。國庫是一個DOT資金池,通過它來提高波卡上的交易成本、懲罰和收益,而這三個部門的資金來源都被設計到波卡的經濟模型中,這意味著只要波卡保持運行,國庫就會有一個恆定的資金來源。同時,波卡的團隊也可以去中心化,逐步走向去中心化的治理層面。
❹ 以太坊源碼分析--p2p節點發現
節點發現功能主要涉及 Server Table udp 這幾個數據結構,它們有獨自的事件響應循環,節點發現功能便是它們互相協作完成的。其中,每個以太坊客戶端啟動後都會在本地運行一個 Server ,並將網路拓撲中相鄰的節點視為 Node ,而 Table 是 Node 的容器, udp 則是負責維持底層的連接。下面重點描述它們中重要的欄位和事件循環處理的關鍵部分。
PrivateKey - 本節點的私鑰,用於與其他節點建立時的握手協商
Protocols - 支持的所有上層協議
StaticNodes - 預設的靜態 Peer ,節點啟動時會首先去向它們發起連接,建立鄰居關系
newTransport - 下層傳輸層實現,定義握手過程中的數據加密解密方式,默認的傳輸層實現是用 newRLPX() 創建的 rlpx ,這不是本文的重點
ntab - 典型實現是 Table ,所有 peer 以 Node 的形式存放在 Table
ourHandshake - 與其他節點建立連接時的握手信息,包含本地節點的版本號以及支持的上層協議
addpeer - 連接握手完成後,連接過程通過這個通道通知 Server
Server 的監聽循環,啟動底層監聽socket,當收到連接請求時,Accept後調用 setupConn() 開始連接建立過程
Server的主要事件處理和功能實現循環
Node 唯一表示網路上的一個節點
IP - IP地址
UDP/TCP - 連接使用的UDP/TCP埠號
ID - 以太坊網路中唯一標識一個節點,本質上是一個橢圓曲線公鑰(PublicKey),與 Server 的 PrivateKey 對應。一個節點的IP地址不一定是固定的,但ID是唯一的。
sha - 用於節點間的距離計算
Table 主要用來管理與本節點與其他節點的連接的建立更新刪除
bucket - 所有 peer 按與本節點的距離遠近放在不同的桶(bucket)中,詳見之後的 節點維護
refreshReq - 更新 Table 請求通道
Table 的主要事件循環,主要負責控制 refresh 和 revalidate 過程。
refresh.C - 定時(30s)啟動Peer刷新過程的定時器
refreshReq - 接收其他線程投遞到 Table 的 刷新Peer連接 的通知,當收到該通知時啟動更新,詳見之後的 更新鄰居關系
revalidate.C - 定時重新檢查以連接節點的有效性的定時器,詳見之後的 探活檢測
udp 負責節點間通信的底層消息控制,是 Table 運行的 Kademlia 協議的底層組件
conn - 底層監聽埠的連接
addpending - udp 用來接收 pending 的channel。使用場景為:當我們向其他節點發送數據包後(packet)後可能會期待收到它的回復,pending用來記錄一次這種還沒有到來的回復。舉個例子,當我們發送ping包時,總是期待對方回復pong包。這時就可以將構造一個pending結構,其中包含期待接收的pong包的信息以及對應的callback函數,將這個pengding投遞到udp的這個channel。 udp 在收到匹配的pong後,執行預設的callback。
gotreply - udp 用來接收其他節點回復的通道,配合上面的addpending,收到回復後,遍歷已有的pending鏈表,看是否有匹配的pending。
Table - 和 Server 中的ntab是同一個 Table
udp 的處理循環,負責控制消息的向上遞交和收發控制
udp 的底層接受數據包循環,負責接收其他節點的 packet
以太坊使用 Kademlia 分布式路由存儲協議來進行網路拓撲維護,了解該協議建議先閱讀 易懂分布式 。更權威的資料可以查看 wiki 。總的來說該協議:
源碼中由 Table 結構保存所有 bucket , bucket 結構如下
節點可以在 entries 和 replacements 互相轉化,一個 entries 節點如果 Validate 失敗,那麼它會被原本將一個原本在 replacements 數組的節點替換。
有效性檢測就是利用 ping 消息進行探活操作。 Table.loop() 啟動了一個定時器(0~10s),定期隨機選擇一個bucket,向其 entries 中末尾的節點發送 ping 消息,如果對方回應了 pong ,則探活成功。
Table.loop() 會定期(定時器超時)或不定期(收到refreshReq)地進行更新鄰居關系(發現新鄰居),兩者都調用 doRefresh() 方法,該方法對在網路上查找離自身和三個隨機節點最近的若干個節點。
Table 的 lookup() 方法用來實現節點查找目標節點,它的實現就是 Kademlia 協議,通過節點間的接力,一步一步接近目標。
當一個節點啟動後,它會首先向配置的靜態節點發起連接,發起連接的過程稱為 Dial ,源碼中通過創建 dialTask 跟蹤這個過程
dialTask表示一次向其他節點主動發起連接的任務
在 Server 啟動時,會調用 newDialState() 根據預配置的 StaticNodes 初始化一批 dialTask , 並在 Server.run() 方法中,啟動這些這些任務。
Dial 過程需要知道目標節點( dest )的IP地址,如果不知道的話,就要先使用 recolve() 解析出目標的IP地址,怎麼解析?就是先要用藉助 Kademlia 協議在網路中查找目標節點。
當得到目標節點的IP後,下一步便是建立連接,這是通過 dialTask.dial() 建立連接
連接建立的握手過程分為兩個階段,在在 SetupConn() 中實現
第一階段為 ECDH密鑰建立 :
第二階段為協議握手,互相交換支持的上層協議
如果兩次握手都通過,dialTask將向 Server 的 addpeer 通道發送 peer 的信息
❺ 以太幣是什麼
以太坊Ethereum是一個區塊鏈。它與比特幣相比特點是可以增加智能合約,圖靈完備,網路速度更快。Etherem上有很多區中心化的區塊鏈產品,比如DigixDAO,黃金物聯網等等。
❻ 以太坊GasLimit的計算方法
以太坊黃皮書上說的gasLimit的計算方法:
gasLimit = Gtransaction + Gtxdatanonzero × dataByteLength
需要注意的是這只是靜態的gas消耗,實際gas消耗還需要加上合約執行的開銷。
計算 IntrinsicGas的源碼位置 core/state_transition.go
相關源碼位置:internal/ethapi/api.go
EstimateGas 採用二分查找法獲取要評估交易的gas值。二分查找的下限是 param.TxGas , 如果 args 參數指定 Gas 大於 param.Gas ,那麼二分查找的上限就是 args.Gas ,否則以當前pending塊的block gas limit(後面簡稱BGL)作為二分查找的上限。 doCall 函數模擬智能合約的執行,經過多次嘗試找到智能合約能夠成功運行的最佳gas值。
由於二分查找的上限和BGL有關,而BGL和不是固定不變的,因此每次gas評估的結果不一定都是相同的,可能每個區塊周期就會變動一次。
在實際進行gas評估的時候,可能會出現類似下面的錯誤
該錯誤出現的最可能是合約執行中出錯。
How do you calculate gas limit for transaction with data in Ethereum?
❼ 走進以太坊網路
目錄
術語「以太坊節點」是指以某種方式與以太坊網路交互的程序。從簡單的手機錢包應用程序到存儲整個區塊鏈副本的計算機,任何設備均可扮演以太坊節點。
所有節點都以某種方式充當通信點,但以太坊網路中的節點分為多種類型。
與比特幣不同,以太坊找不到任何程序作為參考實施方案。在比特幣生態系統中, 比特幣核心 是主要節點軟體,以太坊黃皮書則提出了一系列獨立(但兼容)的程序。目前最流行的是Geth和Parity。
若要以允許獨立驗證區塊鏈數據的方式連接以太坊網路,則應使用之前提到的軟體運行全節點。
該軟體將從其他節點下載區塊,並驗證其所含交易的正確性。軟體還將運行調用的所有智能合約,確保接收的信息與其他節點相同。如果一切按計劃運行,我們可以認為所有節點設備均存儲相同的區塊鏈副本。
全節點對於以太坊的運行至關重要。如果沒有遍布全球的眾多節點,網路將喪失其抗審查性與去中心化特性。
通過運行全節點,您可以直接為網路的 健康 和安全發展貢獻一份力量。然而,全節點通常需要使用獨立的機器完成運行和維護。對於無法(或單純不願)運行全節點的用戶,輕節點是更好的選擇。
顧名思義,輕節點均為輕量級設備,可顯著降低資源和空間佔用率。手機或筆記本電腦等攜帶型設備均可作為輕節點。然而,降低開銷也要付出代價:輕節點無法完全實現自給自足。它們無法與整條區塊鏈同步,需要全節點提供相關信息。
輕節點備受商戶、服務供應商和用戶的青睞。在不必使用全節點並且運行成本過高的情況下,它們廣泛應用於支收付款。
挖礦節點既可以是全節點客戶端,也可以是輕節點客戶端。「挖礦節點」這個術語的使用方式與比特幣生態系統不同,但依然應用於識別參與者。
如需參與以太坊挖礦,必須使用一些附加硬體。最常見的做法是構建 礦機 。用戶通過礦機將多個GPU(圖形處理器)連接起來,高速計算哈希數據。
礦工可以選擇兩種挖礦方案:單獨挖礦或加入礦池。 單獨挖礦 表示礦工獨自創建區塊。如果成功,則獨享挖礦獎勵。如果加入 礦池 ,眾多礦工的哈希算力會結合起來。出塊速度得以提升,但挖礦獎勵將由眾多礦工共享。
區塊鏈最重要的特性之一就是「開放訪問」。這表明任何人均可運行以太坊節點,並通過驗證交易和區塊強化網路。
與比特幣相似,許多企業都提供即插即用的以太坊節點。如果只想啟動並運行單一節點,這種設備無疑是最佳選擇,缺點是必須為便捷性額外付費。
如前文所述,以太坊中存在眾多不同類型的節點軟體實施方案,例如Geth和Parity。若要運行個人節點,必須掌握所選實施方案的安裝流程。
除非運行名為 歸檔節點 的特殊節點,否則消費級筆記本電腦足以支持以太坊全節點正常運行。不過,最好不要使用日常工作設備,因為節點會嚴重拖慢運行速度。
運行個人節點時,建議設備始終在線。倘若節點離線,再次聯網時可能耗費大量的時間進行同步。因此,最好選擇造價低廉並且易於維護的設備。您甚至可以通過Raspberry Pi運行輕節點。
隨著網路即將過渡到權益證明機制,以太坊挖礦不再是最安全的長期投資方式。過渡成功後,以太坊礦工只能將挖礦設備轉入其他網路或直接變賣。
鑒於過渡尚未完成,參與以太坊挖礦仍需使用特殊硬體(例如GPU或ASIC)。若要獲得可觀收益,則必須定製礦機並尋找電價低廉的礦場。此外,還需創建以太坊錢包並配置相應的挖礦軟體。這一切都會耗費大量的時間和資金。在參與挖礦前,請認真考量自己能否應對各種挑戰。(國內嚴禁挖礦,切勿以身試法)
ProgPow代表 程序化工作量證明 。這是以太坊挖礦演算法Ethash的擴展方案,旨在提升GPU的競爭力,使其超過ASIC。
在比特幣和以太坊社區,抗ASIC多年來一直是飽受爭議的話題。在比特幣網路中,ASIC已經成為主要的挖礦力量。
在以太坊中,ASIC並不是主流,相當一部分礦工仍然使用GPU。然而,隨著越來越多的公司將以太坊ASIC礦機引入市場,這種情況很快就會改變。然而,ASIC到底存在什麼問題呢?
一方面,ASIC明顯削弱網路的去中心化。如果GPU礦工無法盈利,不得不停止挖礦,哈希率最終就會集中在少數礦工手中。此外,ASIC晶元的開發成本相當昂貴,坐擁開發能力與資源的公司屈指可數。這種現狀有可能導致以太坊挖礦產業集中在少數公司手中,形成一定程度的行業壟斷。
自2018年以來,ProgPow的集成一直飽受爭議。有些人認為,它有益於以太坊生態系統的 健康 發展。另一些人則持反對態度,認為它可能導致硬分叉。隨著權益證明機制的到來,ProgPoW能否應用於網路仍然有待觀察。
以太坊與比特幣是一樣,均為開源平台。所有人都可以參與協議開發,或基於協議構建應用程序。事實上,以太坊也是區塊鏈領域目前最大的開發者社區。
Andreas Antonopoulos和Gavin Wood出品的 Mastering Ethereum ,以及Ethereum.org推出的 開發者資源 等都是新晉開發者理想的入門之選。
智能合約的概念於20世紀90年代首次提出。其在區塊鏈中的應用帶來了一系列全新挑戰。2014年由Gavin Wood提出的Solidity已經成為開發以太坊智能合約的主要編程語言,其語法與Java、JavaScript以及C++類似。
從本質上講,使用Solidity語言,開發者可以編寫在分解後可由以太坊虛擬機(EVM)解析的指令。您可以通過Solidity GitHub詳細了解其工作原理。
其實,Solidity語言並非以太坊開發者的唯一選擇。Vyper也是一種熱門的開發語言,其語法更接近Python。
❽ 以太坊event log查詢與解析
從 ethereum json-rpc文檔 的文檔中找到一個同時指定多個事件以 OR 或者 AND 查詢的方法.以下是查詢 Approval 或 Transfer 事件的方法:
topics 欄位中指定查詢條件的語法參考上面鏈接。
通過 getTransactionReceipt 在ropsten測試網上查詢到交易號為 的交易詳情
這個交易從 "from": "" 發送到合約地址 "to": "" .這個合約為ERC20代幣合約.從 topics 的第一個元素可以看出合約中產生了 Transfer 事件(topics第一個元素一定是事件的keccak哈希). topics 的第二個欄位是轉出代幣的地址,第三個欄位是接收者地址.ERC20代幣 Transfer 事件的簽名為
我們注意到 Transfer 事件的第一個和第二個參數被標記為 indexed , 因此他們的值被放在 topics array 中. 由於tokens參數沒有標記為 indexed , 所以他的值被放在 data 欄位. 如果事件中有多個欄位未標記為 indexed , 那麼他們的值都會被記錄在 data 欄位中。