https://github.com/wupeaking/pbft_impl
基于pbft共识算法的贝壳区块链平台
https://github.com/wupeaking/pbft_impl
blockchain compiler evm p2p pbft
Last synced: 5 months ago
JSON representation
基于pbft共识算法的贝壳区块链平台
- Host: GitHub
- URL: https://github.com/wupeaking/pbft_impl
- Owner: wupeaking
- License: mit
- Created: 2020-08-04T09:14:53.000Z (almost 6 years ago)
- Default Branch: dev
- Last Pushed: 2023-03-06T05:25:37.000Z (over 3 years ago)
- Last Synced: 2024-06-19T00:37:08.089Z (almost 2 years ago)
- Topics: blockchain, compiler, evm, p2p, pbft
- Language: Go
- Homepage:
- Size: 7.46 MB
- Stars: 46
- Watchers: 3
- Forks: 10
- Open Issues: 15
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
## 贝壳 -- 一个基于PBFT共识算法的区块链平台
### 缘由
最初是计划学习pbft算法之后对其进行一个Go语言的实现. 编写的过程中发现, 如果想实现PBFT, 需要实现网络通信, 需要加密和验证签名功能.
于是逐渐的就写了加密模块, 区块链下载模块, 交易缓存, 数据存储等模块. 既然写了这么多, 索性就实现一个完整的区块链.
## 模块介绍
### pbft 共识
pbft共识在网络上有很多文章介绍, 但是具体的开源实现却比较少。 尤其是用在区块链项目中。 本项目的共识算法的状态流转和消息模型参考了
超级账本的sawtooth-rfcs(https://github.com/wupeaking/sawtooth-rfcs/blob/master/text/0019-pbft-consensus.md)项目的部分设计
### 加密
使用的是go标准库的椭圆曲线加密算法, 减少依赖 使用起来非常方便。
### P2P网络
在应用层封装成通信接口, 屏蔽不同的实现.
在调试场景使用http进行通信的模拟, 调试完成后使用目前比较成熟的开源libp2p进行封装.
### 交易池
一个本地的消息队列交易池
### 虚拟机
目前只能进行账户之间的金额转账. 等此功能完全稳定后, 会考虑将自己之前实现的一个脚本解释器经过修改移植到此项目中.
[https://github.com/wupeaking/panda]
### 数据存储
定义为三级存储, 最底层为leveldb实现持久化存储。
对其他组件提供缓存层.
### 实现的功能
- pbft共识模块
> 在单节点, 3节点, 4节点测试成功
- blockchain模块
- 下载区块
- 广播区块
- 停止共识
- 查询区块高度, 区块详情
- p2p模块
- 封装了libp2p
- 使用http协议进行调试通信
- 加密模块
- 存储模块
- 虚拟机模块
- 进行转账功能
- 账户系统
- 账户查询
- 创建
- 转账
- 交易
- 广播交易
- 查询交易
- 验证交易
- 命令行工具
- 账户创建 查询 转账
## 使用示例
### 使用说明
```shell
./counch.x --help
NAME:
counch 贝壳-一个区块链平台 - counch --help 显示更多使用说明
USAGE:
counch.x [global options] command [command options] [arguments...]
VERSION:
v0.0.1
COMMANDS:
account, account 贝壳账户系统
help, h Shows a list of commands or help for one command
GLOBAL OPTIONS:
--help, -h show help (default: false)
--version, -v print the version (default: false)
```
#### 创建账户
```shell
./counch.x account create --help
NAME:
counch 贝壳-一个区块链平台 account create - 创建一个新的账户
USAGE:
counch 贝壳-一个区块链平台 account create [command options] [arguments...]
OPTIONS:
--password value 密码 (default: 123456)
--help, -h show help (default: false)
```
#### 列出自己的账户
```shell
./counch.x account list
-------------------------
address: 0x8e1fbf5b13279c82eac11cc23f456118d12a1babdecd9dbfb643defe4a1d9e62, public: 0x6a1582185f55b394b1da2e695d7935b8d38e8d30cd7e4414a5400490e6c58207f6c15ddfe41ce89a02e3716b351aea04e897bf130952b2161a4ab44c101248cc, private: , index: 1
address: 0xf52772d71e21a42e8cd2c5987ed3bb99420fecf4c7aca797b926a8f01ea6ffd8, public: 0xc4024ffd0b42495f49002b5da606512aee341c53e43a641b7d8efac8e29f6ed2d5c6449fe4343f41c5216a84ea9dd43e07daeeadb38556bb19527ce699394cd7, private: , index: 2
累计: 2
-------------------------
```
#### 查询当前钱包所有余额
```shell
./counch.x account balance
```
### 如何启动一个新的贝壳链
#### 1. 编译
```
git clone git@github.com:wupeaking/pbft_impl.git
go build -v -o counch.x cmd/counch/main.go
```
#### 启动
```
## 创建.counch文件夹
> mkdir .counch
## 拷贝配置文件 并根据需要修改
> cp test_node1/.counch/config.json ./.counch
## 启动
> ./counch.x
```
### 目前已经部署了3个节点的测试链
区块链浏览器地址为: http://blockchain.wupengxin.cn
