以太坊(1)--在CentOS 6.5上搭建以太坊私有鏈的步驟(圖文詳細)
我們在研究和使用以太坊的過程中,碰到了許多坑,走了許多的彎路。用以太坊作為關鍵詞去百度或者谷歌搜尋,雖然能夠搜到許多結果,但其實對於我們來說,這些結果存在2個問題:1,網上的這些文章互相拷貝,雖然看起來很多,但其實就那麼兩篇;2,一些文章裡介紹的步驟雖然看起來很合理,很順暢,但其實真正跑起來,還是存在一定困難的。本文將以最簡單、最正確的方式搭建以太坊私有鏈,一來,作為我們學習自己成果的記錄,二來,給後來人一些指引,避免像我們以前趟坑走彎路。本系列偏向於實戰,將以連載的形式來進行記錄,本次將介紹如何在CentOS6.5上搭建以太坊私有鏈。
先總體說一下步驟:
1.作業系統準備
2. golang安裝
3.下載以太坊
4. 安裝以太坊
5. 創世區塊檔案的準備
6. 創世區塊初始化
7. 以太坊啟動
下面以圖文的形式詳細介紹每一個步驟:
1. 作業系統準備
我們使用的作業系統是CentOS6.5,安裝之後需要系統能夠上網,因為後面的步驟需要聯網安裝以太坊所需的環境。系統安裝好之後,執行 cat /etc/redhat-release確認系統版本,以下是我們執行的結果:
[[email protected]_VM_10_100_142_62 ~]# cat /etc/redhat-release
CentOS release 6.5 (Final)
2. golang安裝
首先執行 rpm -ivh http://ftp.riken.jp/Linux/fedora/epel/6/i386/epel-release-6-8.noarch.rpm 安裝yum源。以下是我們執行結果的截圖:
注意:
(1).這個步驟需要聯網,這是在上一步我們強調系統需要能夠上網的原因
(2).注意安裝結果是否成功,如我們上面的截圖中第二個紅框所示
yum源安裝成功後就可以使用下面的命令安裝golang了:
yum install golang
下面是我們的安裝結果:
注意:
(1)中間有一步需要確認,輸入小寫的y,然後回車即可
(2)注意安裝結果是否成功
3. 下載以太坊原始碼
4. 安裝以太坊
將下載的zip格式的原始碼包解壓縮並進入解壓縮後的目錄。
我們的結果如下:
然後在go-ethereum-1.4.12目錄下執行 make命令開始進行編譯。
我們的結果如下:
編譯成功後,將在go-ethereum-1.4.12目錄下出現build/bin這樣的子目錄,並且在該子目錄下出現geth這樣的可執行檔案,如上圖所示。
這樣,我們的以太坊就安裝完成了。
5. 創世區塊檔案的準備
在go-ethereum-1.4.12/build/bin目錄下建立init.json的文字檔案,內容如下:
{
"nonce": "0×0000000000000042",
"mixhash": "0×0000000000000000000000000000000000000000000000000000000000000000",
"difficulty": "0×4000",
"alloc": {},
"coinbase": "0×0000000000000000000000000000000000000000",
"timestamp": "0×00",
"parentHash": "0×0000000000000000000000000000000000000000000000000000000000000000",
"extraData": "GenesisBlock",
"gasLimit": "0xffffffff"
}
我們的結果如下:
6. 創世區塊初始化
在go-ethereum-1.4.12/build/bin目錄下執行以下命令以完成創世區塊的建立:
./geth --datadir "/app/chain" init init.json
注意:上面命令中--datadir後面的 /app/chain可以任意指定,無需提前建立,但是一定要保證有足夠的磁碟空間。init.json是我們在上一步建立的檔案,注意檔名要一致。
執行完成後,將會出現類似以下資訊:
I0927 14:31:07.374864 ethdb/database.go:82] Alloted 16MB cache and 16 file handles to /app/chain/chaindata
I0927 14:31:07.402544 cmd/geth/main.go:299] successfully wrote genesis block and/or chain rule set: 244469eaad4c9c7a245fa4962a6ed7346e9925317f222b580e7f3113f9722657
我們的執行結果如下:
這樣,創世區塊就初始化完成了,下面將要進行最後一步,以太坊的啟動。
7. 以太坊啟動
仍然在go-ethereum-1.4.12/build/bin目錄下執行,執行的命令是:
./geth --rpc --rpccorsdomain "*" --datadir "/app/chain" --port "30303" --rpcapi "db,eth,net,web3" --networkid 100000 console
注意:上面命令中--datadir 後的"/app/chain"要跟我們上一步的--datadir 引數一致。
執行完此命令後將會出現類似以下資訊:
I0927 14:32:17.538013 ethdb/database.go:82] Alloted 128MB cache and 1024 file handles to /app/chain/chaindata
I0927 14:32:17.554665 ethdb/database.go:169] closed db:/app/chain/chaindata
I0927 14:32:17.554722 cmd/utils/flags.go:592] WARNING: No etherbase set and no accounts found as default
I0927 14:32:17.555722 ethdb/database.go:82] Alloted 128MB cache and 1024 file handles to /app/chain/chaindata
I0927 14:32:17.575639 eth/backend.go:621] upgrading db log bloom bins
I0927 14:32:17.575767 eth/backend.go:629] upgrade completed in 138.089µs
I0927 14:32:17.575802 ethdb/database.go:82] Alloted 16MB cache and 16 file handles to /app/chain/dapp
I0927 14:32:17.580530 eth/backend.go:172] Protocol Versions: [63 62], Network Id: 100000
I0927 14:32:17.580584 eth/backend.go:201] Blockchain DB Version: 3
I0927 14:32:17.581103 core/blockchain.go:206] Last header: #0 [244469ea…] TD=0
I0927 14:32:17.581122 core/blockchain.go:207] Last block: #0 [244469ea…] TD=0
I0927 14:32:17.581131 core/blockchain.go:208] Fast block: #0 [244469ea…] TD=0
I0927 14:32:17.582008 p2p/server.go:313] Starting Server
I0927 14:32:19.644094 p2p/discover/udp.go:217] Listening, enode://e1f793e06289097df035e55d68f7667658630b48c1e7fd70b5dee7445db5bec9d[email protected][::]:30303
I0927 14:32:19.650870 node/node.go:366] HTTP endpoint opened: http://localhost:8545
I0927 14:32:19.652471 p2p/server.go:556] Listening on [::]:30303
I0927 14:32:19.652892 node/node.go:296] IPC endpoint opened: /app/chain/geth.ipc
Welcome to the Geth JavaScript console!
一直到出現Welcome to the Geth JavaScript console! 句話,並自動進入geth的命令列則說明以太坊私有鏈安裝成功了。
注意:以上命令中 --datadir引數後面的"/app/chain"要和上一步保持一致。
我們的結果如下:
到目前為止,我們的私有鏈就搭建成功了。下一次,我們會介紹賬戶建立,挖礦,轉賬等操作。