Skip to content

Latest commit

 

History

History
134 lines (93 loc) · 4.99 KB

README.md

File metadata and controls

134 lines (93 loc) · 4.99 KB

ephemery

Guide to getting started with the Ethereum Ephemery Testnet quickly

https://ephemery.dev is the central repository for all things Ephemery

These notes draw heavily on documentation in T-ess's guide based on geth and lodestar.

0. Notes

This guide will become outdated VERY quickly! It's meant to capture a moment in time of Ephemery development, and unless it has been updated recently will be mostly useless after a month.

Everything in this guide is free for anyone to follow, including the software and Ephemery Ether. The only things that could incur an expense are the hardware and Internet connection. Virtual Private Servers (VPS) services often provide a server that you can use for around $6 a month.

1. Test machine setup

This demonstration is being done on an Ubuntu 24.04.1 (Noble Numbat) Desktop installed on a VirtualBox Virtual machine.

  • The Desktop version isn't generally recommended for running a validator, but it won't hurt and I'm using it to make copy/pasting easier when I create the video.
  • I installed the VirtualBox Additions before starting this guide. It isn't necessary to do this, but you can.
  • In order to install VirtualBox Additions, I also installed some pre-requisites: sudo apt install gcc make perl

2. The big picture

Running an Ethereum validator requires two different pieces of software to work together, these are called the Execution client (historically called an "Eth1 client") and the Consensus client (the "Eth2 cleint). They work in concert, with the execution client managing transactions and the consensus client managing the chain. In order to have a validator running, we'll need both of these clients up and running, then we can deposit 32 [Ephemery]Ether to be a validator.

3. Execution Client

Because of a deep desire to develop client diversity I strongly suggest that people use a different execution client, but because Ephemery is still in development, I'm using what's available.

Install dependencies

sudo apt install golang-go curl nodejs git default-jre make gcc
sudo npm install --global yarn

Download the Ephemery testnet configuration files

Download the testnet-all.tar.gz file for the latest release of the Ephemery testnet to this directory using wget. Then unzip inside this folder. Note that the link in the example is likely to be outdated.

cd ~
mkdir testnet-all
cd testnet-all
wget https://github.com/ephemery-testnet/ephemery-genesis/releases/download/ephemery-138/testnet-all.tar.gz #this is likely to be an outdated resource
tar -xzf testnet-all.tar.gz

Generate a jwt token to allow Eth1 and Eth2 clients to communicate.

The following command will generate a secret to ensure secure communication between the Execution Client and the Consensus client at /tmp/jwtsecret. Be mindful that using a jwt may require additional flags to be provided.

openssl rand -hex 32 | tr -d "\n" > "/tmp/jwtsecret"

Download geth

cd ~
wget https://gethstore.blob.core.windows.net/builds/geth-linux-amd64-1.14.11-f3c696fa.tar.gz
tar xvf geth-linux-amd64-1.14.11-f3c696fa.tar.gz
sudo mv geth-linux-amd64-1.14.11-f3c696fa/geth /usr/local/bin/
rm -rf ~/geth-linux-amd64-1.14.11-f3c696fa*

Initialize Geth with Ephemery settings

sudo mkdir /var/lib/geth
cd ~
sudo geth init --datadir "/var/lib/geth" ~/testnet-all/genesis.json

Create a system service

echo "[Unit]
Description=Geth Ethereum Node
After=network.target

[Service]
Type=simple
User=geth
ExecStart=/usr/lcoal/bin/geth --networkid 39438138 --syncmode=full --port 30303 --http --datadir \"/var/lib/geth\" --authrpc.jwtsecret=/tmp/jwtsecret --bootnodes enode://50a54ecbd2175497640bcf46a25bbe9bb4fae51d7cc2a29ef4947a7ee17496cf39a699b7fe6b703ed0feb9dbaae7e44fc3827fcb7435ca9ac6de4daa4d983b3d@137.74.203.240:30303
Restart=on-failure

[Install]
WantedBy=multi-user.target" | sudo tee /etc/systemd/system/geth.service

Enable and start the service

sudo systemctl enable geth.service
sudo systemctl daemon-reload
sudo systemctl start geth.service
sudo journalctl -f -u geth.service

(Press "Ctrl + C" to stop watching the log. Type "journalctl -f -u geth" to see it again.

4. Consensus Client

Lodestar is a powerful consensus client developed in TypeScript. I gladly encourage using Lodestar on a production validator!

Download and build Lodestar

cd ~
git clone https://github.com/chainsafe/lodestar.git
cd lodestar
yarn
yarn run build

5. Set up MetaMask

6. Get Ephemery Ether

https://ephemery-faucet.pk910.de/

7. Creating the validator keys and deposit data

7. Set up the validator

8. Import the validator keys

./lodestar validator import --importKeystores ../validator_keys --dataDir /home/phiz/datadir-lodestar --importKeystoresPassword ./password.txt

9. Making the deposit

10. Monitoring progress