blockj
Java 实现的一个简易区块链(联盟链)项目,包括加密工具,钱包,P2P 传输,区块同步,网络共识等基础实现。 它使用 SpringBoot + Tio 网络框架实现,是一个非常好的区块链学习项目,目前只实现了 POW 共识算法,如果要用于生产项目需要根据自己的项目需求修改共识。
项目架构
主程序使用 SpringBoot 实现, P2P 传输这块使用的是 t-io 网络框架。
运行环境为 JDK1.8 以上版本。
项目模块
- blockj-base 基础公共的工具包,如加密,区块,消息等数据模型,数据存储等。
- blockj-miner 区块链主程序,如矿工,区块同步,P2P 网络,RPC API 等。
- blockj-client 客户端命令行工具,主要就是调用 Miner 的相关 API,用户跟链交互。
快速开始
创建一条链的操作流程如下:
- 创建创世节点(创建一个网络)
- 启动创世节点(Genesis Miner)
- 其他节点要加入网络的话,只需要以创世区块初始化 Miner,然后再启动 Miner 即可。
创建创世节点
首先我们需要编译打包程序:
git clone https://gitee.com/blackfox/blockj.git
cd blockj
mvn clean package
然后创建创世节点:
./miner genesis --repo=/data/genesis --enable-mining=true
启动创世 Miner:
./miner run --repo=/data/genesis
启动新 Miner
首先需要初始化 miner,需要导入创世区块(genesis.car)来加入网络:
./miner init --repo=/data/miner1 --genesis=genesis.car --api.port=8002 --p2p.port=3456
启动 Miner
./miner run --repo=/data/miner1
客户端使用
-
查看钱包列表
./client wallet list # 输出 Address Balance Nonce 0x0d181310331612e107b5e0dfdf971cfb9de780bb 800 1 0x2505bf54f3a63848e44a105e8de599ad08ae8c58 2400 0 0xb6258bc70240ee5daa213f671c08db51e50a4cbe 50800 3 0xcd3da3ec4195070e13a6d88b75101f6ceb427a8e 0 0
-
创建新钱包
# 创建普通钱包 ./client wallet new 0xb640636a77381b6589c78d58d629221131946dc # 创建带助记词的钱包,可设置密码,生成 keystore 文件 ./client wallet new --mnemonic=true 123456 Mnemonic words: rain fog canal matrix tonight initial frog wear feel movie worry whisper Address: 0x42a8037f2876f649e08f7be6764b810e9a2f21da
-
查询钱包余额
./client wallet balance 0x2505bf54f3a63848e44a105e8de599ad08ae8c58 # 输出 Address Balance 0x2505bf54f3a63848e44a105e8de599ad08ae8c58 2400
-
转账
./client chain send --from=0x0d181310331612e107b5e0dfdf971cfb9de780bb 0x2505bf54f3a63848e44a105e8de599ad08ae8c58 123 # 输出 Send message, CID: 05b6074241f1406cd1a68731d74cf612f55981692a3f4e5d9da01b13b4ee3631
-
查看当前链高度
./client chain head Chain head: 1217
-
查看指定的链上消息
./client chain getMessage 05b6074241f1406cd1a68731d74cf612f55981692a3f4e5d9da01b13b4ee3631 # 输出 Message{version=1, from='0x0d181310331612e107b5e0dfdf971cfb9de780bb', to='0x2505bf54f3a63848e44a105e8de599ad08ae8c58', value=123, timestamp=1672826743640, pubKey='PZ8Tyr4Nx8MHsRAGMpZmZ6TWY63dXWSCw5EXe33S25zZDT25sNYu1bjtBfaCwEGSgnGhJiE31fCfDsyE3pNFw7cC87VfQZQqiEdntMmztfpiDcRe1gv3aJJ4', cid='05b6074241f1406cd1a68731d74cf612f55981692a3f4e5d9da01b13b4ee3631', status=APPENDING, nonce=2, params='null', height=0, sign='30460221009A8B2750A6D986EB926B67163B740BBACDD07FE2D87F8FA9AE2F08424989477602210082C1C36EAEEC6367C023847F995291873F305B867E9B65A5C68ED8A4293DB890'}
-
查看指定高度的区块信息
./client chain getBlock 1 # 输出 Block{header=BlockHeader{height=1, difficulty=28269553036454149273332760011886696253239742350009903329945699220681916416, nonce=703, createTime=1672813674, hash='0004c262f7ead28cc66c9336d7a8335cb8fea5a06b0b1fd7488c3c9b140987cc', previousHash='ed5126ddd65f39a17739b8e26ea3edecfff6bf196148dc259d9a3eddeefc23d5'}, messages=[Message{version=0, from='B099', to='0xb6258bc70240ee5daa213f671c08db51e50a4cbe', value=50, timestamp=1672813674163, pubKey='PZ8Tyr4Nx8MHsRAGMpZmZ6TWY63dXWSD1ErKp8AqSj4Ph9Jsj2Gvk7w1pyLgqDRiguC7JvjeGZJZ1si1qRYCAsVmu1UvYRqvhiCBgYDpmyuWK5VzD5KK4RNY', cid='3e1f8987b0d66b2de155e78aeef6984ab7cb6c3acdf03c835c01f4b4088fb90d', status=SUCCESS, nonce=0, params='Miner Reward.', height=1, sign='304402202DF6EABBF5C81C41996C44F8E1230D44CAE8ADA9184B466D9B708ADC8B050225022049D74E4E99E0EA8E56208AD2E4B7B17C2320DC3E6461A17C94D1820818559CA9'}], blockSign='3046022100C04714C00642527AF6AA1DB2B537E5FD887F52999F66929AA2A928D4C6A4897A022100AF98888FDC825FFB0683E8D65494363790E5173F3991AF61AB86DEEFEAF15D81'}
-
查看当前网络中 P2P 节点列表
./client net peers
-
查看当前节点 P2P 连接信息
./client net listen # P2P 连接信息,用于被其他节点连接 127.0.0.1:2345
-
手动连接某个节点
./client net connect 192.22.33.11:3456
TODOLIST
- blockj-miner api 实现
- 消息同步和打包
- blockj-client(客户端)功能实现:网络,钱包,转账
- 文档完善
- 添加 PBFT 共识支持