eos代码分层架构

eos代码分层架构_第1张图片


服务层:

对外提供服务接口,其中:

1.  eosio-launcher是P2P网络组成启动器源代码,该部分简化了nodeos节点组网的流程。

2.  eosio-abigen是智能合约编译器源代码(用于生成智能合约的.abi文件)

3.  keosd是内置钱包程序,配合钱包相关插件通过HTTP接口或RPC API与cleos进行通信,完成账户创建,转账等基本钱包功能。

4.  cleos是eos项目中与nodeos之间交互信息的命令行工具cleos的源代码,编译后与nodeos公开的REST API进行信息交互。

5.  nodeos是eos项目的核心程序源代码,可以配置不同插件来运行不同类型节点。该进程主要负责提供区块生产,封装API接口和本地开发的功能。

合约层:

合约层是EOS 的智能合约部分的实现,包含三部分:

1.  库函数合约:实现合约层中依赖的一些库函数,里面包括最重要的action的实现(参考https://github.com/facebook/flux/tree/master/examples/flux-concepts)

2.  系统合约:为了提高EOS 弹性升级的能力将一些容易变更的部分放在系统合约里面,防止硬分叉,包括:

1) Token:

实现了发行token的功能,可以说EOS本身代币或后续基于EOS的代币都是通过该合约发行的。

2)Bios

用于启动EOS的P2P网络,该合约可以直接控制其他帐户的资源分配并访问其他特权API调用,具体启动流程如下:

     初始启动节点部署该合约,并设置所需的参数;

     待连接节点通过初始启动节点的地址与之相连;

     初始启动节点调用bios合约,为待连接节点设置权限。

2)Msig:

定义了多签系统合约,实现了一个多签功能,由于EOS要求系统的每一次更新都需要出块节点完成一次多签,当签名数达到2/3+1时,更新才能生效。所以出块节点可以调用这个合约实现多签功能(已废弃)。

3)Sudo:

现了创建EOS系统中root账户的功能,用于修改系统代码与更新合约。

4)System

实现了EOS项目的所有基本功能:

    创建新账户;

    部署智能合约;

    交易RAM;

    抵押获取资源(net、cpu);

   投票;

   领取节点奖励;

3   其他合约

插件层:

由于区块链根据节点类型不同,需要具备的功能也不同,例如生产节点、轻客户端两者需要的功能模块就不同,所以实现了插件的设计模式,其中还用到了桥接模式来隔离调用者编译的依赖性。

插件层内部包含三层结构:

 1.  基础层:根据宏APPBASE_PLUGIN_REQUIRES来判断是否是基础层,包括:

       chain_plugin:承载了nodeos节点程序与区块链交互的基本功能 

       http_client_plugin: 定义了eos网络http层响应请求,并做相应的安全验证的客户端插件

       http_plugin:定义了网络http插件,这个插件承载了P2P网络中http层相关功能,实现endpoint的创建和连接。

       wallet_plugin:目录定义了钱包插件,这个插件承载了nodeos节点程序与钱包交互的相关功能

2   依赖层:

     bnet_plugin: 同net_plugin并行的P2P插件,参考:https://eosio.stackexchange.com/questions/590/whats-the-difference-between-bnet-endpoint-and-p2p-listen-endpoint-in-v1-0-0-co

     history_plugin: 定义了查询指定账户中指定公钥的所有历史交易记录。

     login_plugin:

     mongodb_plugin: 定义了保存并管理本地不可逆转区块链数据的MongoDB数据库基本配置插件

     net_plugin: 定义了P2P网络插件,这个插件承载了eos系统的P2P网络中区块链网络消息的处理功能

     producer_plugin:定义了区块生产节点的功能插件

3.  API层: 该层用来提供对外的API接口。

库函数层:

库函数层抽象为底层的API供上层的插件层、合约层以及服务层调用,实现了包含:

1.  abi_generator包含了智能合约编译器所需的依赖文件

2.  appbase提供了一个用于从一组插件构建应用程序的基本框架。该模块负责管理插件的生命周期,并确保所有插件按正确的顺序配置,初始化,启动和关闭。

3.   builtins中包含了eos项目编译过程中所需要的compiler-RT编译器(libgcc的替换库)的源代码,包括编译器本身以及相关功能函数的代码描述

4.   chain包含有eos项目的核心内容,包括区块,区块链,merkle树等数据结构以及初始区块,控制器等关键算法

5.  chainbase中定义了保存eos区块链数据的数据库结构,可以说该数据库旨在满足区块链应用程序的苛刻要求,但适用于任何需要强大的事务数据库的应用程序。

6.  fc是eos项目的细胞级模块,定义了eos项目中的基本变量数据结构,包括String,Time,Base系列编码等

7.  softfloat包含了一个Berkeley SoftFloat,即符合IEEE浮点运算标准二进制浮点的软件实现

8. utilities主要包含了一些通用的标准函数

9.  wasn-jit中包含了一个WebAssembly的独立VM

你可能感兴趣的:(eos代码分层架构)