Ⅰ 以太坊開發(2):在以太坊私有鏈上的基本操作
在上一講 如何使用geth搭建以太坊私有鏈 完成了私有鏈的搭建,下面介紹在私有鏈上的基本操作。
啟動私有鏈後在命令行輸入:
執行完之後可以查看到生成的賬戶地址為
查詢賬戶余額:
剛剛創建的私有鏈賬戶都是沒有餘額的,需要通過挖礦才會產生eth,下面介紹如何在私有鏈上挖礦。
在geth環境下執行:
這時候查看日誌geth.log可以看到以太坊私有鏈有個啟動的百分比,到100就正式啟動了:
挖礦開始:
這時候有個疑問,挖礦挖到的eth到哪了,其實默認到了eth.account[0],就是第一個賬戶上:
如何修改挖礦所得的賬戶:
命令如下:
下面開始進行轉賬:
這時候出現報錯,原因是轉賬的賬戶沒有解鎖,需要輸入密碼解鎖轉賬的賬戶才能完成轉賬操作:
Ⅱ 怎麼接以太坊公鏈
建立連接以接儒以太坊公鏈。
一、1、以太坊客戶端下載,注意:需翻牆,下載版本為1.8.23-stable,否則可能出現與以太坊錢包客戶端存在不匹配問題。
2、以太坊錢包客戶端下載。
3、安裝以太坊客戶端。
二、私有鏈創建:創建創世區塊。
三、安裝並啟動以太坊錢包客戶端。
Ⅲ 以太坊多節點私有鏈部署
假設兩台電腦A和B
要求:
1、兩台電腦要在一個網路中,能ping通
2、兩個節點使用相同的創世區塊文件
3、禁用ipc;同時使用參數--nodiscover
4、networkid要相同,埠號可以不同
1.4 搭建私有鏈
1.4.1 創建目錄和genesis.json文件
創建私有鏈根目錄./testnet
創建數據存儲目錄./testnet/data0
創建創世區塊配置文件./testnet/genesis.json
1.4.2 初始化操作
cd ./eth_test
geth --datadir data0 init genesis.json
1.4.3 啟動私有節點
1.4.4 創建賬號
personal.newAccount()
1.4.5 查看賬號
eth.accounts
1.4.6 查看賬號余額
eth.getBalance(eth.accounts[0])
1.4.7 啟動&停止挖礦
啟動挖礦:
miner.start(1)
其中 start 的參數表示挖礦使用的線程數。第一次啟動挖礦會先生成挖礦所需的 DAG 文件,這個過程有點慢,等進度達到 100% 後,就會開始挖礦,此時屏幕會被挖礦信息刷屏。
停止挖礦,在 console 中輸入:
miner.stop()
挖到一個區塊會獎勵5個以太幣,挖礦所得的獎勵會進入礦工的賬戶,這個賬戶叫做 coinbase,默認情況下 coinbase 是本地賬戶中的第一個賬戶,可以通過 miner.setEtherbase() 將其他賬戶設置成 coinbase。
1.4.8 轉賬
目前,賬戶 0 已經挖到了 3 個塊的獎勵,賬戶 1 的余額還是0:
我們要從賬戶 0 向賬戶 1 轉賬,所以要先解鎖賬戶 0,才能發起交易:
發送交易,賬戶 0 -> 賬戶 1:
需要輸入密碼 123456
此時如果沒有挖礦,用 txpool.status 命令可以看到本地交易池中有一個待確認的交易,可以使用 eth.getBlock("pending", true).transactions 查看當前待確認交易。
使用 miner.start() 命令開始挖礦:
miner.start(1);admin.sleepBlocks(1);miner.stop();
新區塊挖出後,挖礦結束,查看賬戶 1 的余額,已經收到了賬戶 0 的以太幣:
web3.fromWei(eth.getBalance(eth.accounts[1]),'ether')
用同樣的genesis.json初始化操作
cd ./eth_test
geth --datadir data1 init genesis.json
啟動私有節點一,修改 rpcport 和port
可以通過 admin.addPeer() 方法連接到其他節點,兩個節點要要指定相同的 chainID。
假設有兩個節點:節點一和節點二,chainID 都是 1024,通過下面的步驟就可以從節點二連接到節點一。
首先要知道節點一的 enode 信息,在節點一的 JavaScript console 中執行下面的命令查看 enode 信息:
admin.nodeInfo.enode
" enode://@[::]:30303 "
然後在節點二的 JavaScript console 中執行 admin.addPeer(),就可以連接到節點一:
addPeer() 的參數就是節點一的 enode 信息,注意要把 enode 中的 [::] 替換成節點一的 IP 地址。連接成功後,節點一就會開始同步節點二的區塊,同步完成後,任意一個節點開始挖礦,另一個節點會自動同步區塊,向任意一個節點發送交易,另一個節點也會收到該筆交易。
通過 admin.peers 可以查看連接到的其他節點信息,通過 net.peerCount 可以查看已連接到的節點數量。
除了上面的方法,也可以在啟動節點的時候指定 --bootnodes 選項連接到其他節點。 bootnode 是一個輕量級的引導節點,方便聯盟鏈的搭建 下一節講 通過 bootnode 自動找到節點
參考: https://cloud.tencent.com/developer/article/1332424
Ⅳ 以太坊無法連接節點
把你的TCP/IP協議設置成自動獲取狀態試試,方法:右鍵網上鄰居-屬性- 右鍵"本地連接"屬性-雙擊"Internet 協議 TCP/IP"-改為自動獲取
IPX/SPX協議,IPX是NetWare最底層的協議,它只負責數據在網路中的移動,並不保證數據是否傳輸成功,也不提供糾錯服務。IPX在負責數據傳送時,如果接收節點在同一網段內,就直接按該節點的ID將數據傳給它;如果接收節點是遠程的(不在同一網段內,或位於不同的區域網中),數據將交給NetWare伺服器或路由器中的網路ID,繼續數據的下一步傳輸。SPX在整個協議中負責對所傳輸的數據進行無差錯處理,所以我們將IPX/SPX也叫做「Novell的協議集」。
Ⅳ Docker 搭建以太坊私有鏈
首先需要安裝 Docker,Docker 的安裝和使用可以參看阮一峰老師的 《Docker 入門教程》 。
Ethereum 官方是支持 docker 的,可以參看 官方文檔 。
centOS
其中 -v /home/linshan/works/block-chain/ethereum:/root 是把我們當前的 ethereum 目錄,掛到了docker 的 /root 下。
在 Windows 環境下使用 -v /home/linshan/works/block-chain/ethereum:/root 不能啟動容器,原因不明,所以在 Windows 下先不要使用目錄掛載。
各欄位具體用途參看 官方文檔 。
Windows
Windows 不必創建 start-ethereum.sh 文件, genesis.json 也可以在 Docker 容器啟動後創建。
centOS
Windows
運行成功後執行
進入 docker 容器命令行
因為 Windows 沒有掛載共享目錄,所以 root 目錄下沒有 genesis.json 文件,我們要在這裏手動創建 genesis.json 文件,內容要和 centOS 的一致。
data 用來存放區塊數據
geth 的參數參看 以太坊客戶端Geth命令用法-參數詳解
啟動私有節點後進入 geth 命令行執行:
輸出的內容就是節點信息,我們在手動連接節點是會用到,注意要把「0.0.0.0「換成你自己的IP,然後將這個信息發送給其他節點。手動連接節點有兩種方式:
當然不管使用哪種方法連接節點都要保證創世區塊文件 genesis.json 一致,還有在啟動時 networkid 也要一致。
至此以太坊私有鏈已搭建完畢。
geth命令
docker命令
Ⅵ macstudio壞了數據
Mac Studio 的性能感到滿意,但許多用戶在使用其以太坊埠時遇到了問題。 雖然大部分用戶可能更喜歡通過 Wi-Fi 連接到互聯網,但對於需要更快、更可靠的互聯網訪問的人們來說,硬連線以太坊電纜仍然是最受歡迎的選擇。
不幸的是,Apple 論壇上的一些用戶抱怨他們在 Mac Studio 上的 10G 以太坊埠無法正常工作。 該埠拒絕響應,並且全天多次發生。 雖然這對某些人來說似乎是一個小問題,但我們知道當你參加會議或做辦公室工作時會多麼令人沮喪。 雖然 Mac Studio 10G 以太坊不工作問題可能表明硬體損壞,但並非總是如此。 以太坊埠無法正常工作的原因可能有幾個罪魁禍首。無論 Mac Studio 20G 以太坊無法正常工作問題背後的原因是什麼,我們都會為你提供幫助。 在本故障排除指南中,我們提到了幾種解決方法,它們將有助於解決 Mac Studio 10G 以太坊最早無法工作的問題。
因此,毫不拖延地,讓我們直接深入研究它們。
檢查你的以太坊電纜
在我們開始查找 Mac Studio 中的故障之前,我們應該花點時間檢查一下以太坊電纜。 尋找任何損壞跡象,例如銷毀、割傷、電線扭曲等。 如果任何東西看起來很可疑,你可以抓住另一根以太坊電纜,看看問題是否已解決。
如果以太坊電纜狀況良好,你可以斷開電纜,然後嘗試連接電纜以建立正確的連接。 你也可以使用此以太坊電纜連接到其他計算機並查看以太坊電纜是否正常工作。
調整錯誤配置的設置
如果你沒有發現以太坊電纜有任何問題,你應該仔細檢查 Mac Studio 的網路設置。 你的 Mac 有一個內置設置,你需要在其中選擇以太坊選項而不是 Wi-Fi。 如果你選擇了不正確的選項,你將無法使用有線選項連接到互聯網,以免你嘗試了多少。 所以讓我們調整一下設置:
點擊 Mac 屏幕左上角的 Apple 圖標。
從下拉菜單中,選擇系統偏好設置選項。
在這里,從窗口中選擇網路選項。
現在你將在左側邊欄中看到所有網路服務。
在此處查找以太坊選項,然後選擇它。 如果在任何情況下都找不到它,請選擇添加選項。使用 Mac 終端重新啟動無響應的以太坊
如果即使使用正確的互聯網設置,以太坊連接也無法正常工作,那麼是時候嘗試一些高級方法了。 我們將重新啟動 Mac Studio 的有線網路介面,以消除干擾 Mac 使用以太坊功能的技術故障和隨機錯誤。 以下是如何開始:
在 Mac Studio 上調出 Finder 應用程序
轉到應用程序,然後選擇實用程序選項。
尋找終端選項並點擊它。此之後,在終端窗口中輸入以下命令並按回車鍵。
sudo ifconfig en0 關閉
系統可能會提示你輸入密碼。
執行上述命令後,鍵入下一條命令並按 Enter 鍵。
sudo ifconfig en0 up
注意:將 en0 替換為有線網路介面。
如果你不知道這一點,請轉到 Apple 菜單 > 關於本機 > 系統偏好設置。
在這里,從左側邊欄中選擇網路選項。
現在,以太坊名稱將出現在右側。
重啟數據機和 Mac Studio
如果重新啟動有線網路介面沒有任何好處,你應該嘗試重新啟動 Mac Studio 和數據機。 這對於建立新連接並使有線互聯網連接可用至關重要。 以這種方式重新啟動你的設備:
首先,關閉你的 Mac 工作室。
然後你需要關閉/拔下數據機。
現在等待至少 30 秒,然後再次成功打開數據機。
按住,直到所有指示燈都處於指示數據機已成功進入位置的位置。
在此之後,打開你的 Mac Studio。
現在連接以太坊電纜,看看你是否可以正常訪問互聯網。 如果沒有,請嘗試其他故障排除方法。
如何移除或安裝內存 – MacBook Pro
將以太坊重新添加到 Mac Studio
如果上述方法似乎都不適合你,那麼是時候嘗試另一種修復方法了。 我們將刪除你 Mac 工作室上的以太坊配置文件,然後重新配置它。 這有助於清除可能導致以太坊工作問題的隨機錯誤和錯誤配置的設置。
按照此處的步驟刪除並重新配置 Mac Studio 上的以太坊配置文件:
將以太坊插入 Mac Studio 的埠並打開路由器。
現在點擊屏幕左上角的 Apple 標志。
從下拉列表中選擇系統偏好設置。
接下來,從左側邊欄中選擇網路選項。
現在你將看到 Mac Studio 的所有網路服務列表。
在這里,選擇以太坊選項,然後按底部的減號按鈕。
最後,按應用按鈕確認更改。
現在訪問網路服務列表並選擇藍牙 PAN 選項。
Ⅶ 以太坊私有鏈如何更新版本
以太坊私有鏈更新版本的方法:
1、獲取以太坊私有鏈系統的當前版本對應的當前版本號;
2、基於所述當前版本號,確定所述以太坊私有鏈系統的升級版本的升級版本號;
3、將所述以太坊私有鏈系統升級為所述升級版本號對應的升級版本。
Ⅷ 以太坊私有鏈搭建(2)--修改挖礦難度
官放解釋就不多說了,Difficulty值越大,越難出區塊,意味著交易不容易確認,默認的機制是難度越來越大,對私有鏈一般是不可接受的,當然這個值也不是越小越好,這樣的話也會讓機器的很卡,所以這個值要根據項目自己確定。
創世區塊中的的難度能影響整體的挖礦速度,但是並不能改變難度上升這個趨勢,所以在自己的項目中,僅僅在創世區塊中指定難度是不夠的。
當前geth版本 1.7 unstable
源文件 consensus/ethash/consensus.go 行290
好了,這里也不多想怎麼實現了,我也看不懂,簡單改下返回難度為恆定值就會~~
將這個函數改為
重新make geth,試試看出塊難度是不是恆定了。
Ⅸ 搭建geth私有鏈和聯盟鏈網路
操作系統:linux或Mac OS
安裝geth執行以下命令:
linux:sudo apt-get install ethereum
Mac OS:brew install ethereum
直接創建兩個geth的工作目錄,用於之後的組建聯盟鏈的使用:
mkdir eth-private1
mkdir eth-private2
首先 cd eth-private1 進入節點1的工作目錄該目錄下執行下面命令
geth --datadir data --nodiscover console (data是之後geth節點的數據目錄,可自行修改)
使用geth自帶的工具 puppeth 用於生成創世區塊,過程如下:
puppeth
+-----------------------------------------------------------+
| Welcome to puppeth, your Ethereum private network manager |
| |
| This tool lets you create a new Ethereum network down to |
| the genesis block, bootnodes, miners and ethstats servers |
| without the hassle that it would normally entail. |
| |
| Puppeth uses SSH to dial in to remote servers, and builds |
| its network components out of Docker containers using the |
| docker-compose toolset. |
+-----------------------------------------------------------+
Please specify a network name to administer (no spaces, please)
輸入私鏈名稱後,會出現二級菜單,現在2:配置一個新的創世快
What would you like to do? (default = stats)
再次出現二級菜單,讓你選擇共識機制(這里採用poa共識)
Which consensus engine to use? (default = clique)
Ethash - proof-of-work(PoW) :工作量證明,通過算力達成共識 (以太坊就是使用這種方式)
Clique - proof-of-authority(PoA): 權威證明、通過預先設定的權威節點來負責達成共識 (不消耗算力,一般用於私有鏈測試開發)
如果選擇Pow的共識方法,直接輸入1,回車即可。
如果選擇PoA的共識方法,輸入2後會提示讓你選擇處快的間隔時間,一般測試開發使用可以設置相對的將處快時間設置較少5秒即可,然後會讓你選擇哪個賬戶來作為權威生成區塊(至少有一個,輸入剛才創建的賬戶,若只是單節點就輸入那個節點目錄生成的地址,若想組建聯盟鏈就填寫生成的兩個地址)
How many seconds should blocks take? (default = 15)
選擇好共識機制後會讓你指定給那些賬號初始化ether(至少有一個),輸入我們剛才創建的賬戶地址回車即可。
Which accounts should be pre-funded? (advisable at least one)
選擇輸入私有鏈的網路ID,任意數字即可(不能為1,1是公鏈),也可以不輸入會給定一個隨機數作為私有鏈的網路ID
Specify your chain/network ID if you want an explicit one (default = random)
選擇導出創世區塊配置文件
選擇導出創世區塊配置文件的保存路徑,可以保存到當前目錄,直接按回車即可
Which file to save the genesis into? (default = my-private-chain.json)
INFO [02-09|14:56:33] Exported existing genesis block
這樣就完成了創世區塊文件的配置了,直接退出puppeth即可。
輸入命令 geth --datadir data init private.json 其中data自己制定,private.json就是剛才生成的創世區塊
若出現如圖錯誤:
輸入命令:
geth --datadir data --syncmode full --port 2001 --networkid 1234 --rpc --rpcport "8545" --rpccorsdomain "*" --rpcaddr "0.0.0.0" --rpcapi "db,eth,net,web3,personal,admin,clique" --nodiscover console 進入控制台
--datadir data:節點的數據目錄
--syncmode full:塊同步的方式(若只是單節點可不填)
--port 2001: 網卡監聽埠
--networkid 1234:網路標識符
--rpc:開啟rpc服務
--rpcport "8545":rpc服務的埠
--rpccorsdomain "*":允許跨域請求的域名列表(逗號分隔)(瀏覽器強制)
--rpcaddr "0.0.0.0" :HTTP-RPC伺服器介面地址(默認值:「localhost」)
--rpcapi "db,eth,net,web3,personal,admin,clique":基於HTTP-RPC介面提供的API(私有鏈可以任意開發,公有鏈需要謹慎)
--nodiscover:不允許節點自動加入
若想搭建聯盟鏈,必須保證創世區塊一致,進入到剛才創建的eth-private2的目錄
將之前生成的創世區塊拷貝過來,初始化創世區塊,然後使用啟動命令啟動分別啟動兩個節點,進入控制台,使用 admin.nodeInfo 命令獲取節點的信息
總結:
兩個伺服器部署兩個節點是可以聯通的,但是只能使用兩個節點對應的地址進行挖礦,所以只能是兩個節點對應兩個地址進行挖礦,使用poa共識,當一個節點掛掉,挖礦停止,因為poa共識挖礦必須超過50%的節點進行錢增,現在只是兩個節點,掛掉一個節點挖礦就會停止等待另一個節點的確認,停掉的節點可以通過正常運作的節點信息重新連接到網路中。
問題:
同步塊有可能報錯情況:
1:Synchronisation failed "retrieved hash chain is invalid" 解決目前找到的方法是removedb 數據目錄 ,重新init創世區塊
2:內存溢出初步確認為開啟rpc服務造成的,有可能伺服器惡意被黑,暴力破解密碼,佔有內存,解決,將伺服器的ip設置一條防火牆
若存在問題可給本人留言或訪問本人的github: https://github.com/qi-shuo/geth-document 記錄了一些本人搭建使用的命令
Ⅹ 官宣!以太坊「合並」9月6日啟動,合並後以太坊會發生什麼
以太坊合並9月6日啟動,是加密行業最重要的事件,以太坊信標鏈社區顧問 Superphiz 合並將完成。以太坊研究員在以太坊丹佛會議上發表了題為“以太坊 POS 和我們的太陽能朋克的”的演講。難度炸彈的時機是無可挑剔的,相信丹尼的話是他不想推遲難度炸彈。合並分叉將在爆炸之前發生,以化解難度炸彈。