本应用示例基于Hyperledger fabric2.4搭建一个自由房屋租赁区块链系统freerent, 用户可以自由在链上开展合同签订、执行和验真。freerent应用背景相对简单,当前应用搭建示例展示 fabric初级功能。后期将会不断探索 fabric应功能特性,也希望可以结合IPFS实现合同存储,扩展成DeFi 服务,违约自动赔付、房屋抵押借贷、资产管理等等。
区块链简单理解:
区块链简单理解是一个进阶的分布式数据库,传统分布式数据库一般是同步运算产生结果,保持全局数据状态一致。而区块链系统是同步整个运算过程,从输入开始就开始同步,节点不信你运算的结果,只信自己运算所产生的结果。所有输入数据都是节点所能理解的数据、先前共识设定好的(智能合约),不接收外部数据,这也限制了一些业务代码的开发,当然也有解决方法,例如:预言机、零知识证明等。
联盟区块链作用:
区块链和去中心化密不可分,去中心化就是权利下发,就是信息平等。联盟区块链就将区块链的作用范围限制在业务团体中,保证业务参与者按照设定去信息平等,从而简化业务流程。正常业务流转很难离开一个公信力强的“中介平台”,此时中介平台如果是非政府机构可能会获取大量的隐私数据,但如果是都是政府机构,那政府机构繁琐的业务流程太多。所以联盟区块链去中心化可以理解成去“中介化”,能点对点完成的流程就不需要第三方,同时在产生分歧也自己就可以拿出法律认可的证据。
项目预期呈现内容:
区块链网络环境搭建基于个人笔记,个人笔记中有部分以前搬运多个网上博客,如发现内容重复,麻烦联系标记或者删除。预期内容:
fabric 学习最好的就是官方文档,可以先看2.2中文翻译版本: hyperledger-fabricdocs master 文档。
本项目基于hyperledger fabric v2.4.5版本。
联盟组织:orderer排序组织+三个成员组织supervisor、rentalcrop、 agency
组织节点 :下章说明
网络: rentnet
通道: rentsign
账本数据库: couchdb
VM版本 :VMware® Workstation 16 Pro
操作系统版本: Centos7.5
三台虚拟机 :1台 2核 4G 、两台 2核 2G
部署方案:3个orderer、3个组织、组织3、2、2个普通节点,通过docker swarm +docker machine 实现一键多机/分布式部署.
添加用户到sudo组,并免密使用sudo(三台均需设置)
# 添加用户到sudo组 并免密使用sudo
su
vim /etc/sudoers
# USERNAME ALL=(ALL) ALL
# USERNAME ALL = NOPASSWD: ALL
vvgo ALL=(ALL) ALL
vvgo ALL = NOPASSWD: ALL

虚拟机互相免密访问(普通用户)
# 将ip和主机名添加到所有的虚拟机中
vi /etc/hosts
192.168.248.128 supervisor
192.168.248.129 rentalcrop
192.168.248.130 agency
/etc/init.d/network restart # 重启网络
su vvgo # 切换至普通用户
# 生成公钥(所有虚拟机都要执行)
# 一直Enter就可以
ssh-keygen -t rsa
2
# 互相拷贝 注意登录身份
# 三台一样的步骤
cd ~/.ssh
cat id_rsa.pub >> authorized_keys
ssh-copy-id 192.168.248.128
ssh-copy-id 192.168.248.129
ssh-copy-id 192.168.248.130
chmod 0600 authorized_keys # 免密登录自己
# 将防火墙关闭
systemctl status firewalld #查看状态
# 关闭
sudo systemctl stop firewalld.service
sudo systemctl disable firewalld.service
因为是新机器,需要更新和下载一些软件,多次环境搭建每次借鉴的教程不一样,所以有的可能并不需要。
sudo yum install git
sudo yum install curl
sudo yum -y install epel-release
sudo yum install python-pip
sudo pip install --upgrade pip
sudo yum install -y unzip
sudo yum install -y wget
主机器安装即可,无需三台都安装
#golang 下载
cd /usr/local/src
# 指令不成功 可以复制链接到主机上下载
sudo wget https://studygolang.com/dl/golang/go1.19.1.linux-amd64.tar.gz
sudo tar -zxvf go1.19.1.linux-amd64.tar.gz -C /usr/local/
# 配置环境
sudo vim /etc/profile
# 写入
export GOROOT=/usr/local/go
export PATH=$PATH:/usr/local/go/bin
source /etc/profile #使golang的环境变量生效
# 设置代理, 加速 go get
go env -w GO111MODULE=on
go env -w GOPROXY=https://goproxy.io,direct
三台均安装
(1)安装 epel更新源
sudo yum install -y vim wget epel-release
(2)设置仓库
安装所需的软件包。yum-utils 提供了 yum-config-manager ,并且 device mapper 存储驱动程序需要 device-mapper-persistent-data 和 lvm2。
sudo yum install -y yum-utils \
device-mapper-persistent-data \
lvm2
(3)用以下命令来设置稳定的仓库。
sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
(4) 安装最新版本的 Docker Engine-Community 和 containerd
sudo yum install -y docker-ce docker-ce-cli containerd.io
(5)配置Docker Hub 镜像加速器
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": [
"https://1nj0zren.mirror.aliyuncs.com",
"https://docker.mirrors.ustc.edu.cn",
"http://f1361db2.m.daocloud.io",
"https://registry.docker-cn.com"
]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
(6)安装docker命令补全工具
sudo yum install -y bash-completion
(7)设置docker开机启动
sudo systemctl enable docker
(8) 设置登录用户到docker用户组(不然需要密码)
sudo groupadd docker #添加docker用户组 已经存在
sudo gpasswd -a vvgo docker #将登陆用户加入到docker用户组中
newgrp docker #更新用户组
docker images #测试docker命令是否可以使用sudo正常使用
三台均安装
Docker Compose是 docker 提供的一个命令行工具,用来定义和运行由多个容器组成的应用。使用 compose,我们可以通过 YAML 文件声明式的定义应用程序的各个服务,并由单个命令完成应用的创建和启动。
sudo yum install docker-compose -y
docker -v && docker-compose -v && go version

主机安装
sudo wget https://mirrors.aliyun.com/docker-toolbox/linux/machine/0.10.0/docker-machine-Linux-x86_64
# 移动到bin目录下
sudo mv docker-machine-Linux-x86_64 /usr/local/bin/docker-machine
# 添加权限
sudo chmod +x ./docker-machine

创建docker-machine node
# 创建 docker-machine
# 在主机上创建, 一定要实现免密登录自己
# 第一次卡主,可以停止并重复运行
docker-machine --debug create --driver generic --generic-ip-address=192.168.248.128 --generic-ssh-user=vvgo supervisor
docker-machine --debug create --driver generic --generic-ip-address=192.168.248.129 --generic-ssh-user=vvgo rentalcrop
docker-machine --debug create --driver generic --generic-ip-address=192.168.248.130 --generic-ssh-user=vvgo agency
docker-machine --debug create --driver generic --generic-ip-a
有点错误,但不影响后续使用

docker pull hyperledger/fabric-peer:2.4.5
docker pull hyperledger/fabric-ca:1.5.2
docker pull hyperledger/fabric-orderer:2.4.5
docker pull hyperledger/fabric-ccenv:2.4.5
docker pull hyperledger/fabric-tools:2.4.5
docker pull hyperledger/fabric-baseos

(1)拉取docker仓库镜像
docker pull registry:2
(2) 设置docker私有库免密 (三台都需要设置)
sudo vi /etc/docker/daemon.json daemon.conf
{
"registry-mirrors": [
"https://1nj0zren.mirror.aliyuncs.com",
"https://docker.mirrors.ustc.edu.cn",
"http://f1361db2.m.daocloud.io",
"https://registry.docker-cn.com"
],
"insecure-registries":["192.168.248.128:5000"]
}
sudo vim /usr/lib/systemd/system/docker.service
# 在 ExecStart=/usr/bin/dockerd.... 后面添加
--insecure-registry 192.168.248.128:5000
sudo systemctl daemon-reload
sudo systemctl restart docker
可能的报错:
[vvgo@supervisor docker]$ sudo systemctl restart docker
Job for docker.service failed because the control process exited with error code. See "systemctl status docker.service" and "journalctl -xe" for details.
#解决:
cd /etc/docker
sudo mv daemon.json daemon.conf
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
是否可以在应用程序中包含的gem代码中知道应用程序的Rails文件系统根目录?这是gem来源的示例:moduleMyGemdefself.included(base)putsRails.root#returnnilendendActionController::Base.send:include,MyGem谢谢,抱歉我的英语不好 最佳答案 我发现解决类似问题的解决方案是使用railtie初始化程序包含我的模块。所以,在你的/lib/mygem/railtie.rbmoduleMyGemclassRailtie使用此代码,您的模块将在
无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD
导读:随着叮咚买菜业务的发展,不同的业务场景对数据分析提出了不同的需求,他们希望引入一款实时OLAP数据库,构建一个灵活的多维实时查询和分析的平台,统一数据的接入和查询方案,解决各业务线对数据高效实时查询和精细化运营的需求。经过调研选型,最终引入ApacheDoris作为最终的OLAP分析引擎,Doris作为核心的OLAP引擎支持复杂地分析操作、提供多维的数据视图,在叮咚买菜数十个业务场景中广泛应用。作者|叮咚买菜资深数据工程师韩青叮咚买菜创立于2017年5月,是一家专注美好食物的创业公司。叮咚买菜专注吃的事业,为满足更多人“想吃什么”而努力,通过美好食材的供应、美好滋味的开发以及美食品牌的孵
在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList()Obt
我们目前正在为ROR3.2开发自定义cms引擎。在这个过程中,我们希望成为我们的rails应用程序中的一等公民的几个类类型起源,这意味着它们应该驻留在应用程序的app文件夹下,它是插件。目前我们有以下类型:数据源数据类型查看我在app文件夹下创建了多个目录来保存这些:应用/数据源应用/数据类型应用/View更多类型将随之而来,我有点担心应用程序文件夹被这么多目录污染。因此,我想将它们移动到一个子目录/模块中,该子目录/模块包含cms定义的所有类型。所有类都应位于MyCms命名空间内,目录布局应如下所示:应用程序/my_cms/data_source应用程序/my_cms/data_ty