Deploying smart contracts to the Ethereum mainnet using Hardhat involves several steps, including setting up your project, writing your contract, configuring your deployment script, and finally executing the deployment. This guide will walk you through the entire process.
1. Setting Up Your Hardhat Project
If you haven't already set up a Hardhat project, follow these steps:
mkdir my-hardhat-project
cd my-hardhat-project
npm init -y
npm install --save-dev hardhat
Next, initialize Hardhat:
npx hardhat
When prompted, choose to create an empty Hardhat configuration file.
2. Writing Your Smart Contract
Create a contracts
directory in your project root and add a simple contract file, for example, MyToken.sol
:
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
contract MyToken {
string public name = "MyToken";
string public symbol = "MTK";
uint256 public totalSupply;
constructor(uint256 _initialSupply) {
totalSupply = _initialSupply;
}
}
3. Configuring Your Deployment Script
Create a scripts
directory in your project root and add a deployment script, for example, deploy.js
:
const hre = require("hardhat");
async function main() {
const initialSupply = 1000000; // Specify the initial supply
const MyToken = await hre.ethers.getContractFactory("MyToken");
const myToken = await MyToken.deploy(initialSupply);
await myToken.deployed();
console.log("MyToken deployed to:", myToken.address);
}
main()
.then(() => process.exit(0))
.catch((error) => {
console.error(error);
process.exit(1);
});
4. Configuring Network Settings
To deploy to the Ethereum mainnet, you need to configure your Hardhat project to connect to the mainnet. Open your hardhat.config.js
file and add the following configuration:
require("@nomiclabs/hardhat-waffle");
require("@nomiclabs/hardhat-ethers");
require("dotenv").config();
module.exports = {
solidity: "0.8.0",
networks: {
mainnet: {
url: process.env.INFURA_URL, // Replace with your Infura/Alchemy URL
accounts: [process.env.PRIVATE_KEY], // Replace with your wallet's private key
},
},
};
Make sure to create a .env
file in your project root and add your Infura/Alchemy URL and your wallet's private key:
INFURA_URL=<your_infura_or_alchemy_url>
PRIVATE_KEY=<your_wallet_private_key>
5. Deploying Your Contract
Once everything is set up, you can deploy your contract to the Ethereum mainnet. Open your terminal and run the following command:
npx hardhat run scripts/deploy.js --network mainnet
This command will execute your deployment script and deploy your contract to the mainnet. If successful, you will see output similar to:
MyToken deployed to: 0xYourContractAddress
6. Verifying Your Contract on Etherscan (Optional)
After deploying your contract, you may want to verify it on Etherscan. You can use the Hardhat Etherscan plugin for this purpose. First, install the plugin:
npm install --save-dev @nomiclabs/hardhat-etherscan
Then, add the plugin to your hardhat.config.js
file:
require("@nomiclabs/hardhat-etherscan");
module.exports = {
// ... existing configuration
etherscan: {
apiKey: process.env.ETHERSCAN_API_KEY, // Add your Etherscan API key
},
};
Finally, verify your contract with the following command:
npx hardhat verify --network mainnet 0xYourContractAddress
Conclusion
Deploying contracts to the Ethereum mainnet using Hardhat is a straightforward process that involves setting up your project, writing your smart contract, configuring your deployment script, and executing the deployment. By following the steps outlined in this guide, you can successfully deploy your smart contracts and interact with the Ethereum blockchain. Always ensure that you test your contracts thoroughly on a test network before deploying to the mainnet to avoid costly mistakes.