瑞星 发表于 2024-7-29 21:05:04

区块链安全应用-------压力测试

基于已有的链进行测试(build_chain默认建的链 四个节 点):

第一步:搭链

1. 安装依靠 在ubuntu操作系统中,操作步调如下:
sudo apt install -y openssl curl
https://img-blog.csdnimg.cn/direct/1b879924641a4fc792436d92189de375.png
2. 创建操作目录, 下载安装脚本
## 创建操作目录

cd ~ && mkdir -p fisco && cd fisco

## 下载脚本
curl -LO https://github.com/FISCO-BCOS/FISCO-BCOS/releases/download/v2.7.1/build_chain.sh
chmod +x build_chain.sh
#搭链
bash build_chain.sh -l 127.0.0.1:4 -p 30300,20200,8545 –e ./fisco-bcos
https://img-blog.csdnimg.cn/direct/1ecca3486247401bbbe4f3d58025e244.png
https://img-blog.csdnimg.cn/direct/add35510d6864808a25c5ca5ff08d4fd.png
3. 启动链
bash nodes/127.0.0.1/start_all.sh
https://img-blog.csdnimg.cn/direct/7ea1629aa22249dd8c0baaccbb82d555.png
https://img-blog.csdnimg.cn/direct/c9ac7a1c0ebe43a79612ce72d6dab87f.png
第二步:设置网络设置文件

在networks/fisco-bcos/test/创建fisco-bcos2.json设置网络适配文件:
{
    "caliper": {
      "blockchain": "fisco-bcos"
    },
    "fisco-bcos": {
      "config": {
            "privateKey": "bcec428d5205abe0f0cc8a734083908d9eb8563e31f943d760786edf42ad67dd",
            "account": "0x0ff8981ebc130c7874ac7093a4d0c0e3d4f36b08"
      },
      "network": {
            "nodes": [
                {
                  "ip": "127.0.0.1",
                  "rpcPort": "8545",
                  "channelPort": "20200"
                },
                {
                  "ip": "127.0.0.1",
                  "rpcPort": "8546",
                  "channelPort": "20201"
                },
                {
                  "ip": "127.0.0.1",
                  "rpcPort": "8547",
                  "channelPort": "20202"
                },
                {
                  "ip": "127.0.0.1",
                  "rpcPort": "8548",
                  "channelPort": "20203"
                }
            ],
            "authentication": {
                "key":"/home/myy/Desktop/fisco-bcos/nodes/127.0.0.1/sdk/sdk.key",
                "cert": "/home/myy/Desktop/fisco-bcos/nodes/127.0.0.1/sdk/sdk.crt",
                "ca": "/home/myy/Desktop/fisco-bcos/nodes/127.0.0.1/sdk/ca.crt"
            },
            "groupID": 1,
            "timeout": 100000
      },
      "smartContracts": [
            {
                "id": "helloworld",
                "path": "src/fisco-bcos/helloworld/HelloWorld.sol",
                "language": "solidity",
                "version": "v0"
            }
      ]
    },
    "info": {
      "Version": "2.0.0",
      "Size": "4 Nodes",
      "Distribution": "Single Host"
    }
}
![](https://img-
blog.csdnimg.cn/direct/5c56ddf688fd4e06a730677f6e888a67.png)![](https://img-
blog.csdnimg.cn/direct/b6c33e3a2ac545feb974284349a8b09d.png)
第三步,对本地四节点链进行测试

npx caliper benchmark run --caliper-workspace caliper-benchmarks --caliper-benchconfig benchmarks/samples/fisco-bcos/helloworld/config.yaml --caliper-networkconfig networks/fisco-bcos/test/fisco-bcos2.json
https://img-blog.csdnimg.cn/direct/5e5750802a4b454f93827fa70008369f.png
https://img-blog.csdnimg.cn/direct/540523fead6548d6826aaeccd58ad5d7.png
测试和进程资源状态都可以监测,但在本地监测中,无法监测每个节点的资源状态。
第四步:克制节点

bash nodes/127.0.0.1/stop_all.sh
https://img-blog.csdnimg.cn/direct/a2e8af88638446e3bbcb217dc7ad350b.png
如何改成预编译的智能合约进行测试?

测试文件参数先容 参数 含义


[*]test.name 要在报告中显示的benchmark的短名称。
[*]test.description 要在报告中显示的benchmark的详细说明。
[*]test.workers 与工作线程相干的对象的设置。
[*]test.workers.type (暂未投入使用)
[*]test.workers.number 指定用于执行工作负载的工作进程数。
[*]test.rounds 对象回合数组,一个数组下可以有多轮差别的测试任务。
[*]test.rounds.label 该轮测试的名称,通常对应于该轮要提交的测试的范例。
[*]test.rounds.txNumber应在该轮任务提交的任务数。
[*]test.rounds.txDuration 该轮提交任务数的用时(单位,秒)。
[*]test.rounds.rateControl 描述该轮的速率控制计谋。
[*]test.rounds.workload 描述该轮的工作负载模块。
[*]test.rounds.workload.module 该轮基准测试工作负载模块实现的路径。
[*]test.rounds.workload.arguments 作为设置,传递给该轮工作负载模块的参数
通过Java SDK进行压力测试

设置工程链基本环境后,先容具体测试步调和要点。


[*]1. 编写合约:HelloWorld合约。
[*]2. 编译智能合约,将其转为Java文件,从上述WeBASE-Front中,也能编译并导出Java文件。
[*]3. 将编译天生的Java文件导入工程中,如HelloWorld.java。
[*]4. 基于上述文件,调用合约功能和接口,编写相干测试案例,例如:ContractTest。
[*]5. 基于Spring提供的gradle插件,我们可以通过”./gradlew test”命令来运行全部测试案例。
[*]6. 假如需要连续集成,可以在设置和初始化FISCO BCOS后,将步调5命令参加主动化脚本中。
第一步:安装JDK

# 安装open JDK 11
sudo apt install openjdk-11-jdk
# 验证Java版本
java --version
# 输出以下内容:
#openjdk 11.0.22 2024-01-16
#OpenJDK Runtime Environment (build 11.0.22+7-post-Ubuntu-0ubuntu220.04.1)
#OpenJDK 64-Bit Server VM (build 11.0.22+7-post-Ubuntu-0ubuntu220.04.1, mixed
mode, sharing)
https://img-blog.csdnimg.cn/direct/6779a2e371174e839208311dd45b3a83.png
第二步:编译源码

# 下载源码
git clone https://github.com/FISCO-BCOS/java-sdk-demo

cd java-sdk-demo
git checkout main-2.0

# 编译源码
./gradlew build
https://img-blog.csdnimg.cn/direct/aad52812ce9c4dc68e2864d9955153de.png
https://img-blog.csdnimg.cn/direct/71d3f3ab321f4e30b5260d954874f77c.png
https://img-blog.csdnimg.cn/direct/3c4d02ff7937444ba719a7827b15c7b4.png
https://img-blog.csdnimg.cn/direct/928a58c81cc94d72944a4d076a1f2f56.png
第三步. 设置Demo

使用Java SDK Demo之前,需要首先要Java SDK,包罗证书拷贝以及端口设置,详细请参考这里
# 拷贝证书(假设SDK证书位于~/fisco/nodes/127.0.0.1/sdk目录,请根据实际情况更改路径)
cd dist
cp -r /root/fisco/nodes/127.0.0.1/sdk/* conf

# 拷贝配置文件
# 注:
#   默认搭建的FISCO BCOS区块链系统Channel端口是20200,若修改了该端口,请同步修改config.toml中的配置选项
$ cp conf/config-example.toml conf/config.toml
#由于我的区块链环境具有四个节点,所以应该修改java-sdk-demo/dist/conf/config.toml下的network.peers配置
peers=["127.0.0.1:20200", "127.0.0.1:20201","127.0.0.1:20202","127.0.0.1:20203"]
https://img-blog.csdnimg.cn/direct/a2e6f84377f24346958d6e9c4e3cf284.png
https://img-blog.csdnimg.cn/direct/fc4fec3d86a347c19c4d001c99b4326b.png
https://img-blog.csdnimg.cn/direct/1d4011168e0247cca95795bce682d301.png
https://img-blog.csdnimg.cn/direct/3cbebbf5563d49d894fd0e4e10794829.png
第四步. 执行示例压力测试步调

Java SDK Demo提供了一系列压测步调,包罗串行转账合约压测、并行转账合约压测、AMOP压测等, 具体使用方法如下:
# 进入dist目录
$ cd dist
mkdir -p contracts/solidity

# 将需要转换为java代码的sol文件拷贝到dist/contracts/solidity路径下
# 转换sol, 其中${packageName}是生成的java代码包路径
# 生成的java代码位于 /dist/contracts/sdk/java目录下
$ java -cp "apps/*:lib/*:conf/" org.fisco.bcos.sdk.demo.codegen.DemoSolcToJava
${packageName}

# 压测串行转账合约:
# count: 压测的交易总量
# tps: 压测QPS
# groupId: 压测的群组ID
java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.PerformanceOk




# 压测并行转账合约
# --------------------------
# 基于Solidity并行合约parallelok添加账户:
# groupID: 压测的群组ID
# count: 压测的交易总量
# tps: 压测QPS
# file: 保存生成账户的文件名
$ java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.ParallelOkPerf

# 基于Precompiled并行合约precompiled添加账户
# (参数含义同上)
java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.ParallelOkPerf

# --------------------------
# 基于Solidity并行合约parallelok发起转账交易压测
# groupID: 压测的群组ID
# count: 压测的交易总量
# tps: 压测的QPS
# file: 转账用户文件
$ java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.ParallelOkPerf

# 基于Precompiled并行合约Precompiled发起转账压测
$ java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.ParallelOkPerf



# CRUD合约压测
# 压测CRUD insert
# count: 压测的交易总量
# tps: 压测QPS
# groupId: 压测群组

$ java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.PerformanceTable


# 压测CRUD update
# (参数解释同上)
$ java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.PerformanceTable


# 压测CRUD remove
# (参数解释同上)
$ java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.PerformanceTable


# 压测CRUD query
# (参数解释同上)
$ java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.PerformanceTable

以上对压测合约进行解释,如已经天生设置文件了,就可以直接运行下面的代码
https://img-blog.csdnimg.cn/direct/72d4ce4d3d8f41ae9f17d71ba8ee5826.png
然后下面是对合约进行运行
cd ~/java-sdk-demo/dist
java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.PerformanceOk


java -cp 'conf/:lib/*:apps/*' org.fisco.bcos.sdk.demo.perf.PerformanceOk 10000 1000 1
#200000代表总测试量为10000   1000代表每秒向区块链系统发送1000次请求   1代表区块链系统的groupId
https://img-blog.csdnimg.cn/direct/c8da62b29974461d9f9aae18754838e4.png
出现以下错误是由于搭链没有启动要先启动链
https://img-blog.csdnimg.cn/direct/b9b1724d044e4520a897ed7b567f45c2.png
bash start_all.sh
https://img-blog.csdnimg.cn/direct/4f58203d98f84562919e65cf90120592.png
自定义压测代码

压测自定义合约的开辟均在Java SDK Demo中进行,我们需要开辟三个文件,分别是: 待压测的智能合约:HelloWorld.sol
待压测的智能合约所编译出的Java类:HelloWorld.java
压力测试步调:PerformanceHelloWorld.java
项目的存放路径

https://img-blog.csdnimg.cn/direct/6202c766ae084425b1d5d52405490458.png
首先编译Helloworld.sol文件
创建 contracts/solidity文件
cd ~/java-sdk-demo/dist
mkdir -p contracts/solidity
https://img-blog.csdnimg.cn/direct/0b66e1c397c94a0ea63622d0cb6baa0a.png
天生Helloworld.sol文件
cd contracts/solidity
vim HelloWorld.sol
#生成以上Helloworld智能合约完成简单的获取和设置name功能


pragma solidity >=0.4.24 <0.6.11;

contract HelloWorld {
    string public name;

    constructor() public {
      name = "Hello, World!";
    }

    function get() public view returns (string memory) {
      return name;
    }

    function set(string memory n) public {
      name = n;
    }
}
学习计划安排

https://img-blog.csdnimg.cn/8bb5de58644d4dbc8bf419bd78b38454.png
我一共划分了六个阶段,但并不是说你得学完全部才气上手工作,对于一些低级岗位,学到第三四个阶段就足矣~
这里我整合并且整理成了一份【282G】的网络安全从零基础入门到进阶资料包,需要的小同伴可以扫描下方CSDN官方合作二维码免费领取哦,无偿分享!!!
假如你对网络安全入门感兴趣,那么你需要的话可以
点击这里
页: [1]
查看完整版本: 区块链安全应用-------压力测试