以下是通过truffle框架将智能合约部署到Ganache的步骤
-
-
- Truffle简介
- 环境准备:
- [智能合约 编写 & 编译](#智能合约 编写 & 编译)
- 部署合约
- 运行Truffle迁移(部署):
- 与智能合约交互:
-
-
以下是通过truffle框架将智能合约部署到Ganache的步骤。
Truffle简介
- Truffle是一个开发框架,用于编写、编译、测试和部署智能合约。
- 官方文档:https://learnblockchain.cn/docs/truffle/quickstart.html
环境准备:
npm install -g truffle
// 安装Truffletruffle init
// 初始化Truffle项目 : 创建没有合约的空工程(三个空文件夹和一个配置文件) 初始化Truffle项目后会生成以下文件内容:
目录/文件 | 描述 |
---|---|
contracts/ |
Solidity合约目录 |
migrations/ |
部署脚本文件目录 |
test/ |
测试脚本目录,参考 如何测试合约于应用? |
truffle-config.js |
Truffle 配置文件 |
智能合约 编写 & 编译
-
在
contracts/
目录下创建一个新的合约文件MyContract.sol
。以下是一个简单的Solidity合约示例:solidity// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; contract MyContract { string public message; constructor(string memory _message) { message = _message; } function setMessage(string memory _newMessage) public { message = _newMessage; } function getMessage() public view returns (string memory) { return message; } }
-
在Truffle项目目录中,运行以下命令编译合约:
bashtruffle compile --all
-
编译后,会在
build/
目录中生成合约的ABI和字节码。
部署合约
本地服务器ganache配置
ganache
是一个区块链模拟器,用于在本地快速启动一个区块链网络,方便进行以太坊智能合约的开发、测试和调试。以下是 ganache
的安装和配置步骤:
- 安装&配置ganache-ui :
- 从Ganache官网下载安装。
- 启动Ganache,选择"Quickstart"或"New Workspace",这会启动一个本地以太坊区块链。
- 安装&配置ganache-cli :
-
ganache-cli使用 ethereumjs 来模拟完整的客户端行为,使开发 Ethereum 应用程序更快、更轻松、更安全: npm install -g ganache-cli
-
安装完成后,可以通过
ganache-cli
命令启动。运行后,ganache-cli
会启动一个本地的以太坊区块链网络,默认监听127.0.0.1:8545
。它会自动生成一组测试账户,并输出账户地址、私钥和初始余额。
-
网络配置
-
编辑
truffle-config.js
文件,在module.exports
里添加一个Ganache网络配置:javascriptmodule.exports = { networks: { development: { // The `development` name is special - truffle uses it by default host: "127.0.0.1", // Ganache的默认主机 port: 7545, // Ganache的默认端口 network_id: "*", // 匹配任何网络ID } }, compilers: { solc: { version: "0.8.0", // 确保Solidity版本与合约一致 } } };
部署合约:
-
在
migrations/
目录中创建一个新的部署脚本1_deploy_contracts.js
:javascriptconst MyContract = artifacts.require("MyContract"); module.exports = function(deployer) { deployer.deploy(MyContract, "Hello, Ganache!"); // 传递合约构造函数的参数 };
-
请注意,文件名以数字为前缀,后缀为描述。 编号前缀是必需的,以便记录迁移是否成功运行。 后缀纯粹是为了人类的可读性和理解力。
运行Truffle迁移(部署):
- 运行以下命令,将智能合约部署到本地的Ganache:
bash
truffle migrate
-
如果成功,将在终端看到合约的部署地址和交易哈希:
➜ workspace git:(main) ✗ truffle migrate
Compiling your contracts...
Everything is up to date, there is nothing to compile.
Starting migrations...
Network name: 'development'
Network id: 1729253904535
Block gas limit: 6721975 (0x6691b7)1_deploy_contracts.js
Deploying 'MyContract' ---------------------- > transaction hash: 0xe988ba8520d9615713e7f1789df1cb072b63219f95ec7adbc1c278aac603ad82 > Blocks: 0 Seconds: 0 > contract address: 0x4Df552fC25A888fC7F792336cD730b9557093828 > block number: 1 > block timestamp: 1729254735 > account: 0x12D5297B2BC267c2744f0feD9CdE75517ae9e8E9 > balance: 99.99268388 > gas used: 365806 (0x594ee) > gas price: 20 gwei > value sent: 0 ETH > total cost: 0.00731612 ETH > Saving artifacts ------------------------------------- > Total cost: 0.00731612 ETH
Summary
Total deployments: 1
Final cost: 0.00731612 ETH -
相应的
ganache-cli
窗口输出:➜ workspace git:(main) ✗ ganache-cli
Ganache CLI v6.12.2 (ganache-core: 2.13.2)Available Accounts
(0) 0x12D5297B2BC267c2744f0feD9CdE75517ae9e8E9 (100 ETH)
(1) 0xA93b4B4f9f40527b5D86eF3621Ab4fb55BE281E8 (100 ETH)
(2) 0xE7DdbEC43D86aE23056cF5581d7D120b41D93248 (100 ETH)
(3) 0x44BCF5058eB95eD5adD4E248AcfF6A1aea5a2519 (100 ETH)
(4) 0x547184E5C9aC0348Deb933c590C6Cb78aB9cecFf (100 ETH)
(5) 0xd4C82Ae01f95b7B12d92E7a8B47478CBAE77C562 (100 ETH)
(6) 0x44B75857234B696B8cea72F3c427683fF5323f12 (100 ETH)
(7) 0x8c2eF5456E31B2b1459716165CB605327B334882 (100 ETH)
(8) 0x4b0FD868C085d6B9b7A8B62298B4bCFb7f3769a1 (100 ETH)
(9) 0xe46A1b806103A60d92404A09c61617273b8e6dEa (100 ETH)Private Keys
(0) 0x07327b119a204389d69a02b9136705b1067f5d968b22878d8f41f23733ff62ca
(1) 0xfc069a75ff3a18a08f4fafe442e276d0de4c157ea10c8d3b2f17211bb5c94a8a
(2) 0x8e20cfa72180812c0079e79e750344108449e4f1365d835ab59893a2ed22edea
(3) 0xac77c1975b2ae054c912e62cdf029801c19c4d628bc81b1136d6269d83b553f0
(4) 0x43655a225f3da0ff9fb80012d3997d2a6b99f5b04f5e5d0147f735503e09e7e2
(5) 0xa15f7b04deee6a1c6b2f42786096db257ce0c98a51dc818255f2cd126736e528
(6) 0x3337be6e13fc27d0bbd6c208e6a25b4fc1d57d1df789c3033c042e0302dbeb2a
(7) 0x7ae3ab9e4ca935eef800d4e4875014ad2194e3ba1f74c95fad16c308cac5a6aa
(8) 0xad3b9f7c0f29e8d5955de28aa66bb7374d730fac521e9bd308838c955876a4e2
(9) 0xdc0cffd4ebbcc4a94fced27f8a434bab5f788b72da49ac6e1f5742e2e8170bf7HD Wallet
Mnemonic: blade tree catalog abuse curve woman round jewel hard civil antenna load
Base HD Path: m/44'/60'/0'/0/{account_index}Gas Price
20000000000
Gas Limit
6721975
Call Gas Limit
9007199254740991
Listening on 127.0.0.1:8545
eth_blockNumber
net_version
............
eth_gasPrice
eth_sendTransactionTransaction: 0xe988ba8520d9615713e7f1789df1cb072b63219f95ec7adbc1c278aac603ad82 Contract created: 0x4df552fc25a888fc7f792336cd730b9557093828 Gas usage: 365806 Block Number: 1 Block Time: Fri Oct 18 2024 12:32:15 GMT+0000 (Coordinated Universal Time)
eth_getTransactionReceipt
eth_getCode
eth_getTransactionByHash
eth_getBlockByNumber
eth_getBalance
与智能合约交互:
-
部署完成后,可以使用Truffle控制台与智能合约交互:
bashtruffle console
在控制台中,运行以下命令与已部署的智能合约进行交互:
javascript// 获取部署的合约实例 let instance = await MyContract.deployed(); // 调用getMessage()函数 let message = await instance.getMessage(); console.log(message); // 输出:Hello, Ganache! // 调用setMessage()函数 await instance.setMessage("New message on Ganache"); // 再次调用getMessage()函数 message = await instance.getMessage(); console.log(message); // 输出:New message on Ganache
-
相应的
ganache-cli
窗口输出:Transaction: 0xca9657eb639ba2ebd29f9e887d5e08ecc3d9c89c8dadf5333dc33b61eb97cfd8
Gas usage: 29576
Block Number: 2
Block Time: Fri Oct 18 2024 12:37:49 GMT+0000 (Coordinated Universal Time)