[blockchain-035]eos的部署安装智能合约

公良弘毅
2023-12-01

0.参考资料

  https://github.com/EOSIO/eos/wiki

1. eos的github地址

https://github.com/EOSIO/eos


2.下载eos源码

 

git clone https://github.com/EOSIO/eos --recursive

3. readme.MD
  beta测试版本
  支持7种os,推荐ubuntu 16.04
  编译、运行、使用的文档参考 https://www.taohuayuangw.com github.com/EOSIO/eos/wiki


4.https://github.com/EOSIO/eos/wiki
  4.1 glossary 一些名词解释
  4.2 Setting Up A Local Environment 设置环境变量
    4.2.1 overview  
      三个可执行程序:nodeos是服务端; cleos是区块链的命令行接口和钱包管理; keosd管理eos钱包
      这三个可执行程序可以在一个单节点上部署。
      三者的关系:cleos管理nodeos和keosd;nodeos管理一个节点,通过这个节点跟整个eos网络的无数节点进行交互; keosd管理钱包。 
    4.2.2 getting the code
      git clone https://github.com/EOSIO/eos --recursive
    4.2.3 building eosio
      确保操作系统。然后运行 ./eosio_build.sh
      安装过程需要多次输入root密码。编译过程比较长。
    4.2.4 creating and launching a single node testnet
      编译完成后,启动单节点的测试网络
      cd build/programs/nodeos
      ./nodeos -e -p eosio --plugin eosio::wallet_api_plugin --www.feifanyule.cn plugin eosio::chain_api_plugin --plugin eosio::account_history_api_plugin 
      正常启动后,会不断滚动形如:
      3343000ms thread-0   producer_plugin.cpp:239       block_production_loo ]www.cnzhaotai.com  eosio generated block 408af1a5... #321 @ 2018-05-10T06:55:43.000 with 0 trxs, lib: 320
      3343502ms thread-0   producer_www.089188.cn plugin.cpp:239       block_www.ruishengks.com production_loo ] eosio generated block 464e6a30... #322 @ 2018-05-10T06:55:43.500 with 0 trxs, lib: 321
      ....
      运行关系:nodeos运行一个单producter的eosio。如果nodeos启动参数有“--plugin eosio::wallet_api_plugin”,那么它可以管理eos钱包。
    4.2.5 docker (暂时不需要)
    4.2.6 troubleshooting guide (暂时不需要)
  4.3 Programs & Tools
    4.3.1 nodeos 
      核心 eosio 守护进程,运行 eos节点。
    4.3.2 cleos
      cleos (client os)是命令行工具,跟nodeos提供 rest api接口进行交互。比如,创建链上的区块和transaction,设置区块链状态,签名,操作钱包,操作网络,向区块链发送智能合约,把区块推送到链上等等。
      命令 "build/programs/cleos$ ./cleos -h" 打印帮助信息      
    4.3.3 keosd
      eosio钱包守护进行,载入钱包插件,提供http接口和rpc api
    4.3.4 launcher
      这个进程为部署多节点eos网络提供辅助功能,在各节点之间发布配置文件,启动多节点的nodeos实例等等。
    4.3.5 snapshot
      nodejs的进程,创建crowdsale合约的snapshot,配置创始区块等等。
    4.3.6 eosiocpp
      这是一个工具,生成abi规范的c++代码。比如,命令"eosiocpp -g abi.json types.hpp"。这块有比较多的细节,暂时还不太懂。
  4.4 Public Testnet目前不可用
  4.5 Accounts & Permissions
    4.5.1 Wallets
      wallet存储若干个key。这些key跟多个account相关联。钱包有两种状态:锁,解锁。登录钱包需要密码。cleos跟keosd做命令交互管理钱包。
    4.5.2 Accounts
      把transaction提交到区块链上需要acount,account是一个拥有标志。
    4.5.3 Authorities and Permissions
      每个account有两个本地命令的授权:owner和active。owner:一个account的拥有者,只有极少数transaction需要这种授权,owner最好存放在冷存储cold storage不要让任何其他人知道。active,转移资金,投票生产者,以及一些 account的变动操作。除了这两种授权,还可以自定义授权。授权需要指定到一个或者多个public key或者有效的acount name。
    4.5.4 Putting it all Together
      本节是示例。描述如何使用account提交transaction,可以用一个账户提交,也可以多个账户提交。相当简单直接。
  4.6 CLI Wallet
    4.6.1 Overview
      keosd在本地运行,在本地存储私钥。
    4.6.2 How to run keosd
      ./keosd,配置文件目录
      然后,cleos 创建钱包,打开钱包,锁钱包,解锁钱包,向钱包导入私钥,list钱包。
      如前所述,可以用nodeos管理钱包,这样,就不需要启动keosd了,但不推荐同时使用keosd和nodes管理钱包。
      
  4.7 Cleos Command Reference
    cleos的具体用法和demo。
  4.8 Persistence API
    4.8.1 Overview
      rosio提供一组服务和接口,让智能合约的开发者实现状态持久化,这种持久话可以跨越action,transaction和boundaries。持久化包括:服务将状态持久化到数据库; 在检索数据库内容的时候,强化查询能力;智能合约开发使用的各种服务的c++接口;库和系统开发者使用的核心服务调用的c api。  
      eosio的智能合约以Actions的方式执行。Action需要一个执行环境,也就是action context。一个action context给action提供必需的资源,比如内存。action在内存里保存各种状态。在执行一个action之前,eosio先建立一个干净的工作内存。在实际情况下,并发/并行的其他的action的执行可能会改变内存里的某些变量。因此,唯一可行的方式,是把变量进行持久化,在需要的时候再从数据库读出使用。
    4.8.2 The EOSIO Multi-Index API
      eosio多索引api,为eosio数据库提供c++接口。主要是提供灵活的查询方式,让智能合约的开发者读写修改持久化状态数据。然后提供了一个demo,交通工具数据库示例。
    4.8.3 C++ API Reference
      创建table,创建index,以及各种使用方式。
  4.9 Smart Contracts
    4.9.1 Introduction to EOSIO Smart Contract
      智能合约基于WASM。WASM被google,ms,apple等多家公司支持。最成熟的wasm工具链是clang/llvm和c/c++编译器。rust,python,solidity等其他语言也有类似的工具链,但语言太简单了,性能也不够好,不推荐使用。
      智能合约的通信方式是action和共享内存。智能合约可以读取另一个智能合约的状态。一个智能合约里可以定义两种通信模型:inline和defered。inline, 可以保证当前tranction能执行action或者unwind,无论成功失败都不会有通知,inline在一个智能合约里执行。defered,以被调度执行,可以timeout,可以跨智能合约执行。
      一个transaction可以有若干个action.
      action的type是base32编码的64位整数。      
    4.9.2 Smart Contract Files
      eosiocpp工具,生成智能合约的源码文件。
    4.9.3 Debugging Smart Contracts
      智能合约在私有测试网络的本地eos节点进行调试。这里给出示例和步骤。
  4.10 Tutorials(智能合约教程)
    4.10.1 Getting Started with Smart Contracts
      启动一个单节点的私有区块链
      创建钱包
      导入一个bios智能合约
      创建account帐号
    4.10.2 Eosio.token, Exchange, and Eosio.msig Contracts
      创建一个eosio.token智能合约并部署。按照步骤执行既可。
    4.10.3 Hello World Tutorial
      用c++开发并部署一个智能合约。
    4.10.4 Comprehensive Accounts & Wallets Tutorial
      更全面的account和wallet教程
    4.10.5 Tic-Tac-Toe
      用智能合约开发一个区块链上的游戏,完整demo。
  4.11 Testnet
    4.11.1 Single Host Multi-Node (www.leyouzxgw.com Private) Testnet
      测试网络,在一台主机上部署多个节点。
  4.12 Releases
      各版本信息。

转载于:https://www.cnblogs.com/qwangxiao/p/9040579.html

 类似资料: