019:Truffle简介与使用|《ETH原理与智能合约开发》笔
待字闺中开发了一门区块链方面的课程:《深入浅出ETH原理与智能合约开发》,马良老师讲授。此简书文集记录我的学习笔记。
课程共8节课。其中,前四课讲ETH原理,后四课讲智能合约。
第六课分为三部分:
- Solidity语法之数组
- Solidity语法之合约
- Truffle简介与使用
这篇文章是第六课第三部分的学习笔记:Truffle简介与使用。
这节课主要讲解了 Truffle 的技术特性,并演示了 Truffle 的安装和一个小例子。
1、Truffle 简介
前面介绍的 Remix 作为学习工具来用是比较好的,但是不能满足生产环境。因为 Remix 不支持 web 前端、自动化程度不是很高,不方便进行自动化测试。实际工作中用到的是Truffle框架。
1.1 技术特性
- Consensys 出品,智能合约开发测试框架
- 内置的编译 / 链接 / 部署
- 快速开发自动合约测试
- 可以部署到 TESTRPC/ 测试网络 / 主网(TESTRPC现在更名为ganache)
- 直接可与合约通信的交互 Console
- 调试合约
- 集成了 web / javascript 组件,可以直接运行 App web 前端
1.2 安装要求
- ubuntu 16.04
- Nodejs LTS 8.11
- ganache-cli 为测试网络(速度快,不需要挖矿。)
2、Truffle 开发演示
马老师把演示的步骤放在了代码仓库:lesson_6/truffle_setup.txt 。下面是我的操作记录。
2.1 Truffle 安装
- 安装NVM。Truffle 是基于 Node.js 开发的,使用时需要node的版本在 8.0 以上,管理版本用的工具是Nvm。安装命令如下:
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.9/install.sh | bash
- 确认各个软件都已安装齐。我这步出了点问题,重启了一下终端,好了。
sudo apt install build-essential python -y
- 退出终端
exit
,使安装的 nvm 生效。也可以不退出,使用如下命令,生成一个子进程。
exec bash
- 安装 node.js 的长期稳定版。我安装之后是8.11.2版。
nvm install --lts
- 再把 npm 更新一下。更新后版本是6.0
npm install -g npm
- 安装 Truffle 和 ganache,另外还要安装webpack并指定版本4.0 。我这步安装了20多分钟,电脑发热的厉害。最后安装成功,Truffle 的版本是4.1.9
npm install -g truffle ganache-cli webpack@4.0.0
2.2 Truffle 实例
- 在工作目录新建一个文件夹。我的工作目录是ETHljx,新建文件夹是hello_world 。再进入到文件夹。
cd ~/ETHljx
mkdir hello_world
cd hello_world
- 用Truffle 生成一个自带的例子。这是一个很简单的例子,并不是ERC20的代币,仅作练习使用。
truffle unbox webpack
- 编译
truffle compile
- 编译后可以看到有三个 .sol 文件。主要是 MetaCoin.sol 文件。查看文件
vim contracts/MetaCoin.sol
MetaCoin.sol代码
查看完代码后,在命令模式下按
:q!
退出vim 。
- 使用 tmux 再开一个窗口,启动ganache测试网络(右边窗口)。
ganache-cli -h 0.0.0.0
上面的命令是老师的,用的是两台机器,一个远程服务器。我的是在同一台电脑上练习,用下面的命令,即不加后面的参数:
ganache-cli
启动后,可以看到10个账号,和对应的私钥。复制下来一个账号。端口号8545要记下来。
- 部署合约(左边窗口)
truffle migrate
-
修改 truffle.js 改端口号到 8545, ip 到本机对应的外部IP(非 127.0.0.1)。注意:前面这句是马老师的情况(使用两台机器),我用的一台机器,所以,IP还得写127.0.0.1 。(老师的是192.168.1.12)
-
修改 package.json,第8行的端口号8008 。
-
修改 app/javascript/app.js 修改ip地址和端口号 否则不能正常运行
vim app/javascript/app.js
window.web3 = new Web3(new Web3.providers.HttpProvider("http://192.168.1.12:8545"));//这是老师的,IP和第13步一样;端口号改成8545。
window.web3 = new Web3(new Web3.providers.HttpProvider("http://127.0.0.1:8545"));//这是我的。
- 启动
npm run dev
-
在浏览器地址栏输入
127.0.0.1:8008
,打开web前端。可以看到当前有10000个Meta币。给刚才复制的账号转88个币,输入88,粘贴地址,点击Send MetaCoin。之后,余额少了88个币。
再回到测试网络,可以看到,区块号增加了1。 -
演示结束。
Ctrl + Z
:停止左边的 web 服务,Ctrl + B
,→
:切换到右边窗口,Ctrl + C
:停止测试网络。exit
:关闭一个tmux窗口,退出 tmux,退出默认的终端,都是这个命令。
小结一下,本节简要介绍了Truffle的技术特性,演示了Truffle的安装过程,并运行了一个简单的实例。
不足之处,请批评指正。