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

总结一下以太坊私有链搭建的过程,已经遇到的问题。

我们使用了LINUX,MAC OSX,WINDOWS三种平台,运行go-ethereum。

一、go语言安装

LINUX

  1. 下载源码
    https://github.com/golang/go

  2. 配置环境变量

命令行输入sudo gedit ~/.bashrc  
在打开的文件最后加上两行代码:

export GOPATH=/usr/local/go
export PATH=$GOPATH/bin:$PATH

命令行输入 source ~/.bashr  使配置生效
命令行输入 go version  验证配置是否成功

MAC OSX
http://blog.csdn.net/soindy/article/details/70239442

WINDOWS
https://studygolang.com/articles/7585

二、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为例

  1. 编辑一个区块链文件 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"
}

  1. 创建节点

任意创建一个文件夹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

转载请注明出处

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352