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

打印 上一主题 下一主题

主题 967|帖子 967|积分 2901

通过Caliper举行压力测试步伐

1.环境配置

第一步. 配置基本环境



  • 摆设Caliper的盘算机须要有外网权限;
  • 操作系统版本须要满足以下要求:Ubuntu >= 16.04、CentOS >= 7或MacOS >= 10.14;
  • 摆设Caliper的盘算机须要安装有以下软件:python 2.7、make、g++、gcc及git。
第二步. 安装NodeJS

版本要求:


  • NodeJS 8 (LTS), 9, 或 10 (LTS),Caliper尚未在更高的NodeJS版本中举行过验证。
安装指南:


  • 发起利用nvm(Node Version Manager)安装,nvm的安装方式如下:
起首重新装一个假造机(Ubuntu 20.04 安装教程_ubuntu20.04安装教程-CSDN博客  )
然后在建立root用户

下载curl下令  apt install curl

安装nvm
  1. curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.2/install.sh | bash
  2. # 若出现因网络问题导致长时间下载失败,可尝试以下命令
  3. curl -o- https://gitee.com/mirrors/nvm/raw/v0.33.2/install.sh | bash
复制代码

  1. # 加载nvm配置
  2. source ~/.$(basename $SHELL)rc
复制代码

  1. # 安装Node.js 8
  2. nvm install 8
复制代码

  1. # 使用Node.js 8
  2. nvm use 8
复制代码
 

第三步. 摆设Docker

  1. # 更新包索引
  2. sudo apt-get update
复制代码

  1. # 安装基础依赖库
  2. sudo apt-get install \
  3.     apt-transport-https \
  4.     ca-certificates \
  5.     curl \
  6.     gnupg-agent \
  7.     software-properties-common
复制代码
 

  1. # 添加Docker官方GPG key
  2. curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
复制代码

  1. # 添加docker仓库
  2. sudo add-apt-repository \
  3. "deb [arch=amd64] https://download.docker.com/linux/ubuntu \
  4. $(lsb_release -cs) \
  5. stable"
复制代码

  1. # 更新包索引
  2. sudo apt-get update
复制代码

  1. # 安装Docker
  2. sudo apt-get install docker-ce docker-ce-cli containerd.io
复制代码

第四步. 安装Docker Compose

  1. sudo curl -L "https://github.com/docker/compose/releases/download/1.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
  2. sudo chmod +x /usr/local/bin/docker-compose
复制代码


2. Caliper摆设 

第一步. 摆设

Caliper提供了方便易用的下令行界面工具caliper-cli,保举在当地举行局部安装:
建立一个工作目录
  1. mkdir benchmarks && cd benchmarks
复制代码

对NPM项目举行初始化
  1. npm init
复制代码

 这一步主要是为在工作目录下创建package.json文件以方便后续依靠项的安装,假如不须要填写项目信息的话可以直接执行npm init -y。
  1. 安装caliper-cli
  2. npm install --only=prod @hyperledger/caliper-cli@0.2.0
复制代码

由于Caliper所有依靠项的安装较为耗时,因此利用--only=prod选项用于指定NPM只安装Caliper的核心组件,而不安装其他的依靠项(如各个区块链平台针对Caliper的适配器)。在摆设完成后,可以通过caliper-cli显式绑定须要测试的区块链平台及相应的适配器。
  1. 验证caliper-cli安装成功
  2. npx caliper --version
复制代码
 若安装成功,则会打印相应的版本信息,如:

第二步. 绑定

由于Caliper采用了轻量级的摆设方式,因此须要显式的绑定步调指定要测试的平台及适配器版本,caliper-cli会主动举行相应依靠项的安装。利用npx caliper bind下令举行绑定,下令所需的各项参数可以通过如下下令查看:
  1. npx caliper bind --help
复制代码

–caliper-bind-sut :用于指定须要测试的区块链平台,即受测系统(***S***ystem ***u***nder ***T***est);
–caliper-bind-sdk:用于指定适配器版本;
–caliper-bind-cwd:用于绑定caliper-cli的工作目录,caliper-cli在加载配置文件等场所时均是利用相对于工作目录的相对路径;
–caliper-bind-args:用于指定caliper-cli在安装依靠项时传递给npm的参数,如用于全局安装的-g。
对于FISCO BCOS,可以采用如下方式举行绑定:
  1. npx caliper bind --caliper-bind-sut fisco-bcos --caliper-bind-sdk latest
复制代码
 

遇到以上标题第一种可以直接在下令行前面加上sudo
第二种:重新下载nodejs以及npm
  1. sudo apt-get install nodejs npm
复制代码

然后在重新运行
  1. sudo npx caliper bind --caliper-bind-sut fisco-bcos --caliper-bind-sdk latest
复制代码

第三步. 快速体验FISCO BCOS基准测试

为方便测试职员快速上手,FISCO BCOS已经为Caliper提供了一组预定义的测试样例,测试对象涵盖HelloWorld合约、Solidity版转账合约及预编译版转账合约。同时在测试样例中,Caliper测试脚本会利用docker在当地主动摆设及运行4个互连的节点组成的链,因此测试职员无需手工搭链及编写测试用例便可直接运行这些测试样例。
在工作目录下下载预定义测试用例
  1. git clone https://github.com/vita-dounai/caliper-benchmarks.git
复制代码
  1. 注意 若出现网络问题导致的长时间拉取代码失败,则尝试以下方式:
  2. # 拉取gitee代码
  3. git clone https://gitee.com/vita-dounai/caliper-benchmarks.git
复制代码

执行HelloWorld合约测试
  1. npx caliper benchmark run --caliper-workspace caliper-benchmarks --caliper-benchconfig benchmarks/samples/fisco-bcos/helloworld/config.yaml  --caliper-networkconfig networks/fisco-bcos/4nodes1group/fisco-bcos.json
复制代码
遇到以下错误: 

由于FISCO BCOS对于caliper 0.2.0版本的适配存在部分不兼容情况,须要手动按照(https://github.com/FISCO-BCOS/FISCO-BCOS/issues/1248)中的步调修改代码后方可正常运行。
此报错须要修改源码才能解决:
更改1:
绿色为新增的代码,赤色为源代码,须要删除。
文件位置:/node_modules/@hyperledger/caliper-fisco-bcos/lib/fiscoBcos.js


绿色信息增加第一段:
  1. if (this.fiscoBcosSettings.network && this.fiscoBcosSettings.network.authentication) {
  2.     for (let k in this.fiscoBcosSettings.network.authentication) {            
  3.        this.fiscoBcosSettings.network.authentication[k] = CaliperUtils.resolvePath(this.fiscoBcosSettings.network.authentication[k], workspace_root);
  4.        }
  5. }
复制代码
绿色信息增加第二段:
  1. const fiscoBcosSettings = this.fiscoBcosSettings;
复制代码

更改二:
变更文件一:绿色为新增的代码,赤色为源代码,须要删除。
文件位置:/node_modules/@hyperledger/caliper-fisco-bcos/lib/channelPromise.js


绿色增加代码:
  1. let emitter = emitters.get(seq); if(!emitter) {
  2.         //Stale message receieved
  3.         return;
  4.     } emitter = emitter.emitter;  
复制代码
 

变更文件二:绿色为新增的代码,赤色为源代码,须要删除。 文件位置:packages/caliper-fisco-bcos/lib/fiscoBcos.js
绿色增加代码:
  1. const Color = require('./common').Color;
复制代码

 

变更文件三:绿色为新增的代码,赤色为源代码,须要删除。

文件位置:/node_modules/@hyperledger/caliper-fisco-bcos/lib/web3lib/web3sync.js

27行绿色增加代码:
  1. uuid = '0x' + uuid.replace(/-/g, '');
复制代码
 

91行绿色增加代码:
  1. extraData: '0x0'
复制代码
 

118行绿色增加代码:
  1. extraData: '0x0'
复制代码

错误2:
 指定secp256k1依靠包时版本限定没写对,导致在绑定时主动安装了4.0版本的secp256k1包,但是最新的4.0的包API全部变了,导致执行出错。
有一个暂时的解决方案,进入node_modules/@hyperledger/caliper-fisco-bcos目录,编辑该目录下的package.json文件,在"dependencies"中添加一项"secp256k1": “^3.8.0”,随后在该目录下执行npm i,更新完成后测试步伐就能启动了。


利用npm i 的时候会出现node和npm版本号兼容的标题

 

可以升级node的版本号,利用nvm安装node14
  1. nvm install v14.19.0
复制代码

然后在重新运行npm i

重新执行HelloWorld合约测试
  1. cd benchmarks/
复制代码
  1. npx caliper benchmark run --caliper-workspace caliper-benchmarks --caliper-benchconfig benchmarks/samples/fisco-bcos/helloworld/config.yaml  --caliper-networkconfig networks/fisco-bcos/4nodes1group/fisco-bcos.json
复制代码


执行Solidity版转账合约测试

  1. npx caliper benchmark run --caliper-workspace caliper-benchmarks --caliper-benchconfig benchmarks/samples/fisco-bcos/transfer/solidity/config.yaml  --caliper-networkconfig networks/fisco-bcos/4nodes1group/fisco-bcos.json
复制代码




免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

笑看天下无敌手

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表