以前三篇咱们掌握了如何使用EOS源码搭建环境、链接主网以及如何建立帐户。自此,咱们对EOS就有了一个感性的认知,对EOS中公钥、帐户以及权限有了新的认知。将来几篇,咱们将学习如何开发EOS智能合约。在此以前,咱们要为此作一些准备工做:搭建本地测试节点,方便之后编写和部署合约。node
这篇,咱们将简单学习如何搭建本地测试节点(你们就不要花钱去买RAM了),以及如何使用超级帐户eosio建立新帐户以及加载基础的系统合约bios。ios
注:再次提醒你们,本系列旨在帮助没有接触过EOS的小伙伴快速入门,对学习深度有要求的小伙伴能够移步至公众号的其余系列,对EOS有更加专业深刻的分析。web
以前咱们已经学会了如何运行EOS节点而且链接到主网,这里简单重复下:数据库
nodeos -e -p eosio --plugin eosio::wallet_api_plugin --plugin eosio::chain_api_plugin --plugin eosio::history_api_plugin
若是启动报错的话,例如碰见dirty-flag
这样的错误,能够试着用--hard-replay-blockchain
强制清空链状态数据库:json
nodeos -e -p eosio --plugin eosio::wallet_api_plugin --plugin eosio::chain_api_plugin --plugin eosio::history_api_plugin --hard-replay-blockchain
以后咱们再使用cleos get info
查看当前链信息:api
这里咱们看到chain_id
已经再也不是主网的id,说明咱们已经在本地的测试节点上了。安全
咱们再来简单复盘下咱们须要用到的组件:bash
cleos
来建立钱包,可是在这之下的钱包管理工具就是keos在这里,我想和你们深刻强化一下钱包的概念:网络
钱包是一个私钥库,用来受权发生在区块链上的动做(action)。这些私钥使用密码生成,被加密存储在磁盘上。这个密码应该被储存在一个安全的密码管理器中。工具
create wallet create -n eosio
这里的eosio
只是钱包名称,和eosio帐户没有任何关系。你们能够任意命名。
eosio帐户在这里是很特殊的,它是系统启动的时候默认建立的超级用户,能够执行系统的一切操做。能够说,拥有了这个帐户,就拥有了整个EOS(测试网络😉)。在主网上,它被21个超级节点共同拥有。
因此在本地测试网络上,咱们可使用eosio帐户随意创造新帐户。这个帐号有多特殊呢,特殊到了公私钥写进了配置文件里:
在~/Libraries/Application Support/eosio/nodeos/config/config.ini
中你们能够找到这个帐号的公私钥:
EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV=KEY:5KQwrPbwdL6PhXujxW37FSSQZ1JiwsST4cqQzDeyXtP79zkvFD3
前面是公钥,后面是私钥。
要想使用eosio
帐户,咱们就要把eosio
帐户的私钥导入咱们新建立的eosio
钱包中(再次声明:钱包能够随意取名):
cleos wallet import -n eosio 5KQwrPbwdL6PhXujxW37FSSQZ1JiwsST4cqQzDeyXtP79zkvFD3
这时咱们就能够操做eosio帐户啦。
下面咱们要创造一个新的钱包用来管理咱们即将建立的新帐户。和以前文章中的步骤同样:
# 建立test钱包 cleos wallet create -n test # 生成秘钥对 # 私钥用于导入钱包,公钥用于建立帐户 cleos create key # 私钥导入test钱包 cleos import -n test import <privateKey-just-created>
上面的步骤就不详细展开了,看不懂的同窗能够先学习前三篇。这里咱们有了一个eosio钱包用来管理eosio帐户,而且有了一个test钱包,用来管理咱们即将建立的帐户。
执行下面的命令:
cleos create account eosio ${new_account} ${owner_key} ${active_key}
在这里咱们建立一个名叫testeosio
的帐户,对照上面的格式,具体命令以下(省略了active_key):
cleos create account eosio testeosio EOS7hHoMoPcbJq6gsTViNdTj35AKCjLCqabamj7P68vzwAfRoCLRq
这时能够看到:
新帐户建立成功!
如今咱们拥有了eosio帐户而且能够自由使用,例如随意建立新帐户。这时咱们就可使用默认的智能合约eosio.bios
,这个合约是不少动做(action)的基础系统,例如:直接控制资源分配、有权限访问API。在主网上,它还能够管理token的抵押和赎回,觉得CPU、网络活动和合约内存保留带宽。
eosio.bios
合约能够在${EOSIO_SOURCE}/build/contracts/eosio.bios
路径中找到。下面的命令是在`${EOSIO_SOURCE
中执行的,固然你也能够在任意路径下执行:
cleos set contract eosio build/contracts/eosio.bios -p eosio@active
返回以下界面:
最后的-p eosio
的含义是:使用eosio帐户(使用的是对应私钥)来为这个action签名。
上面的cleos set contract
能够被拆分为如下两个独立的动做:
eosio::setcode
:code描述了合约是如何运行的eosio::setabi
:setabi,abi描述了如何在二进制文件和json文件中转换,能够理解成对合约接口的描述。这章咱们学习了如何搭建本地节点、使用超级帐户eosio
来运行系统级别的智能合约以及建立新帐户。至此,咱们就基本搭建好了智能合约的开发运行环境,为下面深刻学习EOS智能合约开发作好了铺垫。
下面一章我还会继续为你们讲解智能合约开发以前的概念储配:例如简单了解LLVM和webAssembly,合约的交互模式等一些必备的概念,简以及单地部署你们最喜闻乐见的hello world contract。