前言

本文基于个人经验,参考相关博客,分享自己使用虚拟机搭建Fabric环境的步骤,希望对大家的入门有帮助。


一、基本概念

1.1. 虚拟机

虚拟机(Virtual Machine)指通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机操作系统。它实质上只是个文件而已,而非真正意义上的操作系统。

虚拟机总是会对应一种要模拟的操作系统,通常是Windows或Linux。对于Linux,它还细分为多种发行版,包括Ubuntu,CentOS等。

Ubuntu又有多种LTS版本,如果打算使用Ubuntu,建议至少选择20.04 LTS。

1.2. 虚拟机软件

虚拟机软件,也叫做Hypervisor或VMM(虚拟机监视器,Virtual Machine Monitor),是一种运行在硬件和虚拟机之间的中间层软件。

虚拟机软件的常见架构有两种:一种是“裸机”型,虚拟机软件直接管理调用硬件资源,不需要底层操作系统;一种是“托管”型,虚拟机软件运行在底层操作系统上。

常见的虚拟机软件厂商及其产品有Vmware(威睿)的Workstation Pro和Oracle(甲骨文)的VitualBox等。


二、虚拟机相关

注1:Oracle的VirtualBox和Vmware的Workstation Pro当下都可以免费使用,但是VirtualBox在多个虚拟机之间的网络互通设置较为麻烦,而Workstation Pro的虚拟机基于默认分配的IP即可互通,使用简单。因此个人建议选择Workstation Pro。如果使用VirtualBox,请跳过2.2和2.5小节;如果使用Vmware,请跳过2.1和2.4小节。

注2:后文参考的部分跟VirtualBox使用相关的文章链接如下。
VirtualBox安装Ubuntu
VirtualBox实现文件与主机复制粘贴
VirtualBox设置共享文件夹
VirtualboxNAT模式+端口转发

注3:后文参考的部分跟Vmware使用相关的文章链接如下。
VMware Workstation Pro 17官网下载安装教程
VMware安装Ubuntu
VMware Tools安装步骤

注4:在虚拟机软件中安装虚拟机需要提前准备对应的ISO镜像文件。
阿里云ubuntu镜像下载
阿里云centos镜像下载

2.1. VirualBox7安装Ubuntu

打开VitualBox,点击“新建”。

在新窗口中输入虚拟机的名称选择提前准备的ISO镜像,勾选“跳过自动安装”,下一步。

在这里插入图片描述

分配内存大小为4096MB,处理器为4个,下一步。

分配虚拟硬盘大小改为30G,下一步,最后点击完成。

启动虚拟机,进入Ubuntu的安装界面,选择语言为“中文(简体)”,点击“安装Ubuntu”,点击“继续”,选择“最小安装”,点击“继续”,点击“现在安装”,点击“继续”,选择地区,点击“继续”,输入用户名和密码,点击“继续”,之后等待安装完成,点击“现在重启”,回车即可。

如果遇到安装界面显示不全以至于无法点击特定按钮,可以按CTRL + ALT + T 调出命令终端并手动输入如下命令调整屏幕大小:

xrandr --size 1280x800

2.2. Vmware安装Ubuntu

打开VMware,点击“创建新的虚拟机”。选择“自定义”,下一步;下一步;选择“稍后安装操作系统”,下一步;选择系统的类型为“Linux”,版本为“Ubuntu 64位”,下一步;更改虚拟机名称,下一步;下一步;分配内存大小为4GB,下一步;选择“使用网络地址转换”,下一步;下一步;下一步;选择“创建新虚拟盘”,下一步;虚拟硬盘大小改为30G,下一步;下一步;完成。

创建好后虚拟机就出现在VMware中了,但此时并不能使用,因为没有安装具体的操作系统,还需要为其加载一个合适的镜像文件。

选择新出现的虚拟机,点击编辑虚拟机设置,为其分配光驱。

在这里插入图片描述

启动虚拟机,进入Ubuntu的安装界面,按照提示操作即可。

2.3. Ubuntu的使用

2.3.1. 软件包管理器

2.3.1.1. yum/apt/curl/wget的区别

yum是CentOS等系统中的软件包管理器,提供查找、安装、删除软件包的命令。

apt是Ubuntu等系统中的软件包管理器,提供类似的命令。执行apt 命令需要root权限,因而通常会在前面加上sudo命令。

curl和wget都是进行文件传输的命令行工具,相当于迅雷。不同的是,wget在几乎所有Linux系统中都是自带的,而curl不是。

2.3.1.2. 设置最佳下载服务器(可选)

当使用apt安装或更新软件时,有时因为下载服务器连接的问题而导致安装或更新出现错误,因此需要设置最佳下载服务器。

点击桌面左下角的按钮,选择“软件和更新”,勾选“源代码”并在下拉菜单中点击“其他站点…”,再点击 “选择最佳下载服务器”,完成后确认。

在这里插入图片描述

注:实际使用中,个人感觉不设置最佳下载服务器影响也不大。

2.3.1.3. apt更新软件包

安装好系统后,应当首先更新软件包列表,检查可用的软件包更新:

sudo apt update

注:如果不更新软件包列表,使用apt命令安装软件包更新时,则可能会出现Unable to locate package的错误。

然后安装所有可用的软件包更新:

sudo apt upgrade
2.3.1.4. 无法获得锁

如果在未完成下载的情况下将终端关闭,或者是系统正在更新,将会导致apt进程被占用,此时无法使用apt命令。

在这里插入图片描述

出现上述提示时解决方法如下:

sudo rm /var/lib/apt/lists/lock

在这里插入图片描述

出现上述提示时解决方法如下:

sudo rm /var/cache/apt/archives/lock
sudo rm /var/lib/dpkg/lock

完成后需要重启虚拟机才能生效。

2.3.2. 开机速度优化

如果虚拟机的开机速度特别慢,可以先查看占用开机时长的服务:

systemd-analyze blame

一般禁用以下服务即可:

sudo systemctl disable plymouth-quit-wait.service

如果使用disable无法将该启动项彻底禁用,可以使用mask:
sudo systemctl mask plymouth-quit-wait.service

另一个可能占用开机时长的启动项是snapd.service,一般会跟随一大堆的dev-loop*.service,此时可以将snapd直接删除:

sudo apt purge snapd

2.3.3. 禁用IPv6

安装net-tools,然后输入如下命令:

sudo apt install net-tools
sudo bash -c 'echo "net.ipv6.conf.all.disable_ipv6 = 1" >>/etc/sysctl.conf'
sudo bash -c 'echo "net.ipv6.conf.default.disable_ipv6 = 1" >>/etc/sysctl.conf'
sudo bash -c 'echo "net.ipv6.conf.lo.disable_ipv6 = 1" >>/etc/sysctl.conf'

随后打开Ubuntu的设置-网络-有线连接,将IPv6改为“禁用”。最后重启虚拟机。如果不更改有线连接中的设置,网卡仍会被分配IPv6地址,但是不影响其它使用。

注:禁用IPv6仅仅是为了后续查看容器时提高可读性,但仍强烈建议。

2.3.4. SSH

2.3.4.1. SSH基本知识

SSH(Secure Shell)是一种网络协议,用于加密两台计算机之间的通信,并且支持各种身份验证机制。该协议的一种开源实现就是OpenSSH项目。

SSH 的软件架构是服务器-客户端模式(Server - Client)。在这个架构中,SSH 软件分成两个部分:向服务器发出请求的部分,称为客户端(client),OpenSSH 的实现为ssh;接收客户端发出的请求的部分,称为服务器(server),OpenSSH 的实现为sshd

另外,OpenSSH还有一些辅助工具软件(比如 ssh-keygen )和专门的客户端工具(比如 scp)。

2.3.4.2. SSH客户端

OpenSSH实现的SSH客户端是二进制程序ssh。Linux 系统一般都自带它,安装位置是/usr/local/bin/ssh。可以使用-V参数输出版本号,查看ssh是否存在:

ssh -V
2.3.4.3. SSH服务器

OpenSSH实现的SSH服务器是二进制程序sshd。通常,Ubuntu只会预装ssh,而没有sshd。使用SSH客户端时应当确保远端的SSH服务器正在运行。

在远端检查SSH服务器的状态:

service ssh status

如果提示Unit ssh.service could not be found.,则说明SSH服务器未安装。

在这里插入图片描述

此时如果使用ssh访问远端,会报ssh: connect to host xx.xx.xx.xx port 22: Connection refused的错误。

在远端使用apt命令安装SSH服务器:

sudo apt install openssh-server -y

安装成功后,再一次检查SSH服务器的状态,会提示Server listening on 0.0.0.0 port 22.,说明SSH服务器已运行。

在这里插入图片描述

2.3.4.4. SSH秘钥登录

SSH 默认的登录方式为密码登录,每次都需要手动输入密码,操作麻烦,这时可以使用秘钥登录。

首先生成秘钥对:

ssh-keygen -t rsa

该命令将在当前用户HOME目录下的.ssh/目录生成一个公钥文件id_rsa.pub和一个私钥文件id_rsa

使用OpenSSH自带的ssh-copy-id命令将本地公钥文件上传到远端上,并把它添加到远端的用户HOME目录下的.ssh/目录的authorized_keys文件中:

ssh-copy-id remote_username@remote_ip

如果需要在多台服务器之间传输文件,在每台服务器上重复上述步骤。

2.3.4.5. SCP

SCP (Secure Copy) 是 Linux 系统下的文件传输工具,主要用于在不同的 服务器之间传输文件。scp命令的底层是 SSH 协议,默认端口是22,相当于先使用ssh命令登录远程主机,然后再使用cp命令执行拷贝操作。

在本地使用以下命令将文件传输到远端:

scp local_file remote_username@remote_ip:remote_folder

在本地使用以下命令将整个目录传输到远端:

scp -r local_folder remote_username@remote_ip:remote_folder
2.3.4.6. SSHPass

SSHPass (SSH Password) 是一个用于非交互式验证SSH密码的工具。

使用apt命令安装sshpass

sudo apt install sshpass

基于sshpass登录远程服务器:

sshpass -p 'remote_password' ssh remote_username@remote_ip

基于sshpass远程执行Shell命令或脚本:

sshpass -p ' remote_password' ssh remote_username@remote_ip "your_command"

基于sshpass远程文件上传:

sshpass -p 'remote_password' scp local_file remote_username@remote_ip:remote_folder

2.3.5. NSCD

NSCD (Name Service Cache Daemon)是一个系统缓存服务,用于缓存常见的名称服务信息,例如用户、组、主机名和服务。它可以提高系统的性能,减少对名称服务的频繁查询和网络流量,从而加快系统的响应速度。

如果在/etc/hosts指定某个IP解析域名,发现实际请求过程中并不生效,那么这时候就要考虑系统内是否存在nscd服务。

使用apt安装NSCD。

sudo apt install nscd -y

启动NSCD服务。

systemctl start nscd

检查其运行状态。

systemctl status nscd

2.4. VitualBox7进阶

2.4.1. 安装增强功能

增强功能是VirtualBox中可用的一个增强工具,主要解决屏幕分辨率不能调整、鼠标光标停顿延迟、无法与原安装系统共享剪切板等问题。

启动虚拟机,在联网状态下,在虚拟机菜单栏点击“设备-安装增强功能”,自动下载,点击“运行”,最后在终端中输入“Return”即可。之后可以在虚拟机菜单栏点击“视图-虚拟显示屏1”调整屏幕分辨率。

如果要共享粘贴板或者拖放文件,还需要在VitualBox中额外进行设置:

选择虚拟机,点击设置。点击常规-高级,确保“共享粘贴板”和“拖放”都是“双向”。点击存储,勾选“使用主机输入输出I/O缓存”。最后重启虚机。

2.4.2. 端口转发

VitualBox提供了多种网络连接模式,包括NAT、桥接、Host-Only等,默认用的是NAT模式。所有虚拟机在NAT模式下,其IP地址都是10.0.2.15,网关地址都是10.0.2.2。此时主机不能ping通虚拟机,且虚拟机之间也不能ping通。但是可以设置端口转发,使主机能够ping通虚拟机,这样就可以使用远程连接工具从主机访问虚拟机了。

  1. 确认SSH服务器已安装(见2.3.4.3节)。
  2. 查看主机IP地址:Windows系统win+r打开cmd,输入ipconfig即可。注意,这里的主机IP地址不是VirtualBox Host-Only Network中的IP。
  3. 设置端口转发规则:点击“端口转发”,新建一条端口转发规则:主机IP为第二步中得到的IP地址,主机端口选择一个空端口(多个不同的虚拟机使用不同的端口),子系统IP为10.0.2.15,子系统端口为22。

完成前述设置后,就可以使用远程连接工具来远程访问虚拟机了。远程连接工具中使用的IP和端口号使用上面的主机IP和主机端口。

2.5. Vmware进阶

2.5.1. 安装VMware Tools

VMware Tools是VMware中可用的一个增强工具,安装该工具可以实现主机和虚拟机之间的粘贴板共享、文件自由拖放、鼠标自由移动(不用再按ctrl+alt)、时间同步,以及虚拟机屏幕大小任意调整或全屏化等功能。

启动虚拟机,在VMware的菜单栏中单击“虚拟机-安装VMware Tools”,桌面会出现一个VMware Tools。双击打开后将其中的.tar.gz压缩包复制到桌面,“右键-提取到此处”,打开其中的vmware-tools-distrib文件夹,“右键-在终端中打开”,运行其中的.pl文件:

sudo ./vmware-install.pl

第一次输入yes,之后一直回车,直到出现Enjoy, –the VMware team,就表示安装成功了,之后可以自由调节窗口大小。

安装VMware Tools后,如果不能共享粘贴板或者拖放文件,输入下述命令:

sudo apt install open-vm-tools
sudo apt install open-vm-tools-desktop

之后重启虚拟机。

注:VMware Tools的安装是针对VMware本身的,在某个虚拟机中安装一次后,所有虚拟机都能获得该工具带来的好处。

2.5.2. 克隆虚拟机

当需要在VMware使用多台虚拟机时,克隆虚拟机无疑是最方便的,只需简单几步,就能获得一个一模一样的系统,免去了创建新虚拟机的重复操作。

选择一个已关闭的虚拟机,点击VMware菜单栏的“虚拟机”(或者右键点击该虚拟机),选择“管理-克隆”,进入向导。点击下一步,选择想要的克隆源(当前状态或者已保存的快照),下一步。选择“创建完整克隆”,下一步。更改虚拟机名称,完成。

因为原来的虚拟机使用的是网络连接模式为NAT模式,新克隆的虚拟机也会自动分配一个新的可用 IP和MAC地址,不会与已有虚拟机冲突。等待克隆完成即可,此时新的虚拟机就已经可以直接使用了,并且与已有虚拟机都能 ping 通。

新克隆的虚拟机与原来的虚拟机将会使用相同的hostname,可选的,如果后续需要通过hostname(而非IP)在不同虚拟机之间互通,则需要修改新克隆的虚拟机的hostname:

hostnamectl set-hostname <new hostname>

最后在需要互通的虚拟机的hosts文件中添加hostname与IP的绑定关系。

2.5.3. 磁盘扩容

如果安装虚拟机时分配的虚拟硬盘太小,后续可能会遇到剩余空间不足的情况,此时可以对虚拟机进行扩容。

选择需要扩容的虚拟机,点击“编辑虚拟机配置”;在新窗口中选择“硬盘(SCSI)”,点击“扩展…”;在新窗口中设置新的最大磁盘大小,点击“扩展”。提示磁盘扩容成功后,点击“确定”。

在这里插入图片描述

启动虚拟机,点击左下角的“显示应用程序”,输入“disk”找到“磁盘”。点击齿轮按钮,点击“调整大小…”。

在这里插入图片描述

拖动滑块,将分区大小调到最大,最后点击“调整大小”。

在这里插入图片描述

注:有快照的虚拟机需要先删除快照,才能扩容。

2.5.4. 提示"该虚拟机似乎正在使用中"

在这里插入图片描述

点击“获取所有权”仍然不成功。

在这里插入图片描述

此时,点击“取消”,打开图中配置文件所在的该虚拟机目录,可以看到一个后缀为.lck的文件,这在其它正常的虚拟机目录下是没有的,删除该文件即可。

2.6. 网络调试基础

  1. 确认IP地址或域名以及端口是否可用

TCPing是基于TCP协议的一种Ping命令,用来测试数据包能否通过TCP协议到到达目标主机。它的优点是可以监听某个端口的状态。

安装方法如下:

# 安装依赖项:
sudo apt install -y tcptraceroute
# 下载TCPing到/usr/bin目录:
sudo wget https://soft.mengclaw.com/Bash/TCP-PING -O /usr/bin/tcping
# 赋予TCPing工具执行权限:
sudo chmod +x /usr/bin/tcping

使用方法如下:

tcping <ipv4addr/hostname> [port]
  1. 查看系统端口的占用情况

Netstat是在内核中访问网络连接状态及其相关信息的程序,它能提供TCP连接、TCP和UDP监听、进程内存管理等功能。通常的用法如下:

netstat -atunlp

注:使用-p参数时,必须运行在root权限下,否则不能得到运行在root权限下的进程名。

在Linux环境下,任何事物都以文件的形式存在,lsof是一个列出当前系统打开文件的工具。可以用lsof命令查看特定端口的占用情况:

lsof -i:<port>
  1. 查看程序是否已启动

Linux的ps命令用于显示当前进程的状态,类似于Windows的任务管理器。

grep是一个文本搜索工具,它能使用特定模式匹配(包括正则表达式)搜索文本。

通常使用ps命令显示所有进程信息及命令行信息,然后通过管道符配合grep命令输出匹配行:

ps -ef | grep <process>

2.7. 其它

  • 在宿主机中打开翻译软件的划译功能后,在虚拟机中双击鼠标左键可能会出现问题。
  • 如果启动虚拟机后一直黑屏,尝试在视图中重设虚拟显示屏的分辨率。
  • 如果VirtualBox在启动时卡死,这时可以在任务管理器中先将进程关掉。

三、Ubuntu安装所需软件

3.1. 基本软件

curl:用于下载文件的工具。

Git:开源的版本控制工具,用于从GitHub上下载源代码。

vim:文本编辑器,用于修改脚本。

Jq:处理JSON文件的工具。

tree:以树状图列出文件目录结构的工具。

sudo apt install curl -y
sudo apt install git -y
sudo apt install vim -y
sudo apt install jq -y
sudo apt install tree

3.2. Fabric版本说明

Fabric提供定期发布的新功能和改进,并且某些版本被指定为长期支持(LTS)版本。

最新LTS版本:

  • v2.5.x

历史LTS版本:

  • v2.2.x(维护于2024年2月结束,最后交付版本为v2.2.15)
  • v1.4.x(维护于2021年4月结束,最后交付版本为v1.4.12)

不同的LTS版本之间存在较大的差异。默认来说,推荐使用v2.5.x,该版本简化了通道的创建过程,并支持BFT等新功能;但是如果想要使用SDK来部署生产网络,则推荐使用v2.2.x。

Fabric的版本还会对其它软件的版本有需求,涉及Golang和Node.js,详见对应章节的说明。

3.3. Docker和Docker Compose

3.3.1. 说明

Docker:开源的应用容器引擎,为应用创造轻量级的、可移植的容器。

Docker Compose:用于定义和运行多容器的Docker应用程序的工具。Compose的使用方法是编写YML文件来配置应用程序需要的所有服务,然后执行docker-compose up命令,就可以基于这个YML文件启动并运行整个应用程序。

YML文件中有个重要的字段“version”,它指定本YML文件是依从compose的哪个版本制定的。在使用YML文件时,“version”与docker以及docker-compose的版本有对应关系。

后续测试网络用于docker-compose的YML文件的“version”都为3.7。查阅Docker官网,3.7版本的YML文件要求的docker版本为18.06.0或更高,要求的docker-compose版本为1.22.0或更高。 因此在安装了docker和docker-compose之后,应检查版本是否符合要求。

3.3.2. 安装

3.3.2.1. Ubuntu20.04安装

在Ubuntu20.04中,直接使用apt命令安装docker-compose(并自动安装docker)即可:

sudo apt install docker-compose
3.3.2.2. Ubuntu18.04安装

如果是Ubuntu18.04,使用apt命令安装的docker-compose的版本为1.17.1,不符合要求。因此,需要手动安装新版本的。

使用apt命令安装docker:

sudo apt install docker.io

下载指定版本的docker-compose:

sudo curl -L "https://github.com/docker/compose/releases/download/1.28.6/docker-compose-$(uname -s)-$(uname -m)" -o /usr/bin/docker-compose

注1:如果出现任何错误,重新运行上述命令。

注2:如果要安装其他版本的docker-compose,替换1.28.6,参见官网的版本说明

注3:在https://get.daocloud.io下载的docker-compose可能会不停地自动安装docker,原因未知。

赋予docker-compose可执行权限:

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

3.3.3. 配置

完成后检查docker和docker-compose的版本:

在这里插入图片描述

设置docker daemon在系统启动的时候自动启动:

sudo systemctl enable docker

查看docker的启动状况:

systemctl status docker

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

sudo usermod -aG docker $USER

重启。 再次检查docker的版本,确认Server已正常。

在这里插入图片描述

3.3.4. 替换镜像源(可选)

由于Docker默认的镜像源在境外,可能因为网络问题,拉取镜像的速度较慢,建议替换为国内镜像源。常用国内镜像源包括清华大学镜像源、网易镜像源、阿里云镜像源等。

这其中,阿里云是为每个阿里云账号生成一个镜像加速器地址,由“系统分配前缀”区分。

“前缀”获取方法如下:

  • 登陆阿里云,点击“产品-容器-容器镜像服务 ACR”;

在这里插入图片描述

  • 在新窗口中点击“管理控制台”;

在这里插入图片描述

  • 点击“镜像工具-镜像加速器”,即可获得个人的加速器地址。

在这里插入图片描述

替换镜像源的方法是在daemon配置文件/etc/docker/daemon.json(没有则新建)中添加配置项registry-mirrors。以阿里云的个人加速器地址为例:

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://xxxxxx.mirror.aliyuncs.com"]
}
EOF

建议多配置几个镜像源。

之后重启Docker:

sudo systemctl daemon-reload
sudo systemctl restart docker

检查镜像源是否成功替换:

docker info

3.4. Golang

用于运行Go语言开发的示例链码和应用程序。

3.4.1. 安装

如果之前下载过Go,先删除,一般是根目录下的/usr/local/go:

sudo rm -rf /usr/local/go

参见https://github.com/hyperledger/fabric/releases,不同版本的Fabric都会在特定的Go版本下测试过(例如Fabric v2.5.10对应Go 1.23.1),建议下载已测试版本的Go压缩包文件:

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

3.4.2. 配置环境变量

Golang的环境配置包括GOROOT和GOPATH:GOROOT是指的Golang的安装目录,一般为/usr/local/go;GOPATH是指的用户的工作空间,用于存放第三方类库和个人的代码,从Go 1.8版本开始,Go开发包在安装完成后会为GOPATH设置一个默认目录,一般为$HOME/go,即便该目录不存在。

较新的Go语言版本已经不要求必须把代码写在GOPATH下面的src目录。因此,无需创建GOPATH的目录,只要将GOROOT写入环境变量即可。

打开当前登录用户的.bashrc文件:

sudo vim ~/.bashrc

在.bashrc文件的最后添加如下内容:

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

使用source命令使之生效:

source ~/.bashrc

接下来可以通过go version命令查看版本或者通过go env命令查看GOPATH和GOROOT是否正确设置。

注:在Linux操作系统中,.bashrc文件用于保存当前登录用户的一些个性化设置,修改.bashrc文件只对当前登录用户生效。对于Ubuntu20系统,当以超级用户身份运行"bash"时,输入go version命令会提示Golang未安装。但是对于Ubuntu18系统,当以超级用户身份运行"bash"时,输入go version命令会正确显示版本。

3.4.3. 配置Modules和代理

设置GOPROXY可以方便用户下载Go语言的第三方包,推荐修改为国内代理源:

export GOPROXY=https://goproxy.cn,direct

Go.mod是Go 1.11版本新引入的官方包管理工具,用于解决依赖包具体版本的问题。Modules 是相关 Go包的集合,是源代码交换和版本控制的单元。Go命令直接支持使用Modules,包括记录和解析对其他模块的依赖性。Modules 和传统的GOPATH不同,不需要包含src、bin这样的子目录,只要其中包含有Go.mod文件。Go.mod通过GO111MODULE设置,一般建议设置为on:

export GO111MODULE=on

3.5. JDK

用于运行Java语言开发的示例链码或应用程序。

3.5.1. 安装

已经编写好的Java项目需要JDK来编译运行。JDK有许多个版本,安装更高版本的JDK时,系统默认不会覆盖低版本,而是高版本和低版本共存。版本并不是越新越好,且建议使用稳定的LTS版本,因此后续使用JDK11。

使用apt命令安装JDK11:

sudo apt install openjdk-11-jdk -y

如果需要安装其它版本的OpenJDK,方法一致。

注意JDK和JRE的区别。不要用sudo apt install openjdk-11-jre-headless -y

3.5.2. 配置环境变量(可选)

打开当前登录用户的.bashrc文件:

vim ~/.bashrc

在.bashrc文件的最后添加如下内容:

export JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH

使用source命令使之生效:

source ~/.bashrc

验证JDK11的安装是否成功:

java --version 

验证JAVA_HOME是否设置成功:

echo $JAVA_HOME

切换版本时,修改JAVA_HOME的路径即可。

3.6. Node.js

用于运行JavaScript或者TypeScript语言开发的示例链码或应用程序。

3.6.1. 说明

JavaScript是一种广泛用于web应用开发的脚本应用语言,TypeScript则是它的超集。因为TypeScript最终会编译成JavaScript去工作,所以它支持任何一种Javascript运行环境。

最初,JavaScript只能在浏览器上运行,而Node.js则是一种能够使得JavaScript脱离浏览器运行的运行环境。

Node.js的版本更新较快且各版本之间差异较大,运行某个应用时,如果版本不同,很可能就会遇到各种莫名其妙的问题。为了方便安装和管理Node.js的版本,需要现在系统中安装NVM(Node Version Manager),它是Node.js的版本管理软件,可以根据不同的需求在Node.js的各个版本之间进行切换。NVM安装并配置成功后,可以直接使用nvm命令轻松地安装不同版本的Node.js,避免了手动从官网安装可能会遇到的各种麻烦。

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

3.6.2. 安装

下载NVM的Gitee镜像:

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

执行install.sh:

./install.sh

验证NVM的安装是否成功:

nvm -v

如果成功安装,但是提示找不到命令"nvm",可以使用source命令使之生效:
source ~/.bashrc

接下来安装Node.js。不同版本的Fabric的Node模块的兼容性,包括它所需的Node.js版本和它可以通信的Fabric Peer版本如下图所示:

在这里插入图片描述

如果是使用Fabric v2.5,则安装18版本:

nvm install v18

检查Node.js和npm的版本:

node -v && npm -v

设置淘宝镜像源:

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

设置官方镜像源:
npm config set registry https://registry.npmjs.org/

3.6.3. 使用

3.6.3.1. nvm

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

nvm current

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

nvm ls

切换Node.js版本:

nvm use xx
3.6.3.2. npm

列出npm当前的所有配置:

npm config list

查看源:

npm config get registry

3.7. Clash

后续工作中会经常遇到因无法访问境外网站而造成的网络问题。使用Clash翻墙是解决这类问题的终极答案。

下载Linux可用的Clash压缩包并重命名:

wget https://down.clashcn.com/soft/clashcn.com_Clash.for.Windows-0.20.39-x64-linux.tar.gz -O clash.tar.gz

将下载的压缩包解压并重命名:

tar -zxvf clash.tar.gz && mv Clash\ for\ Windows-0.20.39-x64-linux/ clash

进入该目录:

cd clash

运行cfw文件:

./cfw

稍等即可打开Clash的GUI。

如果运行cfw文件时出现如下错误:
The SUID sandbox helper binary was found, but is not configured correctly. Rather than run without sandboxing I'm aborting now. You need to make sure that /…/chrome-sandbox is owned by root and has mode 4755.
解决方法是:
sudo chown root chrome-sandbox && sudo chmod 4755 chrome-sandbox

打开Ubuntu的设置-网络-网络代理,确保已修改为手动并正确设置:

在这里插入图片描述

在这里插入图片描述

复制自行购买的海外服务器节点的配置文件,在Profiles中粘贴,点击“Download”:

在这里插入图片描述

不需要使用时,在Settings中点击“Quit”退出:

在这里插入图片描述

关闭Clash后,如果火狐浏览器无法访问任何网页,打开Ubuntu的设置-网络-网络代理,将其设置为“已禁用”即可。或者打开浏览器的设置-常规-网络设置,点击“设置…(E)”按钮,从“使用系统代理设置”改为“不使用代理服务器”,需要时再改回来。

在这里插入图片描述

在这里插入图片描述

3.8. CFSSL(可选)

CFSSL是一套第三方的开源证书管理工具,在Fabric的v2.5.x版本中被引入作为一种可选的网络加密材料生成方式。

使用apt命令安装CFSSL:

sudo apt install golang-cfssl

验证CFSSL的安装是否成功:

cfssl version

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐