日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

geth 转账_以太坊1 - 私有链部署、挖矿、转账

發布時間:2023/12/15 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 geth 转账_以太坊1 - 私有链部署、挖矿、转账 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

總結一下以太坊私有鏈搭建的過程,已經遇到的問題。

我們使用了LINUX,MAC OSX,WINDOWS三種平臺,運行go-ethereum。

一、go語言安裝

LINUX

命令行輸入sudo gedit ~/.bashrc

在打開的文件最后加上兩行代碼:

export GOPATH=/usr/local/go

export PATH=$GOPATH/bin:$PATH

命令行輸入 source ~/.bashr 使配置生效

命令行輸入 go version 驗證配置是否成功

二、go-ethereum安裝

MAC OSX

首先確保已安裝 homebrew,沒有安裝過的可以在命令行下執

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" 進行安裝

brew tap ethereum/ethereum

brew install ethereum

WINDOWS

訪問 https://geth.ethereum.org/downloads/

下載并安裝 Geth for Windows

LINUX

git clone https://github.com/ethereum/go-ethereum

sudo apt-get install -y build-essential golang

cd go-ethereum

make geth

下面以linux為例:

在環境變量中添加

export PATH=$PATH:/usr/local/ethernum/go-ethereum/build/bin:$PATH

在命令行下輸入 geth -h , 有如下顯示表示成功

1521012260(1).png

三、創建節點和創世區塊

以linux為例

編輯一個區塊鏈文件 genesis.json

{

"config": {

"chainId": 109,

"homesteadBlock": 0,

"eip155Block": 0,

"eip158Block": 0

},

"alloc" : {},

"coinbase" : "0x0000000000000000000000000000000000000000",

"difficulty" : "0x10000",

"extraData" : "",

"gasLimit" : "0xffffff",

"nonce" : "0x0000000000000077",

"mixhash" : "0x0000000000000000000000000000000000000000000000000000000000000000",

"parentHash" : "0x0000000000000000000000000000000000000000000000000000000000000000",

"timestamp" : "0x00"

}

創建節點

任意創建一個文件夾ethereumNode,在其中創建文件data1和data2

在ethereumNode文件下打開兩個終端A,B

終端A中

對創世區塊進行初始化,輸入:

geth -datadir data1 init genesis.json

啟動節點 端口號自行設定

參數說明

networkid 網絡標識符

datadir 設置當前區塊鏈網絡數據存放的位置

console 啟動命令行模式,可以在Geth中執行命令

ipcdisable 禁用IPC-RPC服務器

geth --networkid 123 --datadir data1 --ipcdisable --port 61910 --rpcport 8200 console

終端B中

對創世區塊進行初始化,輸入:

geth -datadir data1 init genesis.json

啟動節點 修改文件夾data2 端口號修改

geth --networkid 123 --datadir data2 --ipcdisable --port 61911 --rpcport 8201 console

進入>命令行即為啟動成功

四、連接節點

終端A的命令行中查看節點enode

>admin.nodeInfo.enode

"enode://2700fee9b8575b3a6df5146b192c74cc0a4eb832a8a3b95a80cc2a9aa73c7abb1a4cf2e734bb0228789611f86c95bcfe2654a187f3fa5ea58b49d245cf014e35@[::]:61910"

終端B的命令行中添加鄰居

>admin.addPeer("enode://2700fee9b8575b3a6df5146b192c74cc0a4eb832a8a3b95a80cc2a9aa73c7abb1a4cf2e734bb0228789611f86c95bcfe2654a187f3fa5ea58b49d245cf014e35@[::]:61910")

在這里如果是多臺機器之間的鏈接添加,需要將[::]改為對應機器的ip地址

終端A的命令行中查看鄰居

admin.peers

1521013925(1).png

可以看到這里的id與終端B節點的的ip是相同的

同樣,也可以在終端B中查看鄰居,會得到節點B的信息

至此,兩個節點就在一個區塊鏈上連接成功

五、挖礦與交易

挖礦前要創建賬戶

創建新賬號

personal.newAccount()

或者 personal.newAccount("123456")

挖礦

開始挖礦 miner.start(1)

停止挖礦 miner.stop()

挖礦一些時間我們可以查看產生了多少區塊等信息

eth.blockNumber 查看區塊數量

eth.getBlock(1) 通過區塊號查看區塊

eth.getTransaction("0x0c59f431068937cbe9e230483bc79f59bd7146edc8ff5ec37fea6710adcab825")

挖礦成功也會得到token

查看賬戶余額

eth.getBalance(eth.accounts[0])

或者 web3.fromWei(eth.getBalance(eth.accounts[0]), "ether")

發起交易前要解鎖賬戶

解鎖賬號

personal.unlockAccount(eth.accounts[0])

使用賬戶資金前都需要先解鎖賬號

查看終端B的賬戶信息

eth.accounts[0]

"0xe4be4471c30c2552e14d1e26e8384db67b6d7e62"

在終端A中查看余額并轉賬

查看余額 單位是wei

> eth.getBalance(eth.accounts[0])

1000000000000000000

轉賬 0.5個ether

eth.sendTransaction({from:eth.accounts[0],to:"0xe4be4471c30c2552e14d1e26e8384db67b6d7e62",value:web3.toWei(0.5,"ether")})

使用 txpool.status 可以看到交易狀態

挖礦確認交易

miner.start()

當有新的區塊產生時停止挖礦

miner.stop()

查看節點B的余額,轉賬成功

eth.getBalance(eth.accounts[0])

500000000000000000

查看節點A的余額,數量反而變多,因為使用節點A進行了挖礦

eth.getBalance(eth.accounts[0])

25500000000000000000

轉載請注明出處

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的geth 转账_以太坊1 - 私有链部署、挖矿、转账的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。