以太坊源码解读
简介以太坊(英文Ethereum)是一个开源的有智能合约功能的公共区块链平台平台,通过其专用加密货币以太币(Ether)提供去中心化的虚拟机(“以太虚拟机” Ethereum Virtual Machine)来处理点对点合约。以太坊的概念首次在2013至2014年间由程序员Vitalik Buterin受比特币启发后提出,大意为“下一代加密货币与去中心化应用平台”,在2014年通过ICO众...
简介
以太坊(英文Ethereum)是一个开源的有智能合约功能的公共区块链平台平台,通过其专用加密货币以太币(Ether)提供去中心化的虚拟机(“以太虚拟机” Ethereum Virtual Machine)来处理点对点合约。
以太坊的概念首次在2013至2014年间由程序员Vitalik Buterin受比特币启发后提出,大意为“下一代加密货币与去中心化应用平台”,在2014年通过ICO众筹开始得以发展。
截至2018年10月,以太币依然是是市值第二高的加密货币,虽然前段时间被Ripper超越,但现在它又夺回了第二的位置,仅次于比特币。
以太坊作为目前区块链技术2.0的代表作品,无论是它独创的智能合约以及它本身交易的速度都优于bitcoin,通过看它的白皮书以及一些文章也略微了解了它的一些原理,但是总体还是对它的实现半知半解。
因此就想分析下它的实现源码,再结合白皮书和黄皮书也许可以深入的理解它的实现。
要解读以太坊的源码,首先要进入github
https://github.com/ethereum/ethereumj.git
准备工作
-
源码下载
git clone https://github.com/ethereum/ethereumj.git
-
结构介绍
本项目主要使用spring来管理对象,使用netty完成通信,使用leveldb负责存储,整体的包的结构如下所示:
每个包的作用大致为:
- cli : 负责启动参数的处理
- config: 负责配置文件注入以及一些bean的注入
- 公共部分:包含系统配置变量(SystemProperties)、配置初始化(Initializer 完成配置的初始化)、仓库、数据源、验证器等的注入
- blockchain:包含的是一些以太坊发布时各个版本的不同的特性,这些特性包括不限于难度值计算以及其他一些EIP所描述的bug或者features
- net:包含的是以太坊支持的不同的网络配置,包含主网或者测试网络不同的配置信息,所谓的配置信息就是blockchain配置所描述的一些不同的EIP或者其他的features
- core: 核心部分,它包含账户、区块、创世块、区块链、transaction、bloom的定义以及区块如何验证、如何加入链以及transaction如何使用vm执行也就是智能合约的执行都在这里完成
- crypto: 加密工具包含不限于hash算法、ECC算法等
- datasource: 提供了两种数据源实现内存以及leveldb,并使用者两种数据源扩展了不同实现,这包含缓存数据源、链数据源,依据于此又封装出读写缓存、异步读写缓存以及链存储相关的数据源实现。
- db: 定义了如何使用datasource存储block、transaction,换句话说就是block、transaction的存储数据结构
- facade: 包含了ethereum的实现,就是将块存储、验证、同步、合约执行等做的封装
- mine是挖矿相关的
- net 涉及的都是网络相关的,以太坊节点发现块同步都是建立在rlpx协议之上,这包含p2p、shh、eth等,另外server包就是节点发现服务启动入口
- samples是一些测试例子
- solidity是合约编译部分的实现
- sync 是负责负责块的同步下载等
- trie 是以太坊链存储的数据结构,该包主要是实现该数据结构也就是MPT
- utils 工具类,包含rlp编码等
- validator 这是一些验证器,在验证block的时候会用到
- vm 以太坊vm实现
- start是程序入口
更多推荐
所有评论(0)