最新资讯

  • Hyperledger Fabric 2.4.9 环境搭建和 Caliper 0.5.0 测试工具部署教程(Ubuntu)

Hyperledger Fabric 2.4.9 环境搭建和 Caliper 0.5.0 测试工具部署教程(Ubuntu)

2025-05-17 09:00:52 0 阅读

1. 环境准备

本教程基于 VMware 17 Ubuntu 20.04Fabric 2.4.9 环境搭建和 Hyperledger Caliper 0.5.0 部署测试。

1.1. VMware安装

由于 VMware 被 Broadcom 收购,原官网停用,下载 VMware 需要注册 Broadcom 账户,个人觉得比较麻烦,推荐下载链接:

VMware Workstation Pro 17.5.2

VMware 17 安装教程,参考如下链接:

vmware-17虚拟机安装教程(保姆级包含图文讲解,不需注册账户)_vmware17-CSDN博客

1.2. Ubuntu安装

使用清华源下载 ios 镜像文件, Ubuntu 20.04 镜像下载链接:

Ubuntu 20.04

Ubuntu 20.04 安装教程,参考如下链接:

【Linux】Ubuntu 20.04安装教程(图文详解)_ubuntu20.04安装教程-CSDN博客

1.3. 基础环境安装

1.3.1. Git

sudo apt install git -y

安装完成后,查看版本:

git --version

1.3.2. cURL

sudo apt install curl -y

1.3.3. vim

sudo apt install vim -y

1.3.4. jq

sudo apt install jq -y

1.3.5. Docker和Docker-compose

我安装的版本分别为:docker 24.0.7 docker-compose 1.25.0

直接使用 apt 命令安装 docker-compose (并自动安装 docker )即可:

sudo apt install docker-compose

赋予 docker-compose 可执行权限:

sudo chmod +x /usr/bin/docker-compose

安装完成后,查看版本:

docker version
docker-compose version

设置 docker 自动启动:

sudo systemctl enable docker

查看 docker 启动状态:

systemctl status docker

安装 docker 时会添加名为 docker 的用户组,需要将当前的用户添加到用户组 docker 中:

sudo usermod -aG docker $USER

重启系统:

reboot

再次查看 docker 版本,确认 Server 已正常。

更换 docker 镜像源,创建目录 /etc/docker:

sudo mkdir -p /etc/docker

创建并修改 daemon.json 配置文件:

sudo vim /etc/docker/daemon.json

 添加如下内容:

{
    "registry-mirrors": [
    	"https://dockerproxy.cn",
    	"https://docker.1panel.dev",
	    "https://docker.fxxk.dedyn.io",
	    "https://docker.xn--6oq72ry9d5zx.cn",
	    "https://a.ussh.net",
	    "https://docker.zhai.cm",
	    "https://docker.m.daocloud.io",
        "https://docker.nju.edu.cn",
        "https://dockerproxy.com"
    ]
}

重启 docker:

sudo systemctl daemon-reload
sudo systemctl restart docker

查看镜像源是否配置成功:

docker info

1.3.6. Go

Fabric 2.4.9 要求 go 版本: Go 1.18.10 版本及以上

这里我安装的是 Go 1.22.4 ,安装命令:

wget https://dl.google.com/go/go1.22.4.linux-amd64.tar.gz
sudo tar -C /usr/local -zxvf go1.22.4.linux-amd64.tar.gz

配置环境变量,修改 ~/.bashrc 文件:

sudo vim ~/.bashrc

在文件开头添加如下内容:

export GOROOT=/usr/local/go
export PATH=$PATH:$GOROOT/bin

使用 source 命令使之生效:

source ~/.bashrc

查看 go 版本信息:

go env

配置 Modules 和代理:

go env -w GO111MODULE=on
go env -w GOPROXY=https://goproxy.cn,direct

1.3.7. Node.js

为了方便安装和管理 Node.js 的版本,需要先在系统中安装 NVM(Node Version Manager),它是 Node.js 的版本管理软件,可以根据不同的需求在 Node.js 的各个版本之间进行切换。

在安装 Node.js 时, npm 也会跟着一起安装,它是 Node.js 的包管理工具,管理 Node.js 中的第三方依赖。

下载 NVM 的 Gitee 镜像:

git clone https://gitee.com/mirrors/nvm.git ~/.nvm && cd ~/.nvm && git checkout `git describe --abbrev=0 --tags`

执行 install.sh:

./install.sh

创建并修改 .bash_profile 文件:

vim .bash_profile

添加如下内容:

export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh" # This loads nvm

使用 source 命令使之生效:

source .bash_profile

验证 NVM 的安装是否成功:

nvm -v

Node.js 的版本要与 Fabric 的版本对应,参考如下图片:

我搭建的版本是 Fabric 2.4.9,所以 Node.js 安装 v16 版本:

nvm install v16.13.0

检查 Node.js 和 npm 的版本:

node -v && npm -v

设置镜像源:

npm config set registry https://registry.npmmirror.com/

1.3.8. nvm和npm的使用

(1)nvm

查看当前使用的 Node.js 版本:

nvm current

查看所有已安装的 Node.js 版本:

nvm ls

切换 Node.js 版本:

nvm use v16.13.0

(2)npm

列出 npm 当前的所有配置:

npm config list

查看配置的镜像源:

npm config get registry

2. Fabric 2.4.9搭建

2.1. 下载Fabric源码

进入 ~ 目录:

cd

创建如下目录:

mkdir -p go/src/github.com/hyperledger/

进入该目录:

cd go/src/github.com/hyperledger/

从 github 上拉取 Fabric 的源码:

git clone https://github.com/hyperledger/fabric.git

2.2. 执行bootstrap.sh脚本

进入如下目录:

cd ~/go/src/github.com/hyperledger/fabric/scripts

打开如下链接:https://github.com/hyperledger/fabric/blob/main/scripts/bootstrap.sh,这里的 bootstrap.sh 脚本显示的是最新版本的 Fabric ,在右边的历史中找到我们所需要的版本 Fabric 2.4.9 ,如下所示:

下载对应版本的 bootstrap.sh 文件,然后用该文件替换掉当前目录中的 bootstrap.sh 文件(或者将下面的内容直接复制到 bootstrap.sh 文件中), Fabric 2.4.9 版本的 bootstrap.sh 文件的内容如下:

#!/bin/bash
#
# Copyright IBM Corp. All Rights Reserved.
#
# SPDX-License-Identifier: Apache-2.0
#

# if version not passed in, default to latest released version
VERSION=2.4.9
# if ca version not passed in, default to latest released version
CA_VERSION=1.5.5

REGISTRY=${FABRIC_DOCKER_REGISTRY:-docker.io/hyperledger}

OS=$(uname -s|tr '[:upper:]' '[:lower:]'|sed 's/mingw64_nt.*/windows/')
ARCH=$(uname -m | sed 's/x86_64/amd64/g' | sed 's/aarch64/arm64/g')
PLATFORM=${OS}-${ARCH}

# Fabric < 1.2 uses uname -m for architecture.
MARCH=$(uname -m)

: ${CONTAINER_CLI:="docker"}

printHelp() {
    echo "Usage: bootstrap.sh [version [ca_version]] [options]"
    echo
    echo "options:"
    echo "-h : this help"
    echo "-d : bypass docker image download"
    echo "-s : bypass fabric-samples repo clone"
    echo "-b : bypass download of platform-specific binaries"
    echo
    echo "e.g. bootstrap.sh 2.4.9 1.5.5 -s"
    echo "will download docker images and binaries for Fabric v2.4.9 and Fabric CA v1.5.5"
}

# dockerPull() pulls docker images from fabric and chaincode repositories
# note, if a docker image doesn't exist for a requested release, it will simply
# be skipped, since this script doesn't terminate upon errors.

dockerPull() {
    #three_digit_image_tag is passed in, e.g. "1.4.7"
    three_digit_image_tag=$1
    shift
    #two_digit_image_tag is derived, e.g. "1.4", especially useful as a local tag for two digit references to most recent baseos, ccenv, javaenv, nodeenv patch releases
    two_digit_image_tag=$(echo "$three_digit_image_tag" | cut -d'.' -f1,2)
    while [[ $# -gt 0 ]]
    do
        image_name="$1"
        echo "====>  ${REGISTRY}/fabric-$image_name:$three_digit_image_tag"
        ${CONTAINER_CLI} pull "${REGISTRY}/fabric-$image_name:$three_digit_image_tag"
        ${CONTAINER_CLI} tag "${REGISTRY}/fabric-$image_name:$three_digit_image_tag" "${REGISTRY}/fabric-$image_name"
        ${CONTAINER_CLI} tag "${REGISTRY}/fabric-$image_name:$three_digit_image_tag" "${REGISTRY}/fabric-$image_name:$two_digit_image_tag"
        shift
    done
}

cloneSamplesRepo() {
    # clone (if needed) hyperledger/fabric-samples and checkout corresponding
    # version to the binaries and docker images to be downloaded
    if [ -d test-network ]; then
        # if we are in the fabric-samples repo, checkout corresponding version
        echo "==> Already in fabric-samples repo"
    elif [ -d fabric-samples ]; then
        # if fabric-samples repo already cloned and in current directory,
        # cd fabric-samples
        echo "===> Changing directory to fabric-samples"
        cd fabric-samples
    else
        echo "===> Cloning hyperledger/fabric-samples repo"
        git clone -b main https://github.com/hyperledger/fabric-samples.git && cd fabric-samples
    fi

    if GIT_DIR=.git git rev-parse v${VERSION} >/dev/null 2>&1; then
        echo "===> Checking out v${VERSION} of hyperledger/fabric-samples"
        git checkout -q v${VERSION}
    else
        echo "fabric-samples v${VERSION} does not exist, defaulting to main. fabric-samples main branch is intended to work with recent versions of fabric."
        git checkout -q main
    fi
}

# This will download the .tar.gz
download() {
    local BINARY_FILE=$1
    local URL=$2
    echo "===> Downloading: " "${URL}"
    curl -L --retry 5 --retry-delay 3 "${URL}" | tar xz || rc=$?
    if [ -n "$rc" ]; then
        echo "==> There was an error downloading the binary file."
        return 22
    else
        echo "==> Done."
    fi
}

pullBinaries() {
    echo "===> Downloading version ${FABRIC_TAG} platform specific fabric binaries"
    download "${BINARY_FILE}" "https://github.com/hyperledger/fabric/releases/download/v${VERSION}/${BINARY_FILE}"
    if [ $? -eq 22 ]; then
        echo
        echo "------> ${FABRIC_TAG} platform specific fabric binary is not available to download <----"
        echo
        exit
    fi

    echo "===> Downloading version ${CA_TAG} platform specific fabric-ca-client binary"
    download "${CA_BINARY_FILE}" "https://github.com/hyperledger/fabric-ca/releases/download/v${CA_VERSION}/${CA_BINARY_FILE}"
    if [ $? -eq 22 ]; then
        echo
        echo "------> ${CA_TAG} fabric-ca-client binary is not available to download  (Available from 1.1.0-rc1) <----"
        echo
        exit
    fi
}

pullDockerImages() {
    command -v ${CONTAINER_CLI} >& /dev/null
    NODOCKER=$?
    if [ "${NODOCKER}" == 0 ]; then
        FABRIC_IMAGES=(peer orderer ccenv tools)
        case "$VERSION" in
        2.*)
            FABRIC_IMAGES+=(baseos)
            shift
            ;;
        esac
        echo "FABRIC_IMAGES:" "${FABRIC_IMAGES[@]}"
        echo "===> Pulling fabric Images"
        dockerPull "${FABRIC_TAG}" "${FABRIC_IMAGES[@]}"
        echo "===> Pulling fabric ca Image"
        CA_IMAGE=(ca)
        dockerPull "${CA_TAG}" "${CA_IMAGE[@]}"
        echo "===> List out hyperledger docker images"
        ${CONTAINER_CLI} images | grep hyperledger
    else
        echo "========================================================="
        echo "${CONTAINER_CLI} not installed, bypassing download of Fabric images"
        echo "========================================================="
    fi
}

DOCKER=true
SAMPLES=true
BINARIES=true

# Parse commandline args pull out
# version and/or ca-version strings first
if [ -n "$1" ] && [ "${1:0:1}" != "-" ]; then
    VERSION=$1;shift
    if [ -n "$1" ]  && [ "${1:0:1}" != "-" ]; then
        CA_VERSION=$1;shift
        if [ -n  "$1" ] && [ "${1:0:1}" != "-" ]; then
            THIRDPARTY_IMAGE_VERSION=$1;shift
        fi
    fi
fi

# prior to 1.2.0 architecture was determined by uname -m
if [[ $VERSION =~ ^1.[0-1].* ]]; then
    export FABRIC_TAG=${MARCH}-${VERSION}
    export CA_TAG=${MARCH}-${CA_VERSION}
    export THIRDPARTY_TAG=${MARCH}-${THIRDPARTY_IMAGE_VERSION}
else
    # starting with 1.2.0, multi-arch images will be default
    : "${CA_TAG:="$CA_VERSION"}"
    : "${FABRIC_TAG:="$VERSION"}"
    : "${THIRDPARTY_TAG:="$THIRDPARTY_IMAGE_VERSION"}"
fi

# Prior to fabric 2.5, use amd64 binaries on darwin-arm64
if [[ $VERSION =~ ^2.[0-4].* ]]; then
  PLATFORM=$(echo $PLATFORM | sed 's/darwin-arm64/darwin-amd64/g')
fi

BINARY_FILE=hyperledger-fabric-${PLATFORM}-${VERSION}.tar.gz
CA_BINARY_FILE=hyperledger-fabric-ca-${PLATFORM}-${CA_VERSION}.tar.gz

# then parse opts
while getopts "h?dsb" opt; do
    case "$opt" in
        h|?)
            printHelp
            exit 0
            ;;
        d)  DOCKER=false
            ;;
        s)  SAMPLES=false
            ;;
        b)  BINARIES=false
            ;;
    esac
done

if [ "$SAMPLES" == "true" ]; then
    echo
    echo "Clone hyperledger/fabric-samples repo"
    echo
    cloneSamplesRepo
fi
if [ "$BINARIES" == "true" ]; then
    echo
    echo "Pull Hyperledger Fabric binaries"
    echo
    pullBinaries
fi
if [ "$DOCKER" == "true" ]; then
    echo
    echo "Pull Hyperledger Fabric docker images"
    echo
    pullDockerImages
fi

执行 bootstrap.sh 脚本:

./bootstrap.sh

执行 bootstrap.sh 脚本,主要会做以下3步:1. 克隆 fabric samples 的代码;2. 下载 fabric 和 fabric-ca 的二进制文件;3. 拉取 fabric 所需要的一些镜像 image 。由于直接执行 bootstrap.sh 脚本文件很有可能会出现卡死的问题或者由于网络问题而无法连接的问题,第一步一般都没有问题,主要是第二步和第三步,对于第二步,可以采用手动下载的方式,挂个梯子去 github 官网下载 fabric 和 fabric-ca 编译后的压缩包,这样速度就很快,然后将压缩包直接拖入虚拟机中,最后将其存放在当前目录下,即:~/go/src/github.com/hyperledger/fabric/scripts

如果出现下载很慢或者网络连接超时等问题,按下 Ctrl+C 键结束命令的执行,继续下面的步骤。

此时检查一下当前 scripts 目录下是否存在 fabric-samples 目录,如果存在,继续下面的步骤,如果不存在就继续重新执行 bootstrap.sh 脚本直至生成该目录。

我下载的版本分别是 fabric 2.4.9fabric-ca 1.5.5 ,在如下链接中找到对应版本下载即可:

fabric:

Releases · hyperledger/fabric · GitHub

fabric-ca:

Releases · hyperledger/fabric-ca · GitHub

 点击 Assets ,下载对应版本:

将这两个压缩包解压到 fabric-samples 目录下:

sudo tar -zxvf hyperledger-fabric-linux-amd64-2.4.9.tar.gz -C ~/go/src/github.com/hyperledger/fabric/scripts/fabric-samples
sudo tar -zxvf hyperledger-fabric-ca-linux-amd64-1.5.5.tar.gz -C ~/go/src/github.com/hyperledger/fabric/scripts/fabric-samples

再次执行 bootstrap.sh 脚本:

./bootstrap.sh -sb

在上面命令中,参数 -sb ,其中 s 表示不执行第一步,即不克隆 fabric-samples 的代码, b 表示不执行第二步,即不下载 fabric 和 fabric-ca 的二进制文件,由于在前面的步骤中我们完成了第一步和第二步,所以只需要执行第三步就可以了,即拉取 fabric 所需的一些镜像 image 。

将 fabric-samples 目录下的 bin 目录添加到 PATH 环境变量中,首先修改 ~/.bashrc 文件:

sudo vim ~/.bashrc

在文件开头添加如下内容:

export PATH=$HOME/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/bin:$PATH

使用 source 命令使之生效:

source ~/.bashrc

验证环境变量是否配置成功:

peer version

2.3. 启动测试网络

进入 test-network 目录:

cd fabric-samples/test-network

2.3.1. 启动网络

sudo ./network.sh up

如果想要关闭网络,执行如下命令:

sudo ./network.sh down

2.3.2. 创建通道

sudo ./network.sh createChannel

注意:通道默认的名字是: mychannel ,也可以使用 -c 来指定通道名称,以下命令将创建一个名为 channel1 的通道:

sudo ./network.sh createChannel -c Channel1

通道创建成功,结果如下所示:

2.3.3. 启动链码

首先配置环境变量,修改 ~/.bashrc 文件:

vim ~/.bashrc

在文件开头添加如下内容:

alias sudo='sudo env PATH=$PATH LD_LIBRARY_PATH=$LD_LIBRARY_PATH'

 使用 source 命令使之生效:

source ~/.bashrc

我们要部署的链码是 go 语言编写的代码,在 chaincode-go 目录下,执行以下命令下载相关依赖:

cd ../asset-transfer-basic/chaincode-go
go mod vendor

结果如下所示:

然后回到 test-network 目录,执行启动链码命令,在 mychannel 通道启动一个链码:

sudo ./network.sh deployCC -ccn basic -ccp ../asset-transfer-basic/chaincode-go -ccl go

注意:如果通道名称不是 mychannel ,在命令中添加 -c 通道名称,表示在该通道上部署链码,如下命令就是在名为 channel1 的通道上部署链码:

sudo ./network.sh deployCC -c channel1 -ccn basic -ccp ../asset-transfer-basic/chaincode-go -ccl go

链码启动成功,结果如下所示:

2.3.4. 与网络交互

由于接下来的操作需要管理员权限,所以执行如下命令,进入 root 用户:

sudo su

在启用测试网络后,可以使用 peer cli 客户端与网络进行交互,通过 peer cli 客户端可以调用已部署的智能合约,更新通道,或安装和部署新的智能合约。

执行以下命令将 cli 客户端添加到环境变量中:

export PATH=${PWD}/../bin:$PATH

将 fabric-samples 代码库中的 FABRIC_CFG_PATH 设置为指向其中的 core.yaml 文件:

export FABRIC_CFG_PATH=$PWD/../config/

设置允许 org1 操作 peer cli 的环境变量:

export CORE_PEER_TLS_ENABLED=true
export CORE_PEER_LOCALMSPID="Org1MSP"
export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt
export CORE_PEER_MSPCONFIGPATH=${PWD}/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp
export CORE_PEER_ADDRESS=localhost:7051

CORE_PEER_TLS_ROOTCERT_FILE 和 CORE_PEER_MSPCONFIGPATH 环境变量指向 Org1 的 organizations 文件夹中的的加密材料。

执行以下命令用一些资产来初始化账本:

peer chaincode invoke -o localhost:7050 --ordererTLSHostnameOverride orderer.example.com --tls --cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem -C mychannel -n basic --peerAddresses localhost:7051 --tlsRootCertFiles ${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt --peerAddresses localhost:9051 --tlsRootCertFiles ${PWD}/organizations/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt -c '{"function":"InitLedger","Args":[]}'

执行成功会返回 Chaincode invoke successful. result: status:200 如下图所示:

执行以下指令来查询通道账本中的资产列表: 

peer chaincode query -C mychannel -n basic -c '{"Args":["GetAllAssets"]}'

结果如下图所示,说明测试网络操作成功:

修改资产所有者,将 asset1 资产的所有者修改为 IDY:

peer chaincode invoke -o localhost:7050 --ordererTLSHostnameOverride orderer.example.com --tls --cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem -C mychannel -n basic --peerAddresses localhost:7051 --tlsRootCertFiles ${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt --peerAddresses localhost:9051 --tlsRootCertFiles ${PWD}/organizations/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt -c '{"function":"TransferAsset","Args":["asset1","IDY"]}'

 执行成功后的结果:

查看修改后的结果:

peer chaincode query -C mychannel -n basic -c '{"Args":["GetAllAssets"]}'

到这里 Fabric 2.4.9 的搭建和测试就完成了,接下来是 Caliper 0.5.0 的部署和测试。

3. Caliper 0.5.0部署和测试

3.1. Caliper安装

3.1.1. 创建Caliper工作区

在 fabric-samples 目录的同一级别创建一个名为 caliper-workspace 的文件夹,然后在 caliper-workspace 文件夹中,分别创建三个名为 networks 、 benchmarks 和 workload 的文件夹:

mkdir -p caliper-workspace/{networks,benchmarks,workload}

如下所示:

3.1.2. 初始化项目

在 caliper-workspace 目录中初始化项目:

cd caliper-workspace && npm init -y

执行完后,在当前目录生成了 package.json 文件。

3.1.3. 安装caliper-cli

在 caliper-workspace 目录中,使用以下终端命令安装 caliper CLI:

npm install --only=prod @hyperledger/caliper-cli@0.5.0

执行完后,会将依赖下载到当前目录下的 node_modules 文件下。

验证 caliper-cli 是否安装成功:

npx caliper --version

3.1.4. 绑定Fabric 2.4

npx caliper bind --caliper-bind-sut fabric:2.4

3.2. 构建网络配置文件

在低版本中采用的是 .json 文件,而在新版本中需要采用 .yaml 文件,在 networks 文件夹下创建一个名为 networkConfig.yaml 的文件:

cd networks && touch networkConfig.yaml

添加如下内容:

name: Caliper Benchmarks
version: "2.0.0"

caliper:
  blockchain: fabric

channels:
  - channelName: mychannel
    contracts:
    - id: basic

organizations:
  - mspid: Org1MSP
    identities:
      certificates:
      - name: 'Admin@org1.example.com'
        clientPrivateKey:
          path: '../fabric-samples/test-network/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp/keystore/priv_sk'
        clientSignedCert:
          path: '../fabric-samples/test-network/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp/signcerts/Admin@org1.example.com-cert.pem'
    connectionProfile:
      path: '../fabric-samples/test-network/organizations/peerOrganizations/org1.example.com/connection-org1.yaml'
      discover: true

3.3. 构建测试工作负载模块

在 workload 文件夹中,创建一个名为 readAsset.js 的文件:

cd ../workload && touch readAsset.js

添加如下内容:

'use strict';

const { WorkloadModuleBase } = require('@hyperledger/caliper-core');

class MyWorkload extends WorkloadModuleBase {
    constructor() {
        super();
    }
    
    async initializeWorkloadModule(workerIndex, totalWorkers, roundIndex, roundArguments, sutAdapter, sutContext) {
        await super.initializeWorkloadModule(workerIndex, totalWorkers, roundIndex, roundArguments, sutAdapter, sutContext);

        for (let i=0; i

3.4. 构建基准测试配置文件

在 benchmarks 文件夹下创建一个名为 myAssetBenchmark.yaml 的文件:

cd ../benchmarks && touch myAssetBenchmark.yaml

添加如下内容:

test:
    name: basic-contract-benchmark
    description: test benchmark
    workers:
      type: local
      number: 2
    rounds:
      - label: readAsset
        description: Read asset benchmark
        txDuration: 30
        rateControl: 
          type: fixed-load
          opts:
            transactionLoad: 2
        workload:
          module: workload/readAsset.js
          arguments:
            assets: 10
            contractId: basic
monitors:
  resource:
  - module: docker
    options:
      interval: 5 
      containers:
      - all

3.5. 运行Caliper基准测试

npx caliper launch manager --caliper-workspace ./ --caliper-networkconfig networks/networkConfig.yaml --caliper-benchconfig benchmarks/myAssetBenchmark.yaml --caliper-flow-only-test --caliper-fabric-gateway-enabled --caliper-fabric-gateway-discovery

如果出现如下错误:

错误信息:

2024.10.21-20:52:36.860 error [caliper] [caliper-engine] Error while performing "test" step: Error: EACCES: permission denied, open '/home/idy/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/test-network/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp/keystore/priv_sk'

这个错误是没有权限,无法打开 priv_sk 文件,执行如下命令授予权限: 

chmod 666 ~/go/src/github.com/hyperledger/fabric/scripts/fabric-samples/test-network/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp/keystore/priv_sk

成功执行启动基准测试命令后,在 caliper-workspace 目录下生成 report.html 的性能测试报告。

还可以测试 CPU Memory 等资源的消耗情况。

4. 参考资料

(1)

Hyperledger Fabric 入门笔记(三)Fabric V2.5 环境搭建_fabric_荆棘鸟骑士-开放原子开发者工作坊 (csdn.net)

(2)

​​​​​​记录搭建 区块链Hyperledger Fabric2.5.4版本环境 - 知乎 (zhihu.com) 

(3)

超级账本Fabric 2.x 详细安装步骤及可能问题解决方式-CSDN博客

(4)
https://github.com/hyperledger/fabric-samples/issues/1097

(5)

Fabric 2.2.0上搭建Hyperledger caliper进行性能测试_fabric caliper-CSDN博客

(6)

超级账本Fabric2.x 如何将智能合约部署到通道_fabric2.x部署-CSDN博客

(7)

解决超级账本测试网络配置中 Cannot run peer because error when setting up MSP of type bccsp from directory 的问题-CSDN博客

(8)

Hyperledger Fabric v2.4.9环境搭建和Caliper 0.5.0测试工具部署教程(MacOS)

(9)

Hyperledger fabric 2.4.9搭建与caliper性能测试

(10)

https://hyperledger-fabric.readthedocs.io/zh-cn/release-2.5/

(11)

hyperledger caliper的使用(以Hyperledger Fabric为例) - TR_Goldfish - 博客园

本文地址:https://www.vps345.com/11008.html

搜索文章

Tags

PV计算 带宽计算 流量带宽 服务器带宽 上行带宽 上行速率 什么是上行带宽? CC攻击 攻击怎么办 流量攻击 DDOS攻击 服务器被攻击怎么办 源IP docker 容器 运维 java-rabbitmq java 服务器安全 网络安全策略 防御服务器攻击 安全威胁和解决方案 程序员博客保护 数据保护 安全最佳实践 服务器 linux 游戏 云计算 Deepseek Deepseek-R1 大模型 私有化部署 推理模型 网络工程师 网络管理 软考 2024 2024年上半年 下午真题 答案 deepseek DeepSeek-R1 API接口 c++ 神经网络 人工智能 深度学习 计算机视觉 卷积神经网络 javascript 前端 chrome edge 数据库 centos oracle 关系型 安全 分布式 harmonyos 华为 物联网 ubuntu python 机器学习 ssh redis DNS ddos android 网络安全 web安全 YOLO conda pytorch vscode yolov5 gcc centos 7 网络 tcp/ip 网络协议 ip协议 自动化 c语言 springsecurity6 oauth2 授权服务器 前后端分离 英语 RTSP xop RTP RTSPServer 推流 视频 vue.js spring boot nginx 进程 操作系统 进程控制 Ubuntu macos windows Ollama Qwen2.5-coder 离线部署 CH340 单片机 嵌入式硬件 串口驱动 CH341 uart 485 flutter Google pay Apple pay 模型联网 API CherryStudio fstab arm开发 架构 Flask FastAPI Waitress Gunicorn uWSGI Uvicorn 阿里云 llama 算法 opencv 自然语言处理 语言模型 经验分享 笔记 C 环境变量 进程地址空间 django unix oracle fusion oracle中间件 学习 学习方法 mysql adb stm32 ROS 自动驾驶 FTP服务器 gnu 负载均衡 https pycharm ide kubernetes prometheus grafana 云原生 游戏引擎 ai nlp 数据库系统 指令 远程桌面 php 开发语言 typescript 计算机网络 tomcat Ubuntu20.04 GLIBC 2.35 ui MacMini Mac 迷你主机 mini Apple ipython intellij-idea 网络结构图 MCP ip spring cloud compose 持续部署 deepseek-r1 大模型本地部署 devops 智能路由器 dell服务器 服务器无法访问 ip地址无法访问 无法访问宝塔面板 宝塔面板打不开 AIGC 人工智能生成内容 Dify Ubuntu DeepSeek DeepSeek Ubuntu DeepSeek 本地部署 DeepSeek 知识库 DeepSeek 私有化知识库 本地部署 DeepSeek DeepSeek 私有化部署 apache 数据分析 jvm 虚拟机 交互 程序 编程 内存 性能分析 vue3 excel 在线预览 xlsx xls文件 在浏览器直接打开解析xls表格 前端实现vue3打开excel 文件地址url或接口文档流二进 开源 milvus c# centos-root /dev/mapper yum clean all df -h / du -sh audio vue音乐播放器 vue播放音频文件 Audio音频播放器自定义样式 播放暂停进度条音量调节快进快退 自定义audio覆盖默认样式 outlook 错误代码2603 无网络连接 2603 vite agi qt arm 科技 个人开发 计算机外设 bug node.js virtualenv dify 知识库 本地化部署 react.js 前端面试题 UEFI Legacy MBR GPT U盘安装操作系统 部署 像素流送api 像素流送UE4 像素流送卡顿 像素流送并发支持 ansible 教程 环境搭建 Java Maven 后端 开发环境 面试 mcu AI-native gpt maxkb ARG fastapi mcp mcp-proxy mcp-inspector fastapi-mcp agent sse 华为云 华为od opengl 目标检测 小程序 微信小程序域名配置 微信小程序服务器域名 微信小程序合法域名 小程序配置业务域名 微信小程序需要域名吗 微信小程序添加域名 JDK LInux Windows jenkins gitee github ffmpeg 音视频 视频编解码 pip C语言 asm Linux xrdp 远程连接 python2 ubuntu24.04 jellyfin nas word图片自动上传 word一键转存 复制word图片 复制word图文 复制word公式 粘贴word图文 粘贴word公式 http flask k8s YOLOv8 NPU Atlas800 A300I pro asi_bench ACL 流量控制 基本ACL 规则配置 数据结构 并查集 leetcode uni-app 上传视频文件到服务器 uniApp本地上传视频并预览 uniapp移动端h5网页 uniapp微信小程序上传视频 uniapp app端视频上传 uniapp uview组件库 虚拟显示器 远程控制 大数据 spark hive udp 本地环回 bind 数据挖掘 ubuntu 18.04 安装教程 debian PVE 多线程服务器 Linux网络编程 鸿蒙 快捷键 旋转屏幕 自动操作 websocket golang 虚拟现实 kafka AI大模型 大模型技术 本地部署大模型 grub 版本升级 扩容 VMware WSL2 IP 地址 mysql离线安装 ubuntu22.04 mysql8.0 Alexnet 银河麒麟 目标跟踪 OpenVINO 推理应用 远程工作 ArkUI 鸿蒙系统 ArkTS USB转串口 cron crontab日志 sql elasticsearch 性能优化 高级IO epoll filezilla 无法连接服务器 连接被服务器拒绝 vsftpd 331/530 机器人 实时音视频 rpc 外网访问 内网穿透 端口映射 集成学习 集成测试 git npm 缓存 交换机 硬件 设备 GPU PCI-Express AI编程 rust腐蚀 svn qps 高并发 asp.net大文件上传 asp.net大文件上传下载 asp.net大文件上传源码 ASP.NET断点续传 程序人生 vnc 镜像源 策略模式 burpsuite 安全工具 mac安全工具 burp安装教程 渗透工具 live555 rtsp rtp eureka Linux 维护模式 Hyper-V WinRM TrustedHosts AI HarmonyOS Next vim list 智能体开发 spring 程序员创富 无人机 PX4 多线程 雨云 NPS burp suite 抓包 axure 富文本编辑器 华为认证 环境迁移 cpu 实时 使用 openvpn server openvpn配置教程 centos安装openvpn VMware Tools vmware tools安装 vmwaretools安装步骤 vmwaretools安装失败 vmware tool安装步骤 vm tools安装步骤 vm tools安装后不能拖 vmware tools安装步骤 电子信息 通信工程 信息与通信 毕业 protobuf 序列化和反序列化 安装 pillow 自定义客户端 SAS 串口服务器 安卓模拟器 mac C# MQTTS 双向认证 emqx dubbo 监控k8s集群 集群内prometheus 命名管道 客户端与服务端通信 gpu算力 前端框架 ssl json 爬虫 课程设计 cursor es6 qt6.3 g726 transformer 聚类 nvm EtherCAT转Modbus EtherCAT转485网关 ECT转485串口服务器 ECT转Modbus485协议 ECT转Modbus串口网关 ECT转Modbus串口服务器 移动端开发 FTP 服务器 kylin CPU 使用率 系统监控工具 linux 命令 maven IIS .net core Hosting Bundle .NET Framework vs2022 媒体 Linux PID 服务器配置 生物信息学 1024程序员节 rtsp服务器 rtsp server android rtsp服务 安卓rtsp服务器 移动端rtsp服务 大牛直播SDK 镜像下载 freebsd ubuntu20.04 开机黑屏 TCP WebServer 链表 ollama 命令 mount挂载磁盘 wrong fs type LVM挂载磁盘 Centos7.9 压力测试 大模型压力测试 EvalScope ssh漏洞 ssh9.9p2 CVE-2025-23419 私有化 本地部署 zip unzip 嵌入式 宝塔面板访问不了 宝塔面板网站访问不了 宝塔面板怎么配置网站能访问 宝塔面板配置ip访问 宝塔面板配置域名访问教程 宝塔面板配置教程 统信 NFS react next.js 部署next.js xcode 高效I/O postman 测试工具 perf 图像处理 open webui ue4 着色器 ue5 虚幻 JAVA gitlab unity rocketmq 思科 pygame bash stm32项目 jupyter GPU环境配置 Ubuntu22 CUDA PyTorch Anaconda安装 iftop 网络流量监控 zotero WebDAV 同步失败 代理模式 反向代理 notepad ros ros1 Noetic 20.04 apt 安装 实时互动 LDAP firewall AutoDL p2p windows 服务器安装 EtherNet/IP串口网关 EIP转RS485 EIP转Modbus EtherNet/IP网关协议 EIP转RS485网关 EIP串口服务器 zabbix mariadb 运维开发 桥接模式 vmware windows虚拟机 虚拟机联网 sublime text 编辑器 电脑 NVML nvidia-smi visualstudio n8n 工作流 阻塞队列 生产者消费者模型 服务器崩坏原因 网易邮箱大师 llm DeepSeek Chatbox frp ip命令 新增网卡 新增IP 启动网卡 linux驱动开发 孤岛惊魂4 adobe 防火墙 端口号 开放端口 访问列表 C++ IMM QT 5.12.12 QT开发环境 Ubuntu18.04 Doris搭建 docker搭建Doris Doris搭建过程 linux搭建Doris Doris搭建详细步骤 Doris部署 腾讯云 rag ragflow 大模型部署 系统安全 进程优先级 调度队列 进程切换 matplotlib fonts-noto-cjk rsyslog 虚拟局域网 IM即时通讯 QQ 微信 企业微信 剪切板对通 HTML FORMAT yum docker-compose docker compose hadoop big data 软件需求 IPMI Linux无人智慧超市 LInux多线程服务器 QT项目 LInux项目 单片机项目 edge浏览器 onlyoffice 网络爬虫 efficientVIT YOLOv8替换主干网络 TOLOv8 SSH Xterminal Kali Linux 黑客 渗透测试 信息收集 aws ecmascript nextjs reactjs web3.py 冯诺依曼体系 fork wait waitpid exit 远程过程调用 Windows环境 程序员 大模型入门 网络药理学 生信 gromacs 分子动力学模拟 MD 动力学模拟 多层架构 解耦 华为OD 华为OD机试真题 可以组成网络的服务器 Trae叒更新了? 压测 ECS ssrf 失效的访问控制 HTML audio 控件组件 vue3 audio音乐播放器 Audio标签自定义样式默认 vue3播放音频文件音效音乐 自定义audio播放器样式 播放暂停调整声音大小下载文件 selenium 工具 wsl 信号处理 tcpdump kotlin android studio iphone 大文件分片上传断点续传及进度条 如何批量上传超大文件并显示进度 axios大文件切片上传详细教 node服务器合并切片 vue3大文件上传报错提示错误 vu大文件秒传跨域报错cors 微信分享 Image wxopensdk vmamba database ROS2 GaN HEMT 氮化镓 单粒子烧毁 辐射损伤 辐照效应 Ubuntu22.04 虚拟化 开发人员主页 大模型微调 su sudo sudo原理 su切换 rust jdk 微信小程序 odoo 服务器动作 Server action grep WLAN 创意 社区 db VMware创建虚拟机 rancher 源码剖析 rtsp实现步骤 流媒体开发 langchain deep learning rabbitmq ftp服务 文件上传 Mermaid 可视化图表 自动化生成 Qualcomm WoS Python QNN AppBuilder linux环境变量 shell remote-ssh netty termux microsoft Agent LLM CrewAI 游戏程序 ios yolov8 回显服务器 UDP的API使用 驱动开发 gitea ufw linux内核 升级 CVE-2024-7347 漏洞 nftables 5G dash 正则表达式 RustDesk自建服务器 rustdesk服务器 docker rustdesk React Next.js 开源框架 KylinV10 麒麟操作系统 Vmware lvm 磁盘挂载 磁盘分区 ESP32 camera Arduino 进程程序替换 execl函数 execv函数 execvp函数 execvpe函数 putenv函数 GCC aarch64 编译安装 HPC Ubuntu 22.04 MySql 算家云 算力租赁 ECT转Modbus协议 EtherCAT转485协议 ECT转Modbus网关 VMware安装mocOS macOS系统安装 HP Anyware oceanbase 传统数据库升级 银行 docker run 数据卷挂载 交互模式 webrtc .netcore diskgenius ai小智 语音助手 ai小智配网 ai小智教程 智能硬件 esp32语音助手 diy语音助手 matlab scikit-learn rdp 远程服务 VSCode iot 政务 分布式系统 监控运维 Prometheus Grafana 话题通信 服务通信 内网渗透 靶机渗透 powerpoint 7z kernel 产品经理 OpenCore Cursor Linux Vim Trae IDE AI 原生集成开发环境 Trae AI VPN wireguard linux上传下载 职场和发展 主从复制 硬件工程 嵌入式实习 web openEuler macbook 硅基流动 ChatBox Kylin-Server 国产操作系统 服务器安装 宝塔 Cline css css3 html5 visual studio code 软件工程 软件构建 rc.local 开机自启 systemd 麒麟 智能体 autogen openai coze MobaXterm 文件传输 云电竞 云电脑 todesk 卡死 SRS 流媒体 直播 java-ee 沙盒 需求分析 提示词 VMware安装Ubuntu Ubuntu安装k8s Hive环境搭建 hive3环境 Hive远程模式 常用命令 文本命令 目录命令 webgl Dell R750XS cuda 新盘添加 partedUtil nohup 异步执行 深度求索 私域 DevEco Studio linuxdeployqt 打包部署程序 appimagetool IIS服务器 IIS性能 日志监控 localhost kali 共享文件夹 温湿度数据上传到服务器 Arduino HTTP ocr 毕设 arkUI arkTs 教育电商 3d 数学建模 etcd 数据安全 RBAC clickhouse 报错 Invalid Host allowedHosts vue 系统架构 硬件架构 计算机科学与技术 云原生开发 K8S k8s管理系统 国产数据库 瀚高数据库 数据迁移 下载安装 安全威胁分析 mongodb Maxkb RAG技术 本地知识库 nacos express deepseak 文心一言 豆包 KIMI 腾讯元宝 glibc html iTerm2 RDP MCP server C/S elk rustdesk 匿名管道 进程信号 浪潮信息 AI服务器 CPU 主板 电源 网卡 HCIE 数通 读写锁 intellij idea 区块链 行情服务器 股票交易 速度慢 切换 股票量化接口 股票API接口 tar ollama api ollama外网访问 计算生物学 生物信息 基因组 gateway Clion Nova ResharperC++引擎 Centos7 远程开发 numpy kubeless 实验 智慧农业 开源鸿蒙 团队开发 王者荣耀 微服务 MacOS录屏软件 虚拟机安装 其他 postgresql 大模型教程 智能手机 TrueLicense 宝塔面板无法访问 vr 隐藏文件 VM搭建win2012 win2012应急响应靶机搭建 攻击者获取服务器权限 上传wakaung病毒 应急响应并溯源 挖矿病毒处置 应急响应综合性靶场 webdav samba 互信 vSphere vCenter 软件定义数据中心 sddc miniapp 真机调试 调试 debug 断点 网络API请求调试方法 ruoyi 具身智能 Isaac Sim 虚拟仿真 一切皆文件 Docker Desktop jar tcp eclipse 热榜 WSL2 上安装 Ubuntu MQTT 消息队列 redhat 大语言模型 LLMs jmeter 软件测试 chatgpt oneapi flash-attention 昇腾 大模型训练/推理 推理问题 mindie 安卓 pdf Mac内存不够用怎么办 离线部署dify k8s部署 MySQL8.0 高可用集群(1主2从) vm 灵办AI ci/cd 代码规范 WebUI DeepSeek V3 minicom 串口调试工具 fd 文件描述符 小智 CosyVoice 浏览器自动化 数据采集 Crawlee Playwright log4j kind java-rocketmq 动静态库 华为证书 HarmonyOS认证 华为证书考试 云桌面 微软 AD域控 证书服务器 Netty MAVROS 四旋翼无人机 数据可视化 推荐算法 考试 visual studio x64 SIGSEGV SSE xmm0 export env 变量 支持向量机 c DigitalOcean GPU服务器购买 GPU服务器哪里有 GPU服务器 sqlserver 安全漏洞 信息安全 less ux LLM Web APP Streamlit gunicorn AD域 京东云 nohup后台启动 代码调试 ipdb 双系统 Docker Docker Compose Kubernetes k8s集群资源管理 RAGFLOW go 自动化编程 string模拟实现 深拷贝 浅拷贝 经典的string类问题 三个swap 软件卸载 系统清理 嵌入式系统开发 监控k8s 监控kubernetes 锁屏不生效 MQTT协议 消息服务器 代码 视觉检测 stable diffusion 信号 内核 MS Materials 显示器 curl wget 宠物 毕业设计 免费学习 宠物领养 宠物平台 直播推流 sqlite3 搜索引擎 全文检索 图搜索算法 机柜 1U 2U Windsurf 免密 登录 公钥 私钥 安装MySQL .net wireshark 显示过滤器 ICMP Wireshark安装 webstorm 远程看看 远程协助 copilot ebpf uprobe 知识图谱 强制清理 强制删除 mac废纸篓 多产物 rime 状态管理的 UDP 服务器 Arduino RTOS WSL win11 无法解析服务器的名称或地址 WebVM chatbox 自动化运维 流水线 脚本式流水线 armbian u-boot hosts hosts文件管理工具 开源软件 AI写作 iperf3 带宽测试 gradle xml 加解密 Yakit yaklang ftp 云耀服务器 client-go k8s二次开发 3GPP 卫星通信 统信UOS bonding 链路聚合 执法记录仪 智能安全帽 smarteye vscode1.86 1.86版本 ssh远程连接 TRAE systemctl composer perl 远程 执行 sshpass 操作 桌面环境 iBMC UltraISO windows日志 java-zookeeper openwrt Ubuntu共享文件夹 共享目录 Linux共享文件夹 笔灵AI AI工具 HistoryServer Spark YARN jobhistory 域名服务 DHCP 符号链接 配置 selete 框架搭建 ros2 moveit 机器人运动 换源 国内源 Debian 磁盘监控 环境配置 系统开发 binder 车载系统 framework 源码环境 基础环境 beautifulsoup 实战案例 file server http server web server import save load 迁移镜像 低代码 单例模式 openjdk Mac软件 网络用户购物行为分析可视化平台 大数据毕业设计 v10 软件 EVE-NG Linux权限 权限命令 特殊权限 shell脚本免交互 expect linux免交互 拓扑图 sdkman 系统 黑苹果 top Linux top top命令详解 top命令重点 top常用参数 RAID RAID技术 磁盘 存储 KingBase docker搭建pg docker搭建pgsql pg授权 postgresql使用 postgresql搭建 openstack Xen KVM webpack 大屏端 deepseek-v3 ktransformers word 负载测试 P2P HDLC nac 802.1 portal autoware 强化学习 docker搭建nacos详解 docker部署nacos docker安装nacos 腾讯云搭建nacos centos7搭建nacos UOS 统信操作系统 网卡的名称修改 eth0 ens33 mybatis alias unalias 别名 工具分享 AI作画 源代码管理 僵尸进程 llama3 Chatglm 开源大模型 YOLOv12 ping++ 图文教程 VMware虚拟机 macOS系统安装教程 macOS最新版 虚拟机安装macOS Sequoia 深度优先 图论 并集查找 换根法 树上倍增 NAS Termux Samba 单元测试 mac设置host 图形化界面 Xinference python3.11 mock mock server 模拟服务器 mock服务器 Postman内置变量 Postman随机数据 CLion 迁移指南 CUPS 打印机 Qt5 GRE SWAT 配置文件 服务管理 网络共享 yaml Ultralytics 可视化 gpt-3 用户管理 券商 股票交易接口api 类型 特点 arcgis Redis Desktop 服务器扩容没有扩容成功 矩阵 playbook 剧本 openssl 银河麒麟服务器操作系统 系统激活 NVM Node Yarn PM2 seatunnel 视频平台 录像 视频转发 性能测试 视频流 腾讯云大模型知识引擎 windwos防火墙 defender防火墙 win防火墙白名单 防火墙白名单效果 防火墙只允许指定应用上网 防火墙允许指定上网其它禁止 g++ g++13 工业4.0 底层实现 harmonyOS面试题 ragflow 源码启动 HarmonyOS Tabs组件 TabContent TabBar TabsController 导航页签栏 滚动导航栏 客户端 博客 Portainer搭建 Portainer使用 Portainer使用详解 Portainer详解 Portainer portainer Linux的基础指令 开发 cudnn anaconda DIFY Reactor 设计模式 junit 豆瓣 追剧助手 迅雷 弹性计算 云服务器 裸金属服务器 弹性裸金属服务器 fpga开发 fpga Webserver 异步 CNNs 图像分类 GPU训练 unity3d kylin v10 麒麟 v10 OpenManus 版本 lighttpd安装 Ubuntu配置 Windows安装 服务器优化 高德地图 鸿蒙接入高德地图 HarmonyOS5.0 ESXi HiCar CarLife+ CarPlay QT RK3588 Web服务器 多线程下载工具 网络编程 PYTHON H3C dns ubuntu24.04.1 IO c/c++ 串口 生活 googlecloud vasp安装 大模型应用 模拟实现 云服务 隐藏目录 文件系统 管理器 通配符 图片增强 增强数据 Web应用服务器 中间件 firewalld photoshop 监控 显卡驱动持久化 GPU持久化 threejs 3D okhttp 路径解析 SSH 密钥生成 SSH 公钥 私钥 生成 国产化 个人博客 Kali 渗透 联网 easyconnect 代理 mysql安装报错 windows拒绝安装 权限 电路仿真 multisim 硬件工程师 硬件工程师学习 电路图 电路分析 仪器仪表 磁盘清理 开机自启动 桌面快捷方式 pyside6 界面 umeditor粘贴word ueditor粘贴word ueditor复制word ueditor上传word图片 ueditor导入word ueditor导入pdf ueditor导入ppt 跨平台 命令行 基础入门 firefox kamailio sip VoIP 大数据平台 蓝耘科技 元生代平台工作流 ComfyUI 飞牛nas fnos retry 重试机制 Carla 智能驾驶 springcloud 建站 DevOps 软件交付 数据驱动 应用场景 pyicu 海康 论文阅读 智能电视 zookeeper Cookie Ubuntu 24 常用命令 Ubuntu 24 Ubuntu vi 异常处理 springboot 功能测试 自动化测试 r语言 Github加速 Mac上Github加速 Chrome浏览器插件 bcompare Beyond Compare 鲲鹏 npu mq Ardupilot 视频监控 网站 计算机 CentOS ollama下载加速 sysctl.conf vm.nr_hugepages 单一职责原则 sublime text3 linux安装配置 软链接 硬链接 键盘 DrissionPage 计算机系统 ArkTs 相机 Office Linux的权限 中兴光猫 换光猫 网络桥接 自己换光猫 iis initramfs Linux内核 Grub 移动云 CDN ELF加载 设置代理 实用教程 安防软件 ShapeFile GeoJSON Nginx Docker Hub docker pull daemon.json GameFramework HybridCLR Unity编辑器扩展 自动化工具 管道 数据集 物联网开发 EMQX 通信协议 cnn DenseNet 群晖 kvm qemu libvirt 机架式服务器 1U工控机 国产工控机 YashanDB 崖山数据库 yashandb LORA NLP prompt rpa conda配置 conda镜像源 LVM lvresize 磁盘扩容 pvcreate tensorflow EasyConnect trae 内网环境 RAGFlow 可用性测试 crosstool-ng 稳定性 看门狗 IPv4/IPv6双栈 双栈技术 网路规划设计 ensp综合实验 IPv4过渡IPv6 IPv4与IPv6 黑客技术 Typore 流式接口 URL api 电视剧收视率分析与可视化平台 cd 目录切换 wsl2 servlet DocFlow 空间 查错 minio 文件存储服务器组件 open Euler dde deepin ubuntu24 vivado24 进程间通信 resolv.conf 大文件秒传跨域报错cors cpp-httplib 网工 创业创新 apt 服务器主板 AI芯片 MVS 海康威视相机 docker命令大全 MI300x virtualbox SSL证书 实时内核 分析解读 输入法 xpath定位元素 Echarts图表 折线图 柱状图 异步动态数据 鸿蒙开发 可视化效果 交叉编译 hdc Open WebUI 游戏服务器 TrinityCore 魔兽世界 zerotier gru esp32 蓝牙 文件分享 Helm k8s集群 边缘计算 lsb_release /etc/issue /proc/version uname -r 查看ubuntu版本 RoboVLM 通用机器人策略 VLA设计哲学 vlm fot robot 视觉语言动作模型 技能大赛 雨云服务器 百度云 矩池云 数据下载 数据传输 能力提升 面试宝典 技术 IT信息化 Linux环境 VGG网络 卷积层 池化层 实习 小艺 Pura X 高效日志打印 串口通信日志 服务器日志 系统状态监控日志 异常记录日志 gaussdb 大模型面经 大模型学习 华为机试 saltstack 相差8小时 UTC 时间 终端 图形渲染 d3d12 密码学 商用密码产品体系 源代码 三级等保 服务器审计日志备份 框架 laravel Reactor反应堆 pthread 无桌面 iNode Macos 微信公众平台 risc-v postgres Dify重启后重新初始化 Qwen3 qwen3 32b vllm Ark-TS语言 bootstrap Socket 网络文件系统 匿名FTP 邮件传输代理 SSL支持 chroot监狱技术 VR手套 数据手套 动捕手套 动捕数据手套 scapy can 线程池 glm4 联想开天P90Z装win10 Zoertier 内网组网 wps 金仓数据库 2025 征文 数据库平替用金仓 av1 电视盒子 机顶盒ROM 魔百盒刷机 mamba 录音麦克风权限判断检测 录音功能 录音文件mp3播放 小程序实现录音及播放功能 RecorderManager 解决录音报错播放没声音问题 蓝桥杯 小番茄C盘清理 便捷易用C盘清理工具 小番茄C盘清理的优势尽显何处? 教你深度体验小番茄C盘清理 C盘变红?!不知所措? C盘瘦身后电脑会发生什么变化? 服务器时间 cmos 充电桩平台 充电桩开源平台 ecm bpm 影刀 Linux的基础开发工具 xfce 宕机切换 服务器宕机 make命令 makefile文件 NAT转发 NAT Server 重启 排查 系统重启 日志 原因 keepalived 数据库架构 数据管理 数据治理 数据编织 数据虚拟化 数码 联机 僵尸毁灭工程 游戏联机 开服 lio-sam SLAM sonoma 自动更新 idm 软件开发 信任链 chromium dpi neo4j 数据仓库 数据库开发 cocos2d 3dcoat Minecraft DOIT 四博智联 thingsboard 宝塔面板 ArcTS ArcUI GridItem ceph HarmonyOS NEXT 原生鸿蒙 服务网格 istio iDRAC R720xd Bug解决 Qt platform OpenCV js 网络攻击模型 powerbi 信息可视化 echarts 免费 chrome devtools chromedriver 裸机装机 linux磁盘分区 裸机安装linux 裸机安装ubuntu 裸机安装kali 裸机 玩游戏 树莓派 VNC harmonyosnext 网页服务器 web服务器 telnet 远程登录 XFS xfs文件系统损坏 I_O error es 测试用例 MDK 嵌入式开发工具 论文笔记 日志分析 系统取证 dity make eNSP 网络规划 VLAN 企业网络 iventoy VmWare OpenEuler 显卡驱动 AnythingLLM AnythingLLM安装 dba archlinux kde plasma OpenHarmony 容器技术 k8s资源监控 annotations自动化 自动化监控 监控service 监控jvm FunASR ASR ECS服务器 欧拉系统 序列化反序列化 searxng docker desktop 镜像 蓝桥杯C++组 程序化交易 PTrade QMT 量化交易 量化股票 Docker引擎已经停止 Docker无法使用 WSL进度一直是0 镜像加速地址 X11 Xming ajax netlink libnl3 本地部署AI大模型 uni-file-picker 拍摄从相册选择 uni.uploadFile H5上传图片 微信小程序上传图片 IP配置 netplan cpolar Wi-Fi 小游戏 五子棋 Spring Security 我的世界 我的世界联机 AP配网 AK配网 小程序AP配网和AK配网教程 WIFI设备配网小程序UDP开 UDP 终端工具 远程工具 ruby AimRT 线程 cfssl Bandizip Mac解压 Mac压缩 压缩菜单 ssh远程登录 CentOS Stream nvidia 健康医疗 互联网医院 Xshell GRUB引导 Linux技巧 jetty undertow SysBench 基准测试 springboot远程调试 java项目远程debug docker远程debug java项目远程调试 springboot远程 llamafactory 微调 Qwen wordpress 源码 MNN uv 混合开发 环境安装 电脑桌面出现linux图标 电脑桌面linux图标删除不了 电脑桌面Liunx图标删不掉 linux图标删不掉 语音识别 DeepSeek行业应用 Heroku 网站部署 多进程 Dell HPE 联想 浪潮 AI代码编辑器 etl 游戏机 考研 lb 协议 在线office 即时通信 NIO llama.cpp chrome 浏览器下载 chrome 下载安装 谷歌浏览器下载 asp.net上传文件夹 asp.net上传大文件 .net core断点续传 .net mvc断点续传 聊天室 对比 meld DiffMerge rnn 思科模拟器 Cisco nuxt3 Alist rclone mount 挂载 网盘 AList fnOS 算力 服务器管理 配置教程 网站管理 node jina IPv4 子网掩码 公网IP 私有IP muduo 计算机学习路线 编程语言选择 向日葵 Linux24.04 飞牛 Charles 金融 打不开xxx软件 无法检查其是否包含恶意软件 mvc 社交电子 DBeaver 高效远程协作 TrustViewer体验 跨设备操作便利 智能远程控制 飞牛NAS 飞牛OS MacBook Pro finebi hibernate 产测工具框架 IMX6ULL 管理框架 邮件APP 免费软件 Ubuntu Server Ubuntu 22.04.5 chfs ubuntu 16.04 safari 显示管理器 lightdm gdm 历史版本 下载 Python教程 pycharm安装 同步 备份 vscode 1.86 网站搭建 serv00 Vmamba 服务器部署 本地拉取打包 miniconda 直流充电桩 充电桩 微信开放平台 微信公众号配置 可信计算技术 SEO 7-zip banner web3 区块链项目 swift 网络穿透 火绒安全 Nuxt.js NLP模型 自学笔记 小米 澎湃OS Android 毕昇JDK PyQt PySide6 致远OA OA服务器 服务器磁盘扩容 上传视频至服务器代码 vue3批量上传多个视频并预览 如何实现将本地视频上传到网页 element plu视频上传 ant design vue vue3本地上传视频及预览移除 Node-Red 编程工具 流编程 CORS 跨域 安全架构 弹性服务器 Linux find grep fast 用户缓冲区 Claude Desktop Claude MCP Windows Cli MCP workflow 支付 微信支付 开放平台 半虚拟化 硬件虚拟化 Hypervisor 可执行程序 micropython mqtt SoC 飞腾处理器 solidworks安装 Kylin OS anythingllm open-webui docker国内镜像 cocoapods pgpool Obsidian Dataview 业界资讯 端口测试 模拟退火算法 田俊楠 SenseVoice code-server mosquitto SVN Server tortoise svn linux 命令 sed 命令 网页设计 WINCC 代码托管服务 ShenTong 自动化任务管理 Attention AISphereButler easyui UOS1070e 服务器ssl异常解决 星河版 GeneCards OMIM TTD 分子对接 autodock mgltools PDB PubChem RAG 检索增强生成 文档解析 大模型垂直应用 Docker快速入门 vsxsrv 配置原理 yum源切换 更换国内yum源 音乐服务器 Navidrome 音流 Jellyfin Java Applet URL操作 服务器建立 Socket编程 网络文件读取 bot ukui 麒麟kylinos openeuler W5500 OLED u8g2 TCP服务器 Pyppeteer DeepSeek r1 医疗APP开发 app开发 MAC SecureCRT VPS pyqt 模拟器 卸载 列表 trea idea vpn RTMP 应用层 大版本升 升级Ubuntu系统 OD机试真题 服务器能耗统计 网络原理 免费域名 域名解析 opensearch helm 大模型推理 WebRTC uniapp android-studio pppoe radius comfyui comfyui教程 恒源云 bat 服务器繁忙 聊天服务器 套接字 shard 智能音箱 智能家居 rtc IPMITOOL BMC 硬件管理 opcua opcda KEPServer安装 办公自动化 pdf教程 #影刀RPA# XCC Lenovo 繁忙 解决办法 替代网站 汇总推荐 AI推理 token sas 多端开发 智慧分发 应用生态 鸿蒙OS csrf 代理服务器 SSH 服务 SSH Server OpenSSH Server nfs 服务器部署ai模型 SSL 域名 skynet pyautogui cmake 服务器数据恢复 数据恢复 存储数据恢复 raid5数据恢复 磁盘阵列数据恢复 embedding 银河麒麟操作系统 Linux awk awk函数 awk结构 awk内置变量 awk参数 awk脚本 awk详解 wsgiref Web 服务器网关接口 GIS 遥感 WebGIS SystemV 概率论 分布式账本 智能合约 共识算法 figma ai工具 阿里云ECS ldap 红黑树封装map和set 知行EDI 电子数据交换 知行之桥 EDI 增强现实 沉浸式体验 技术实现 案例分析 AR h.264 GoogLeNet paddle 架构与原理 多个客户端访问 IO多路复用 TCP相关API 查看显卡进程 fuser ArtTS 自定义登录信息展示 motd 美化登录 数据库管理 deekseek ranger MySQL8.0 虚幻引擎 怎么卸载MySQL MySQL怎么卸载干净 MySQL卸载重新安装教程 MySQL5.7卸载 Linux卸载MySQL8.0 如何卸载MySQL教程 MySQL卸载与安装 Unity Dedicated Server Host Client 无头主机 logstash 脚本 vue-i18n 国际化多语言 vue2中英文切换详细教程 如何动态加载i18n语言包 把语言json放到服务器调用 前端调用api获取语言配置文件 Sealos Ubuntu 24.04.1 轻量级服务器 烟花代码 烟花 元旦 csrutil mac恢复模式进入方法 SIP 恢复模式 NFC 近场通讯 智能门锁 fiddler 搭建个人相关服务器 极限编程 midjourney yum换源 mybase 网络建设与运维 网络搭建 神州数码 神州数码云平台 云平台 信创 信创终端 中科方德 sentinel 佛山戴尔服务器维修 佛山三水服务器维修 PPI String Cytoscape CytoHubba mm-wiki搭建 linux搭建mm-wiki mm-wiki搭建与使用 mm-wiki使用 mm-wiki详解 swoole 无法访问wordpess后台 打开网站页面错乱 linux宝塔面板 wordpress更换服务器 web开发 Putty 花生壳 OpenSSH 抗锯齿 规格说明书 设计规范 干货分享 黑客工具 密码爆破 IDEA 问题解决 accept tailscale derp derper 中转 triton 模型分析 线性代数 电商平台 流量运营 C++软件实战问题排查经验分享 0xfeeefeee 0xcdcdcdcd 动态库加载失败 程序启动失败 程序运行权限 标准用户权限与管理员权限 whistle gitee go 浏览器开发 AI浏览器 欧标 OCPP xshell termius iterm2 lua 静态IP proxy模式 linux子系统 忘记密码 鸿蒙NEXT 性能调优 安全代理 本地知识库部署 DeepSeek R1 模型 音乐库 Python基础 Python技巧 设备树 合成模型 扩散模型 图像生成 Claude Apache Beam 批流统一 案例展示 数据分区 容错机制 移动开发 c/s 语法 docker search #STC8 #STM32 技术共享 多路转接 捆绑 链接 谷歌浏览器 youtube google gmail 我的世界服务器搭建 跨域请求 aac react native 线程同步 线程互斥 条件变量 VM虚拟机 prometheus数据采集 prometheus数据模型 prometheus特点 massa sui aptos sei USB网络共享 ISO镜像作为本地源 游戏开发 磁盘镜像 服务器镜像 服务器实时复制 实时文件备份 Erlang OTP gen_server 热代码交换 事务语义 regedit 开机启动 备份SQL Server数据库 数据库备份 傲梅企业备份网络版 项目部署 wpf System V共享内存 进程通信 ubuntu安装 linux入门小白 dns是什么 如何设置电脑dns dns应该如何设置 银河麒麟桌面操作系统 xss IO模型 win服务器架设 windows server easyTier 组网 hugo dock 加速 AI员工 分布式训练 玩机技巧 软件分享 软件图标 AI agent kerberos 授时服务 北斗授时 金仓数据库概述 金仓数据库的产品优化提案 finalsheel qt项目 qt项目实战 qt教程 brew 国标28181 监控接入 语音广播 流程 SDP 状态模式 根服务器 IMX317 MIPI H265 VCU 移动魔百盒 TCP协议 集群管理 Qwen2.5-VL VS Code seleium 小智AI服务端 xiaozhi TTS element-ui 上传视频并预览视频 vue上传本地视频及进度条功能 vue2选择视频上传到服务器 upload上传视频组件插件 批量上传视频 限制单个上传视频 端口聚合 windows11 AD 域管理 达梦 DM8 nosql hexo Logstash 日志采集 homeassistant rsync 材料工程 内网服务器 内网代理 内网通信 deepseek r1 接口返回 备选 调用 示例 bigdata 软负载 minecraft image HTTP 服务器控制 ESP32 DeepSeek 端口 查看 ss 查询数据库服务IP地址 SQL Server deployment daemonset statefulset cronjob 内存管理 哈希算法 sqlite post.io 企业邮箱 搭建邮箱 navicat docker部署翻译组件 docker部署deepl docker搭建deepl java对接deepl 翻译组件使用 NVIDIA MinIO 物理地址 页表 虚拟地址 flink 三次握手 WireGuard 异地组网 OpenManage OS 银河麒麟高级服务器 外接硬盘 Kylin IPv6 IPv6测试 IPv6测速 IPv6检测 IPv6查询 做raid 装系统 软考设计师 中级设计师 SQL 软件设计师 钉钉 AzureDataStudio 项目部署到linux服务器 项目部署过程 超融合 抓包工具 动态库 GCC编译器 -fPIC -shared autodl win向maOS迁移数据 pyscenic 生信教程 飞书 qt5 客户端开发 qtcreator 机械臂 动态规划 子系统 嵌入式Linux IPC MacOS EMUI 回退 降级 高频交易 docker部署Python Python 视频爬取教程 Python 视频爬取 Python 视频教程 Radius mcp服务器 client close Masshunter 质谱采集分析软件 使用教程 科研软件 Headless Linux Anolis nginx安装 linux插件下载 企业网络规划 华为eNSP 僵尸世界大战 游戏服务器搭建 运维监控 大大通 第三代半导体 碳化硅 元服务 应用上架 ardunio BLE 智能问答 向量数据库 Spring AI Milvus 顽固图标 启动台 pythonai PlaywrightMCP tidb 风扇控制软件 UFW 零售 火山引擎 RK3568 SPI EMC存储 NetApp存储 粘包问题 caddy 工厂方法模式 qwen2vl 命令模式 华为鸿蒙系统 ArkTS语言 Component 生命周期 条件渲染 Image图片组件 轮播图 macOS 安装部署 milvus安装 Unity插件 数字证书 签署证书 mapreduce 定义 核心特点 优缺点 适用场景 sequoiaDB 输入系统 GRANT REVOKE 带外管理 云计算面试题 进程池实现 solr 服务器正确解析请求体 mujoco webview 搜狗输入法 中文输入法 HAProxy 计算虚拟化 弹性裸金属 PostgreSQL15数据库 Metastore Catalog openvino notepad++ 接口优化 watchtower AI Agent 字节智能运维 lrzsz 流程图 mermaid ABAP authing 软件商店 livecd systemtools mcp协议 go-zero 存储维护 解决方案 pxe 网络库 实时云渲染 云渲染 3D推流 STL 北亚数据恢复 oracle数据恢复 李心怡 西门子PLC 通讯 Qt QModbus Async注解 CAD瓦片化 栅格瓦片 矢量瓦片 Web可视化 DWG解析 金字塔模型 制造 环境 非root vCenter服务器 ESXi主机 监控与管理 故障排除 日志记录 vmware tools ubantu 学习路线 事件驱动 手机 模板 泛型编程 漏洞报告生成 bert 蜂窝网络 频率复用 射频单元 无线协议接口RAN 主同步信号PSS Multi-Agent access blocked 破解 OpenGL 文件共享 Modbus TCP AI提示词优化 web环境 医院门诊管理系统 AWS 导航栏 devmem 华为昇腾910b3 能源 Ubuntu 24.04 搜狗输入法闪屏 Ubuntu中文输入法 4 - 分布式通信、分布式张量 LVS java毕业设计 微信小程序医院预约挂号 医院预约 医院预约挂号 小程序挂号 数字比特流 模拟信号 将二进制数据映射到模拟波形上 频谱资源 振幅频率相位 载波高频正弦波 烟雾检测 yolo检测 消防检测 LSTM MLLMs VLM gpt-4v 代码复审 容器化 Serverless springboot容器部署 springboot容器化部署 微服务容器化负载均衡配置 微服务容器多节点部署 微服务多节点部署配置负载均衡 动态域名 RagFlow NTP服务器 实时日志 logs Python学习 Python编程 fabric rtcp Web3 Telegram orbslam2 CPU架构 服务器cpu 能效分析 BCLinux 惠普服务器 惠普ML310e Gen8 惠普ML310e Gen8V2 broadcom 超级终端 多任务操作 提高工作效率 wifi驱动