时间:2022-06-13 10:13:36 | 栏目:Golang | 点击:次
geth
以太坊智能合约开发中最常用的命令行工具。
Geth
是由以太坊基金会提供的官方客户端软件,用Go
编程语言编写的。Geth
提供了一个交互式命令控制台,通过命令控制台中包含了以太坊的各种功能(API)。全名go-ethereum
。
官网(很慢):https://geth.ethereum.org/downloads/
国内镜像:https://ethfans.org/wikis/Ethereum-Geth-Mirror
下载下来之后,会在安装目录生成geth.exe
将这个文件放在gopath
的bin目录中,
放在这里就行了
geth version
如果你安装了,但是没有显示这个的话,可能是因为你的系统环境里面没有go的路径,把go的bin目录路径放在系统变量的path就好了~
geth -help
查看帮助
命 令:geth [选项] 命令 [命令选项] [参数…]
命令参数介绍:超详细
如:geth --datadir “路径” account new
查看账户:geth account list
查看账户的信息
创建账户:geth account new
然后输入两次密码
更新指定账户:geth account update "用户地址"
输入账户密码及确认密码
默认是会把用户的账户信息存放在这个目录
导入账户:geth account import 你的私钥文件路径(导出私钥存放到xx.txt)
指定保存路径的创建用户:geth --datadir account new
启动并进入交互式javascript环境
默认连接的是ipc
geth attach http://IP:8545,默认不开启
geth attach ws://IP:8546,默认不开启
进入控制台:geth console 可以指定--datadir "路径"
退出控制台:exit
或者 ctrl+d
常用api:
获取区块号:eth.blockNumber
是否在监听端口 net.listening
开始挖矿:miner.start()
不要直接删除datadir目录,使用removedb
geth --datadir "路径" removedb
这会删除路径/geth/chaindata,其他东西都不会动,不会删除用户。
geth account -hgeth account help new 查看子命令
1 . Error: authentication needed: password or unlock undefined:
这种报错解锁下账户即可
账户解锁:personal.unlockAccount(“账户地址”)
2 . Returned error: exceeds block gas limit:
出现这种错误就看块号的gaslimit,部署时改成一直
获取块号:eth.blockNumber
根据块号获取详细信息:eth.getBlock(0)
geth --datadir "fanone" --identity "fanone" --rpc --rpcport 8545 --rpcapi "db,eth,net,web3,personal" --rpccorsdomain "*" console
–identity
“fanone”:节点身份标识
–rpc
:开启 RPC
接口
–rpcport
:RPC
端口,默认go是8545
–rpcapi
“db,eth,net,web3”:提供给别人使用的 RPC API,默认为web3
接口
–rpccorsdomain
:设置能连接到你的节点的 URL,用来完成RPC
任 务。* 指任何URL
都能连接到,默认只能自己连接
–datadir
:区块数据文件夹 ,如果不指定的话,就是上面的那个在C盘的地址。
为了C盘着想,所以还是建议这样,新建一个文件夹放在其他盘
就会在这里进行存放了
–networkid
:net_version
的id
–port
:用来监听其他节点的端口
–nodiscover
:你的节点不会被其他人发现,除非他们手动添加你
是连接这个url
下载包:"github.com/ethereum/go-ethereum/rpc"
示例代码:
client, _ := rpc.Dial("http://localhost:8545") var result bool client.Call(&result ,"net_listening") // 注意这里必须使用指针,否则会报空指针异常
启动之后
在go中调用
net_version
当前连接网络的ID
net_version
: 当前连接网络的ID
var networkid string client.Call(&networkid,"net_version")
networkid: "1":Mainnet "2": Morden Testnet "3": Ropsten Testnet "4": Rinkeby Testnet "42": Kovan Testnet
在启动rpc服务接口的时候可以指定: --networkid
net_listening
客户端是否处于监听状态
var is_listing bool client.Call(&is_listing,"net_listening")
net_peerCount
所连接对端节点旳数量
var count string client.Call(&count,"net_peerCount") //"0x0" 表示0个 //"0x2" 表示2个
1 .eth_accounts:账户地址数组
var accounts []string client.Call(&accounts,"eth_accounts")
2 .eth_getBalance:获取指定地址账户的余额,单位:wei
var balance string client.Call(&balance,"eth_getBalance","0x558c90c05d8c4b55a87de03bd601fd76faf50f9b","latest")
参数:
账户地址
整数块编号,或者字符串"latest", “earliest” 或 “pending”
3 .eth_gasPrice:返回当前的gas价格,单位:wei。
var gas_price string client.Call(&gas_price,"eth_gasPrice")
4.eth_coinbase:
获取挖矿账户地址
var coinbase string client.Call(&coinbase, "eth_coinbase")
5.eth_protocolVersion:
返回当前以太坊协议的版本。
var proto_version string client.Call(&proto_version , "eth_protocolVersion")
6.eth_mining:
客户端是否在挖矿中
var is_mining bool client.Call(&is_mining,"eth_mining")
7.eth_hashrate:
返回节点挖矿时每秒可算出的哈希数量。
var hashrate string client.Call(&hashrate,"eth_hashrate")
8.eth_getTransactionCount:
返回指定地址发生的交易数量
var transactionCount string client.Call(&transactionCount,"eth_getBalance","0x72w12d05d8c4b55a87de03bd601fd76faf50f9b","latest") //参数 // 账户地址 // 整数块编号,或者字符串"latest", "earliest" 或 "pending"
9.eth_blockNumber:获取节点当前块编号
var blockNum string client.Call(&blockNum ,"eth_blockNumber")
1 .personal_listAccounts:
获取该节点下的所有账户,和eth_accounts效果一样
var accounts []string client.Call(&accounts,"personal_listAccounts")
2.personal_newAccount:
创建用户
var newAccount string client.Call(&newAccount, "personal_newAccount", "12345678") 参数: 密码
3.personal_lockAccount:
锁定指定账户
var is_lock bool client.Call(&is_lock, "personal_lockAccount", "账户地址") //参数: // 账户地址
4.personal_unlockAccount:
解锁指定账户,有些操作必须解锁账户才可以操作
var is_unlock bool client.Call(&is_unlock, "personal_lockAccount", "账户地址","账户密码") 参数: 账户地址 账户密码
1.db_putString:
在本地数据库中存入字符串
var is_ok bool client.Call(&is_ok, "db_putString", "db_name","key",""value") 参数: 数据库名称 key名 要存入的字符串值
2.db_getString:
从本地数据库读取字符串。
var val string client.Call(&val, "db_getString", "db_name","key") //参数: // 数据库名称 // key名