首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

fabric区块链(一)—搭建环境

在Ubuntu上搭建Hyperledger Fabric 2.4.9需要进行以下步骤:安装Docker和Docker Compose在Ubuntu上安装Docker和Docker Compose可以使用以下命令.../network.sh createChannel -c mychannel图片到这里channel也创建好了部署和测试链码如果通道创建成功,可以使用joinChannel.sh脚本将peer节点加入到该通道中.../asset-transfer-basic/chaincode-javascript/ -ccl javascript这个命令还将部署‘assert-transfer-basic'链码,部署成功就可以在通道上执行交易和查询了...,这是一个用于处理JSON数据的命令行工具,用下面的命令安装sudo apt-get updatesudo apt-get install jq图片在Hyperledger Fabric中,链码是一个智能合约...可以使用以下命令在测试网络上部署和测试一个示例链码:# 安装链码./network.sh deployCC# 测试链码./scripts/testCC.sh

1.2K40

fabric区块链(一)—搭建环境

在Ubuntu上搭建Hyperledger Fabric 2.4.9需要进行以下步骤: 安装Docker和Docker Compose 在Ubuntu上安装Docker和Docker Compose可以使用以下命令...可以使用以下命令安装: sudo apt-get install golang-go 安装完成后,可以使用以下命令检查是否安装成功: go version 安装Node.js和npm Hyperledger.../network.sh createChannel -c mychannel 到这里channel也创建好了 部署和测试链码 如果通道创建成功,可以使用joinChannel.sh脚本将peer节点加入到该通道中...Fabric中,链码是一个智能合约,用于在区块链上执行业务逻辑。...可以使用以下命令在测试网络上部署和测试一个示例链码: # 安装链码 ./network.sh deployCC # 测试链码 ./scripts/testCC.sh

70320
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Hyperledger Fabric 系统架构详解

    链码 Fabric也有类似以太坊的智能合约,称为 Chaincode 链码,智能合约使外部的应用程序可以和Fabric网络中的账本进行交互。...不同于Ethereum,Fabric使用 Docker 而不是特定的虚拟机来存放链码,提供了一个安全、轻便的语言执行环境。...链码主要分成系统链码和用户链码两种,系统链码嵌入在系统内,提供对系统进行配置、管理的支持;而用户链码则是运行在单独的 Docker 容器中,提供对上层应用的支持,用户通过链码相关的 API 编写用户链码...链码经过安装和实例化操作后即可被调用,在安装的时候需要指定具体安装到哪个 Peer 节点(有的节点可以没有链码),实例化时还需要指定通道及背书策略。...对于一个链码交易来说,背书策略是在链码实例化的时候指定的,一笔有效交易必须是背书策略相关组织签名才能生效,本质上Fabric区块链中的交易验证是基于对背书节点的信任,这也是称Fabric并不是严格意义上的去中心化的原因之一

    2.4K10

    Hyperledger Fabric 2.x 环境搭建

    创建Channel 现在我们的机器上正在运行对等节点和排序节点, 我们可以使用脚本创建用于在Org1和Org2之间进行交易的Fabric通道。...在通道启动一个链码 创建通道后,可以开始使用智能合约与通道账本交互。...在Fabric中,智能合约作为链码以软件包的形式部署在网络上。链码安装在组织的对等节点上,然后部署到某个通道,然后可以在该通道中用于认可交易和区块链账本交互。...在将链码部署到通道前,该频道的成员需要就链码定义达成共识,建立链码治理。何时达到要求数量的组织同意后,链码定义可以提交给通道,并且可以使用链码了。...创建频道后,可以使用network.sh脚本在通道上启动链码: ./network.sh deployCC -ccn basic -ccp ..

    1.7K10

    Hyperledger Fabric1.0运行Fabcar以及常见问题解决(持续更新)

    /bootstrap.sh 进入first-network目录中 cd first-network 是否已经构建,如果构建关闭重新构建 关闭应用 ....加入通道 peer channel join -b mychannel.block 链码 ---- 安装链码 peer chaincode install -n mycc -v 1.0 -p github.com.../hyperledger/fabric/examples/chaincode/go/chaincode_example02 实例化链码 peer chaincode instantiate \ -o orderer.example.com.../byfn.sh -m down 参数说明: -o:指定order服务节点地址 --tls:是否开启TLS验证 --cafile:指定TLS_CA证书的所在路径 -C:指定通道名称 -n:指定链码名称...-c:指定调用链码的所需参数 -p:指定安装链码的所在路径 -P:指定背书策略 Node.js SDK和fabcar交互 ---- 进入fabric-samples目录下的fabcar目录中 cd fabric-samples

    2.1K00

    Hyperledger Fabric 2.0 Alpha发布了!

    Fabric chaincode lifecycle Fabric 2.0 Alpha介绍了分布式治理链码的特性,包括在你的节点上安装链码以及在一个通道中启动链码的新流程。...新的模型在之前的生命周期上进行了改进: 多个组织必须同意链码的参数:在Fabric 1.x版本中,一个组织能够为所有其他通道成员设置链码参数(例如背书策略)。...使用同一个安装包启动多个链码:在之前的生命周期管理中一个通道上的链码可以使用名字和版本来指定一个安装的链码。...在现在的版本中你可以使用一个链码安装包在同一个通道或者不同的通道使用不同的名字进行多次部署。...Endorsement policies:了解使用新的链码生命周期如何使用通道配置中的策略作为背书策略。 限制 Fabric v2.0 Alpha版本中链码生命周期尚未完成。

    1.2K30

    深入解析fabric的peer命令(一)

    有这句,导致我们在命令行使用peer命令,后面可以加chaincode 四,深入分析mainCmd.AddCommand(chaincode.Cmd(nil, cryptoProvider))这一句 首先...在 Hyperledger Fabric 中,chaincode.Cmd 函数用于创建与链码相关的命令。它接受两个参数:chaincodeID 和 cryptoProvider。...chaincodeID 参数是一个表示链码标识的字符串。在这里,传递的是 nil,表示没有指定特定的链码标识,即执行与链码相关的命令时不需要指定特定的链码。...因此,mainCmd.AddCommand(chaincode.Cmd(nil, cryptoProvider)) 的作用是将与链码相关的命令添加到 mainCmd 中,其中使用了默认的加密提供程序,并且不指定特定的链码标识...通过添加这个命令,可以在运行程序时使用 peer chaincode 命令执行与链码相关的操作,例如安装、实例化、升级、查询等。

    584150

    Hyperledger Fabric 2.0 Alpha发布了!

    Fabric chaincode lifecycle Fabric 2.0 Alpha介绍了分布式治理链码的特性,包括在你的节点上安装链码以及在一个通道中启动链码的新流程。...新的模型在之前的生命周期上进行了改进: 多个组织必须同意链码的参数:在Fabric 1.x版本中,一个组织能够为所有其他通道成员设置链码参数(例如背书策略)。...使用同一个安装包启动多个链码:在之前的生命周期管理中一个通道上的链码可以使用名字和版本来指定一个安装的链码。...在现在的版本中你可以使用一个链码安装包在同一个通道或者不同的通道使用不同的名字进行多次部署。...Endorsement policies:了解使用新的链码生命周期如何使用通道配置中的策略作为背书策略。 限制 Fabric v2.0 Alpha版本中链码生命周期尚未完成。

    83720

    Fabric private data入门实战

    本文将介绍如何在链码开发中使用fabric private data。 ?...目前在Hyperledger Fabric中实现数据隐私的方法是使用通道。...但是官方并不孤立为了实现数据的隐私保护而在大型网络中创建大量通道,因为这会带来额外的开销,例如管理策略、链码版本以及成员服务提供(MSP)等。在一个通道中,所有的数据要么是公开的,要么是私有的。...所有的marble数据都可以公开,除了其持有人以及价格信息,这两个数据是不能对别人公开的,价格不应该被别人了解。可能你需要跟踪这个数据,因为你需要验证在销售marble的人是否是真正的持有人。...fabric private data链码最佳实践 当然,我们的数据中有一部分是Hyperledger Fabric网络中的任何人都看得到的。

    1.3K40

    Fabric的6大特性

    成员准入 Hyperledger Fabric是用于准入网络的框架,其中所有参与者都具有已知身份。在考虑准入的网络时,您应该考虑您的区块链用例是否需要遵守数据保护法规。...性能,可伸缩性和信任级别 Hyperledger Fabric建立在模块化架构之上,该架构将事务处理分为三个阶段:分布式逻辑处理和协议(“链码”),事务排序以及事务验证和承诺。...增加的事务需要改进的可伸缩性和性能,Hyperledger Fabric v1.X提供了此功能,部分原因是拆分了链代码执行。 拆分链码执行还可以使网络动态增长。...在Hyperledger Fabric v1.X中,可以动态和以编程方式添加peer,而不是像v0.6中那样以静态方式添加。例如,假设一家管理外汇汇率的公司有一家新银行要添加到网络中。...例如,在供应链场景中,您可以使用JSON文档样式来帮助概述商品和运输实体的特定数据。您可以轻松地生成用于资产到最终目的地的不同地点和运输实体的资产报告。

    1.2K20

    深入解析fabric的peer命令(一)

    有这句,导致我们在命令行使用peer命令,后面可以加chaincode 四,深入分析mainCmd.AddCommand(chaincode.Cmd(nil, cryptoProvider))这一句 首先...在 Hyperledger Fabric 中,chaincode.Cmd 函数用于创建与链码相关的命令。它接受两个参数:chaincodeID 和 cryptoProvider。...chaincodeID 参数是一个表示链码标识的字符串。在这里,传递的是 nil,表示没有指定特定的链码标识,即执行与链码相关的命令时不需要指定特定的链码。...因此,mainCmd.AddCommand(chaincode.Cmd(nil, cryptoProvider)) 的作用是将与链码相关的命令添加到 mainCmd 中,其中使用了默认的加密提供程序,并且不指定特定的链码标识...通过添加这个命令,可以在运行程序时使用 peer chaincode 命令执行与链码相关的操作,例如安装、实例化、升级、查询等。

    32620

    Fabric-sdk-java最新教程 原

    、链码调用等,适合快速上手fabric java sdk。...java sdk访问链码 这篇文章的重点在于链码的调用,因此比较详细地步骤讲解了使用fabric java sdk查询链码状态 或提交链码交易的代码,使用的是官方的fabcar链码案例。...6、使用fabric java sdk进行TLS通信 这篇文章的重点是介绍如何使用fabric java sdk访问启用了tls通信的超级账本fabric区块链 网络。...使用fabric java sdk创建和部署网络 这篇文章介绍如何使用fabric java sdk来创建并部署一个fabric区块链网络。...Hyperledger Fabric Java SDK 构建和部署区块链网络 这篇文章主要介绍如何使用Hyperledger Fabric SDK Java创建,部署和测试区块链网络,以及链码开发、部署与调用

    3.5K30

    深入解析fabric的peer命令(一)

    有这句,导致我们在命令行使用peer命令,后面可以加chaincode 四,深入分析mainCmd.AddCommand(chaincode.Cmd(nil, cryptoProvider))这一句 首先...在 Hyperledger Fabric 中,chaincode.Cmd 函数用于创建与链码相关的命令。它接受两个参数:chaincodeID 和 cryptoProvider。...chaincodeID 参数是一个表示链码标识的字符串。在这里,传递的是 nil,表示没有指定特定的链码标识,即执行与链码相关的命令时不需要指定特定的链码。...因此,mainCmd.AddCommand(chaincode.Cmd(nil, cryptoProvider)) 的作用是将与链码相关的命令添加到 mainCmd 中,其中使用了默认的加密提供程序,并且不指定特定的链码标识...通过添加这个命令,可以在运行程序时使用 peer chaincode 命令执行与链码相关的操作,例如安装、实例化、升级、查询等。

    38740

    Hyperledger Fabric学习笔记01-系统逻辑架构

    2.这些模块也可以通过需求进行扩展,集成到系统中。 充分利用容器技术 1.不仅节点使用容器做为运行环境,链码也默认运行在安全的容器中。...节点可以加入到不同的通道(Channel)中,链码可以运行在不同的节点上,这样可以更好地提升并行执行的效率和吞吐量。...安全性 Hyperledger Fabric 1.0提供的是授权访问的区块链网络,节点共同维护成员信息,MSP(Membership Service Provider)模块验证、授权了最终用户后才能使用区块链网络的功能...多链和多通道的设计容易实现数据隔离,也提供了应用程序和链码之间的安全通道,实现了隐私保护。 系统逻辑架构 下图是 Hyperledger Fabric 1.0设计的系统逻辑架构图: ?...区块链强一致性要求各个节点之间达成共识需要较长的执行时间,也是采用异步通信模式进行开发的,事件模块可以在触发区块事件或者链码事件的时候执行预先定义的回调函数。

    1.3K30

    Hyperledger Fabric 2.0 Alpha新特性

    Hyperledger Fabric v2.0 Alpha引入两大新功能,新的Fabric链码生命周期和FabToken....新的链码生命周期 2.0支持链码的去中心化的治理,引入新的流程在节点上安装链码,在通道上启动实例。新的链码生命周期允许多个组织对链码的参数协同达成一致,例如链码的背书策略。...(3) 更简单的更新背书策略 新的链码生命周期无需重新打包安装链码,可直接修改背书策略,用户也可以使用新的默认的策略,从通道的主要成员获得背书。这个默认策略在组织加入或退出通道时会自动更新。...(5) 使用一个包在一个通道上启动多个链码 老版本的链码在通道安装会使用名字和版本做标记,新版本我们可以打为一个链码包,使用不同的名字即可,在一个或多个通道部署多次。...使用新的链码生命周期 官方提供了新的操作手册和例子: Chaincode for operator https://hyperledger-fabric.readthedocs.io/en/latest

    77910

    fabric区块链(六)—解析basic智能合约(go)

    └── vendor(包含项目依赖项的目录,通常在使用特定版本管理工具时会将依赖项放在此目录中。)...它使用chaincode.SmartContract{}作为智能合约的实现。if err != nil { ... }: 这是一个错误处理的条件语句,用于检查链码实例的创建过程中是否发生了错误。...= nil { ... }: 这是另一个错误处理的条件语句,用于检查链码实例的启动过程中是否发生了错误。如果发生错误,将会输出错误日志并终止程序运行。...在总体上,这段代码的功能是创建一个基于Hyperledger Fabric的区块链应用程序,并启动该应用程序的链码实例。...它使用了Hyperledger Fabric提供的链码API和自定义的智能合约实现。如果创建或启动过程中出现错误,程序将输出相应的错误日志并终止运行。

    58810

    fabric区块链(六)—解析basic智能合约(go)

    └── vendor(包含项目依赖项的目录,通常在使用特定版本管理工具时会将依赖项放在此目录中。)...它使用chaincode.SmartContract{}作为智能合约的实现。 if err != nil { ... }: 这是一个错误处理的条件语句,用于检查链码实例的创建过程中是否发生了错误。...= nil { ... }: 这是另一个错误处理的条件语句,用于检查链码实例的启动过程中是否发生了错误。如果发生错误,将会输出错误日志并终止程序运行。...在总体上,这段代码的功能是创建一个基于Hyperledger Fabric的区块链应用程序,并启动该应用程序的链码实例。...它使用了Hyperledger Fabric提供的链码API和自定义的智能合约实现。如果创建或启动过程中出现错误,程序将输出相应的错误日志并终止运行。

    79730
    领券