EOS入门指南PART4——合约开发铺垫:搭建本地测试节点

以前三篇咱们掌握了如何使用EOS源码搭建环境、链接主网以及如何建立帐户。自此,咱们对EOS就有了一个感性的认知,对EOS中公钥、帐户以及权限有了新的认知。将来几篇,咱们将学习如何开发EOS智能合约。

在此以前,咱们要为此作一些准备工做:搭建本地测试节点,方便之后编写和部署合约。node

摘要

这篇,咱们将简单学习如何搭建本地测试节点(你们就不要花钱去买RAM了),以及如何使用超级帐户eosio建立新帐户以及加载基础的系统合约bios。ios

注:再次提醒你们,本系列旨在帮助没有接触过EOS的小伙伴快速入门,对学习深度有要求的小伙伴能够移步至公众号的其余系列,对EOS有更加专业深刻的分析。web

1. 运行EOS本地节点

以前咱们已经学会了如何运行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

testnet-getinfo

这里咱们看到chain_id已经再也不是主网的id,说明咱们已经在本地的测试节点上了。安全

咱们再来简单复盘下咱们须要用到的组件:bash

  • cleos - 管理帐户、查询链信息、部署合约以及和合约交互等的客户端工具;
  • eosiocpp - eos的编译器,会产生部署合约须要的.wast和.abi文件;
  • nodeos - 负责总体链管理的命令工具,例如启动/中止
  • keosd - 虽然咱们使用cleos来建立钱包,可是在这之下的钱包管理工具就是keos

2. 为eosio帐户建立钱包

在这里,我想和你们深刻强化一下钱包的概念:网络

钱包是一个私钥库,用来受权发生在区块链上的动做(action)。

这些私钥使用密码生成,被加密存储在磁盘上。这个密码应该被储存在一个安全的密码管理器中。工具

create wallet create -n eosio

eosio-wallet

这里的eosio只是钱包名称,和eosio帐户没有任何关系。你们能够任意命名。

eosio帐户在这里是很特殊的,它是系统启动的时候默认建立的超级用户,能够执行系统的一切操做。能够说,拥有了这个帐户,就拥有了整个EOS(测试网络😉)。在主网上,它被21个超级节点共同拥有。

因此在本地测试网络上,咱们可使用eosio帐户随意创造新帐户。这个帐号有多特殊呢,特殊到了公私钥写进了配置文件里:

~/Libraries/Application Support/eosio/nodeos/config/config.ini中你们能够找到这个帐号的公私钥:

EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV=KEY:5KQwrPbwdL6PhXujxW37FSSQZ1JiwsST4cqQzDeyXtP79zkvFD3

前面是公钥,后面是私钥。

3. 导入eosio帐户的私钥

要想使用eosio帐户,咱们就要把eosio帐户的私钥导入咱们新建立的eosio钱包中(再次声明:钱包能够随意取名):

cleos wallet import -n eosio 5KQwrPbwdL6PhXujxW37FSSQZ1JiwsST4cqQzDeyXtP79zkvFD3

这时咱们就能够操做eosio帐户啦。

4. 建立新钱包、以及导入私钥

下面咱们要创造一个新的钱包用来管理咱们即将建立的新帐户。和以前文章中的步骤同样:

# 建立test钱包
cleos wallet create -n test
# 生成秘钥对
# 私钥用于导入钱包,公钥用于建立帐户
cleos create key
# 私钥导入test钱包
cleos import -n test import <privateKey-just-created>

上面的步骤就不详细展开了,看不懂的同窗能够先学习前三篇。这里咱们有了一个eosio钱包用来管理eosio帐户,而且有了一个test钱包,用来管理咱们即将建立的帐户。

5. 建立新帐户

执行下面的命令:

cleos create account eosio ${new_account} ${owner_key} ${active_key}

在这里咱们建立一个名叫testeosio的帐户,对照上面的格式,具体命令以下(省略了active_key):

cleos create account eosio testeosio EOS7hHoMoPcbJq6gsTViNdTj35AKCjLCqabamj7P68vzwAfRoCLRq

这时能够看到:

eos-new-account-locally

新帐户建立成功!

6. 载入基础BIOS合约

如今咱们拥有了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

返回以下界面:cleos-set-contract-1

最后的-p eosio的含义是:使用eosio帐户(使用的是对应私钥)来为这个action签名。

  • 读取 WAST/WASM文件(这个文件是被新部署到build目录下的)
  • 装配 WASM
  • 发布合约
  • 执行交易(合约也是一个交易),这里经过两个动做来生成一个交易,
  • 上面的cleos set contract能够被拆分为如下两个独立的动做:

    • eosio::setcode:code描述了合约是如何运行的
    • eosio::setabi:setabi,abi描述了如何在二进制文件和json文件中转换,能够理解成对合约接口的描述。

总结

这章咱们学习了如何搭建本地节点、使用超级帐户eosio来运行系统级别的智能合约以及建立新帐户。至此,咱们就基本搭建好了智能合约的开发运行环境,为下面深刻学习EOS智能合约开发作好了铺垫。

下面一章我还会继续为你们讲解智能合约开发以前的概念储配:例如简单了解LLVM和webAssembly,合约的交互模式等一些必备的概念,简以及单地部署你们最喜闻乐见的hello world contract。

相关文章
相关标签/搜索