Fabric2.0.0部署运行test-network日记
Author:wts
Date:2020年2月27日
2020-2-27:
1、安装Ubuntu(完成)
密码是123456
因为磁盘空间的原因,将Ubuntu存储在移动硬盘里,方便后期移动。
这个网址的环境是1.4,我们到时使用fabric官方路径吧。
今天的目标,装好ubuntu,golang,nodejs,curl等需要的软件。
推荐用apt代替apt-get
估计是要装在移动硬盘上的原因吧,对移动硬盘又是一次考验。
2、Ubuntu 安装curl(完成)
https://blog.csdn.net/songmingzhan/article/details/78876400
程序“curl”尚未安装。 您可以使用以下命令安装:sudo apt install curl 已经提示很明确了,sudo apt install curl先更新一下
sudo apt-get update
sudo apt install curl
3、Ubuntu安装git(完成)
https://www.jianshu.com/p/cc76129478ab
sudo apt-get update
sudo apt-get install git
设置Git
安装Git之后建议做一些基础设置,例如设置一下你的用户名与电子邮件等,这些信息在提交代码的时候都是必需的。可以使用以下的命令:
git config --global user.name "你的用户名,例如github的账号"
git config --global user.email "你的邮箱,例如github中的邮件地址"
之后,就可以用git config --list来查看设置的信息。
初始化仓库
在初始化仓库之前,可以先创建一个代码存储的文件侠,例如“git_test”,之后用git init来初始化,如下:
mkdir temp
cd temp
git init
初始化操作会在这个目录中新建一个名为“.git”的目录,相关的配置以及编辑信息均存储在其中。说明一下,这个文件夹默认隐藏,如果需要查看,可以用ls -a来查看。
4、Ubuntu安装docker和docker compose(完成)
https://www.jianshu.com/p/cef32b054968
太复杂了。。。。有这么麻烦么。。。。
好麻烦。。。
5、Ubuntu安装GO(完成)
vim ~/.bashrc
最后一行加上下面配置
export GOPATH=/usr/local/go
export PATH=$GOPATH/bin:$PATH
通过apt安装的不在这里
有时候需要配置ubuntu安装的软件,一般安装软件都是使用apt-get install。那么安装完后,软件的安装目录在哪里呢,可执行文件又放在哪里呢。
A、下载的软件的存放位置:/var/cache/apt/archives
B、安装后软件的默认位置:/usr/share
C、可执行文件位置:/usr/bin
D、配置文件位置:/etc
E、lib文件位置:/usr/lib
过程挺慢的,竟然还需要18分钟。。。
6、Ubuntu安装Node.js(完成)
https://blog.csdn.net/cgs1999/article/details/89703649
sudo add-apt-repository ppa:chris-lea/node.js
sudo apt-get update
sudo apt-get install nodejs
sudo apt install libssl1.0-dev nodejs-dev node-gyp npm
sudo npm config set registry https://registry.npm.taobao.org
sudo npm config list
sudo node -v
sudo npm -v
先到这里吧。
7、Ubuntu上不去git(完成不算太快,也没快哪去。。)
Ubuntu上不去github:
https://www.cnblogs.com/chenxi188/p/10862503.html(这个链接里写的比较好)
第二步,追加域名的IP地址
我们可以利用https://www.ipaddress.com/来获得以下两个GitHub域名的IP地址:
(1) github.com
(2) github.global.ssl.fastly.net
打开网页后,利用输入框内分别查询两个域名:
先试一下github.com(也可直接访问):http://github.com.ipaddress.com/#ipinfo
在标注的IP地址中,任选一个记录下来。
再来是github.global.ssl.fastly.net(也可直接访问):http://github.global.ssl.fastly.net.ipaddress.com/#ipinfo
将以上两段IP写入Hosts文件中:
151.101.185.194 github.global.ssl.fastly.net192.30.253.112 github.com
解决连不上GitHub,也ping不通
https://blog.csdn.net/believe_s/article/details/81539747
Ping不通,这时候,只需要在host文件里做些修改就可以,首先,定位到路径
C:\Windows\System32\drivers\etc
1找到host文件,右键-属性-安全-编辑,选中当前电脑登录的用户,给自己最高权限,确认。
然后用记事本打开,在最后一行加:
192.30.253.113 github.com
192.30.252.131 github.com
185.31.16.185 github.global.ssl.fastly.net
74.125.237.1 dl-ssl.google.com
173.194.127.200 groups.google.com
192.30.252.131 github.com
185.31.16.185 github.global.ssl.fastly.net
74.125.128.95 ajax.googleapis.com
保存,再ping,发现速度杠杠的
ubuntu上设置
https://blog.csdn.net/wuzhong8809/article/details/84061323
通过修改/etc/hosts 强制捆绑域名和IP地址
下面通过将abc.com 的IP指定为 127.0.0.1 为例:
一、打开/etc/hosts 文件,在其中添加如下一行:
127.0.0.1 abc.com
保存退出。
二、重启网络模块
sudo /etc/init.d/networking restart
三、验证
>ping abc.com
PING abc.com (127.0.0.1) 56(84) bytes of data.
64 bytes from localhost (127.0.0.1): icmp_seq=1 ttl=64 time=0.092 ms
64 bytes from localhost (127.0.0.1): icmp_seq=2 ttl=64 time=0.084 ms
64 bytes from localhost (127.0.0.1): icmp_seq=3 ttl=64 time=0.077 ms
8、Ubuntu搭建ftp服务器
运行:sudo apt-get install vsftpd命令,安装VSFTP工具:
安装好了之后,使用如下命令启动FTP服务:
sudo systemctl start vsftpdsudo systemctl enable vsftpd
2.等待安装完成,进入配置文件目录, cd /etc/
3. 将配置文件备份, sudo cp vsftpd.conf vsftpd.conf.bak 这是个人习惯。
4.配置文件中主要有这几项修改:
匿名用户(就是可以直接登录的)
anon_upload_enable=YES #默认是NO
anon_mkdir_write_enable=YES #匿名登录创建文件夹
anon_upload_enable=YES #匿名登录可以上传
anon_other_write_enable=YES # 匿名登录可写
其他还有一些local_enable 登录账号白名单,用户白名单之类的以后再介绍。
5.重启ftp服务。 sudo /etc/init.d/vsftpd restart
登录客户端
ftp://xxx.xxx.xxx
这里登录的路径是服务器的/srv/ftp/
这里要求ftp文件夹是不可写的。否则会出错。即 sudo chmod 555 /srv/ftp/.
————————————————
版权声明:本文为CSDN博主「seVIIen」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/cfycyf/article/details/79420588
9、Ubuntu部署基于Fabric的虚拟区块链服务
https://blog.csdn.net/sinat_35119798/article/details/78518919
sudo curl -sSL
https://raw.githubusercontent.com/hyperledger/fabric/master/scripts/bootstrap.sh | bash -s
10、Docker中如何删除image(镜像)
http://yaxin-cn.github.io/page/2/
docker中删除images的命令是docker rmi,但有时候执行此命令并不能删除images
[yaxin@ubox ~]$docker imagesREPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZEeg_sshd latest ed9c93747fe1 45 hours ago 329.8 MBCentOS65 latest e55a74a32125 2 days ago 360.6 MB[yaxin@ubox ~]$docker rmi ed9c93747fe1Untagged: ed9c93747fe16627be822ad3f7feeb8b4468200e5357877d3046aa83cc44c6af[yaxin@ubox ~]$docker imagesREPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE<none> <none> ed9c93747fe1 45 hours ago 329.8 MBCentOS65 latest e55a74a32125 2 days ago 360.6 MB
可以看出,image并没有被删除,只是他的tag被删除了,再次执行docker rmi IMAGE_ID只会报错
[yaxin@ubox ~]$docker rmi ed9c93747fe1Error: image_delete: Conflict, ed9c93747fe1 wasn't deleted2014/03/22 15:58:27 Error: failed to remove one or more images
查看docker的帮助会发现有两个与删除有关的命令rm和rmi
rm Remove one or more containersrmi Remove one or more images
这里有两个不同的单词,images和container。其中images很好理解,跟平常使用的虚拟机的镜像一个意思,相当于一个模版,而container则是images运行时的的状态。docker对于运行过的image都保留一个状态(container),可以使用命令docker ps来查看正在运行的container,对于已经退出的container,则可以使用docker ps -a来查看。如果你退出了一个container而忘记保存其中的数据,你可以使用docker ps -a来找到对应的运行过的container使用docker commit命令将其保存为image然后运行。
回到之前的问题,由于image被某个container引用(拿来运行),如果不将这个引用的container销毁(删除),那image肯定是不能被删除。
所以想要删除运行过的images必须首先删除它的container。继续来看刚才的例子,
[yaxin@ubox ~]$docker ps -aCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES117843ade696 ed9c93747fe1 /bin/sh -c /usr/sbin 46 hours ago Up 46 hours 0.0.0.0:49153->22/tcp test_sshd
可以看出ed9c93747fe1的image被117843ade696的container使用着,所以必须首先删除该container
[yaxin@ubox ~]$docker rm 117843ade696Error: container_delete: Impossible to remove a running container, please stop it first2014/03/22 16:36:44 Error: failed to remove one or more containers
出现错误,这是因为该container正在运行中(运行docker ps查看),先将其关闭
[yaxin@ubox ~]$docker stop 117843ade696117843ade696
[yaxin@ubox ~]$docker rm 117843ade696117843ade696[yaxin@ubox ~]$docker rmi ed9c93747fe1Deleted: ed9c93747fe16627be822ad3f7feeb8b4468200e5357877d3046aa83cc44c6afDeleted: c8a0c19429daf73074040a14e527ad5734e70363c644f18c6815388b63eedc9bDeleted: 95dba4c468f0e53e5f1e5d76b8581d6740aab9f59141f783f8e263ccd7cf2a8eDeleted: c25dc743e40af6858c34375d450851bd606a70ace5d04e231a7fcc6d2ea23cc1Deleted: 20562f5714a5ce764845119399ef75e652e23135cd5c54265ff8218b61ccbd33Deleted: c8af1dc23af7a7aea0c25ba9b28bdee68caa8866f056e4f2aa2a5fa1bcb12693Deleted: 38fdb2c5432e08ec6121f8dbb17e1fde17d5db4c1f149a9b702785dbf7b0f3beDeleted: 79ca14274c80ac1df1333b89b2a41c0e0e3b91cd1b267b31bef852ceab3b2044[yaxin@ubox ~]$docker imagesREPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZECentOS65 latest e55a74a32125 2 days ago 360.6 MB
可以看出,image已经被删除。
11、修改docker images的名称,删除同名同id不同tag的镜像
原创周子青最后发布于2018-05-11 15:22:24 阅读数 15127 收藏
展开
docker tag imageid name:tag正解。
docker tag 镜像ID xxxx:xxxx
例子:
docker tag 899bd984 lyb/php:1.0
今天建立docker容器的时候由于疏忽,镜像的名字输错了,结果容器创建成功后,镜像中出现两个id相同的:
使用docker rmi e4a35914679d删除的时候执行失败:
Error response from daemon: conflict: unable to delete e4a35914679d (must be forced) - image is referenced in one or more repositories
提示应该是该id有两个本地文件,不能用id删除。
所以我想删除所有镜像docker rmi $(docker images -q),出现下面错误
Error response from daemon: conflict: unable to delete e4a35914679d (must be forced) - image is referenced in one or more repositories
后来在Stack Overflow删看到使用repository和tag进行操作的,所以执行docker rmi docker.io/redis:3.2
再次查询的时候只剩下一个镜像,删除OK。
所以,可以使用repository:tag的组合来删除特殊的镜像。
————————————————
版权声明:本文为CSDN博主「周子青」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_37674858/article/details/80282068
12、使用docker安装mysql
第一步:使用docker pull拉取docker hub仓库中mysql镜像 (注意备注)
l
mysql镜像版本如下:
命令:docker pull mysql:8.0
备注:docker pull默认到官方参考拉取 mysql:8.0 镜像名:镜像tag
(ctrl+c)可以取消下载
官方地址为国外地址安装缓慢可进行配置为国内的加速镜像,具体操作见下面
第二步:修改镜像文件拉取地址
命令:vi /etc/docker/daemon.json
备注:insert编辑内容如下 并esc 输入:wq 保存退出
{
"registry-mirrors":["http://f1361db2.m.daocloud.io"]
}
备注:国内可用加速地址:
https://registry.docker-cn.com
https://3laho3y3.mirror.aliyuncs.com
https://mirror.ccs.tencentyun.com
第三步:重启docker重新进行【第一步】安装速度变快
命令:systemctl restart docker
第四步:查看镜像安装情况
命令:docker images
第五步:启动docker中镜像
命令:docker run --name mysql8.0 -p 3307:3306 -e MYSQL_ROOT_PASSWORD=root -d mysql:8.0
备注:--name服务启动别名设置 -p端口映射 宿主机端口:镜像运行端口 -d 镜像名:tag 使用守护进程模式启动 -e:设置root帐号密码
第六步:查看运行的镜像
命令:docker ps -a
第七步:进入镜像运行mysql
命令:docker exec -it mysql8.0 /bin/bash
备注:exec docker进入容器命令 -it 容器中服务别名 /bin/bash 表示命令行模式 与 -d 后台守护进行模式启动 形成两种运行方式 进入容器中如图所示变化如下
命令:cd /usr/bin
命令:mysql -u root -p
备注:在容器中进入用户目录启动mysql输入密码连接成功
安装成功
其他就正常操作mysql了。
13、大坑集锦 【推荐】HyperLedger Fabric环境搭建、测试及注意事项 [详尽指导] [亲测有效]
https://www.cnblogs.com/X-knight/p/9511491.html
14、Ubuntu开启telnet
Fabric-sample目前是运行成功了。
目录在/home/wts/fabric-samples下。
2020-2-28:
1、Fabric test-network的运行
curl -sSL https://bit.ly/2ysbOFE | bash -s【此命令运行不成功】
改成如下命令:
curl -sSL https://raw.githubusercontent.com/hyperledger/fabric/master/scripts/bootstrap.sh | bash -s【会安装需要的bin目录下的文件和docker中需要的iamge】
Bring up the test network:
#cd fabric-samples/test-network
#./network.sh up
#docker ps -a【可以看到docker中已经运行的镜像】
#./network.sh createChannel 【默认创建一个mychannel】
#./network.sh deployCC -l java【java版本】
#./network.sh deployCC 【go版本】
export PATH=${PWD}/../bin:${PWD}:$PATH
export PATH=/home/wts/fabricmyself/fabric-samples/bin:/home/wts/fabricmyself/fabric-samples:$PATH
export FABRIC_CFG_PATH=$PWD/../config/
export FABRIC_CFG_PATH=/home/wts/fabricmyself/fabric-samples/config
You can now set the environment variables that allow you to operate the peer CLI as Org1:
# Environment variables for Org1
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
export CORE_PEER_TLS_ENABLED=true
export CORE_PEER_LOCALMSPID="Org1MSP"
export CORE_PEER_TLS_ROOTCERT_FILE=/home/wts/fabricmyself/fabric-samples/test-network/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt
export CORE_PEER_MSPCONFIGPATH=/home/wts/fabricmyself/fabric-samples/test-network/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp
export CORE_PEER_ADDRESS=localhost:7051
peer chaincode invoke -o localhost:7050 --ordererTLSHostnameOverride orderer.example.com --tls true --cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem -C mychannel -n fabcar --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":"changeCarOwner","Args":["CAR9","Dave"]}'
peer chaincode invoke -o localhost:7050 --ordererTLSHostnameOverride orderer.example.com --tls true --cafile /home/wts/fabricmyself/fabric-samples/test-network/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem -C mychannel -n fabcar --peerAddresses localhost:7051 --tlsRootCertFiles /home/wts/fabricmyself/fabric-samples/test-network/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt --peerAddresses localhost:9051 --tlsRootCertFiles /home/wts/fabricmyself/fabric-samples/test-network/organizations/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt -c '{"function":"changeCarOwner","Args":["CAR9","Dave"]}'
Test-network运行完毕。
好了,撸起袖子加油干吧。后面要理解、掌握的东西还很多。