Ethereum staking node orchestrator
Project description
Ethereum Staking Node
A complete Ethereum validator infrastructure running Geth (execution) + Prysm (consensus) + MEV-Boost on AWS ECS.
🏗️ Architecture
graph TB
subgraph Docker["Docker Container"]
subgraph Node["staker.node (Process Orchestrator)"]
Geth["Geth<br/>(Execution)"]
Beacon["Beacon Chain<br/>(Consensus)"]
Validator["Validator"]
MEV["MEV-Boost"]
VPN["VPN<br/>(optional)"]
end
end
subgraph AWS["AWS"]
ECS["ECS (EC2 Mode)"]
EBS["EBS Volume"]
Snapshot["EBS Snapshots"]
SSM["SSM Parameter Store"]
Lambda["Snapshot Validator<br/>(Lambda)"]
ASG["Auto Scaling Group"]
end
subgraph External["External"]
Relays["MEV Relays"]
Peers["P2P Network"]
end
Docker --> ECS
ECS --> EBS
Node --> Snapshot
Node --> SSM
Lambda --> SSM
Lambda --> Snapshot
MEV --> Relays
Geth --> Peers
Beacon --> Peers
ASG --> ECS
💖 Support
Love this tool? Your support means the world! ❤️
| Currency | Address | QR |
|---|---|---|
| ₿ BTC | bc1qwn7ea6s8wqx66hl5rr2supk4kv7qtcxnlqcqfk |
|
| Ξ ETH | 0x7cdB1861AC1B4385521a6e16dF198e7bc43fDE5f |
|
| ɱ XMR | 463fMSWyDrk9DVQ8QCiAir8TQd4h3aRAiDGA8CKKjknGaip7cnHGmS7bQmxSiS2aYtE9tT31Zf7dSbK1wyVARNgA9pkzVxX |
|
| ◈ BNB | 0x7cdB1861AC1B4385521a6e16dF198e7bc43fDE5f |
📦 Installation
PyPI (Recommended)
uv pip install staker
From Source
git clone https://github.com/alkalescent/ethereum.git
cd ethereum
uv sync
📁 Project Structure
src/staker/
├── config.py # Configuration constants and relay lists
├── environment.py # Runtime abstraction (AWS vs local)
├── mev.py # MEV relay selection and health checking
├── node.py # Main orchestrator - starts/monitors processes
├── snapshot.py # EBS snapshot management for persistence
└── utils.py # Utility functions (IP check, log coloring)
✅ Prerequisites
- uv (Python package manager)
- Docker
- AWS CLI (configured with appropriate permissions)
- Python 3.11+
⚙️ Configuration
Environment Variables
| Variable | Description | Required |
|---|---|---|
DEPLOY_ENV |
dev (Hoodi testnet) or prod (Mainnet) |
✅ |
ETH_ADDR |
Fee recipient address | ✅ |
AWS |
Set to true when running on AWS |
❌ |
DOCKER |
Set to true when running in container |
❌ |
VPN |
Set to true to enable VPN |
❌ |
Network Ports
| Port | Protocol | Purpose |
|---|---|---|
| 30303 | TCP/UDP | Geth P2P |
| 13000 | TCP | Prysm P2P |
| 12000 | UDP | Prysm P2P |
🛠️ Development
make install # Install dependencies
make lint # Run linting
make format # Format code
make test # Run tests
make cov # Run tests with coverage
make build # Build Docker image
make run # Run Docker container
make kill # Stop container gracefully
make deploy # Deploy to AWS
⚡ MEV Relays
The node connects to multiple MEV relays for optimal block building:
Mainnet: Flashbots, Ultra Sound, bloXroute, Aestus, Agnostic, Titan, Wenmerge
Hoodi: Flashbots, Aestus, bloXroute, Titan
Relays are automatically tested on startup; unreliable ones are filtered out.
💾 Backup Strategy
- Snapshots created every 30 days
- Maximum 3 snapshots retained (90 days)
- Automatic launch template updates with latest snapshot
- Graceful shutdown triggers snapshot on instance draining
📊 Version Info
| Component | Version |
|---|---|
| Geth | 1.16.7 |
| Prysm | v7.1.2 |
| MEV-Boost | 1.10.1 |
| Base Image | Ubuntu 24.04 |
📄 License
MIT License - see LICENSE for details.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file staker-0.2.0.tar.gz.
File metadata
- Download URL: staker-0.2.0.tar.gz
- Upload date:
- Size: 136.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5cdd18c869c3d6b4506da7766de2200fd13550a8912e5216461d5a335ad234b1
|
|
| MD5 |
f606539e0cfb05b3823ec68316a38a31
|
|
| BLAKE2b-256 |
97d878042cce37fa6f033e174a3f59b84f96fcf426e994a05875ee03f833d1ab
|
Provenance
The following attestation bundles were made for staker-0.2.0.tar.gz:
Publisher:
release.yml on alkalescent/ethereum
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
staker-0.2.0.tar.gz -
Subject digest:
5cdd18c869c3d6b4506da7766de2200fd13550a8912e5216461d5a335ad234b1 - Sigstore transparency entry: 832437390
- Sigstore integration time:
-
Permalink:
alkalescent/ethereum@f4c94d291b2a7d07791d0d44a10e3500a595a791 -
Branch / Tag:
refs/heads/master - Owner: https://github.com/alkalescent
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@f4c94d291b2a7d07791d0d44a10e3500a595a791 -
Trigger Event:
push
-
Statement type:
File details
Details for the file staker-0.2.0-py3-none-any.whl.
File metadata
- Download URL: staker-0.2.0-py3-none-any.whl
- Upload date:
- Size: 18.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
adf484978f5bee5b63ac76eddeb83e67ae2c70a8dd5cf6f90d957ec5a8b63ea0
|
|
| MD5 |
3153c39b20a00595c31687d06340c45b
|
|
| BLAKE2b-256 |
53f6cdb2ff81dc8339fe3ac47bdaef2802bf97135bfaffa294eb2bc1b5c19f36
|
Provenance
The following attestation bundles were made for staker-0.2.0-py3-none-any.whl:
Publisher:
release.yml on alkalescent/ethereum
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
staker-0.2.0-py3-none-any.whl -
Subject digest:
adf484978f5bee5b63ac76eddeb83e67ae2c70a8dd5cf6f90d957ec5a8b63ea0 - Sigstore transparency entry: 832437393
- Sigstore integration time:
-
Permalink:
alkalescent/ethereum@f4c94d291b2a7d07791d0d44a10e3500a595a791 -
Branch / Tag:
refs/heads/master - Owner: https://github.com/alkalescent
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@f4c94d291b2a7d07791d0d44a10e3500a595a791 -
Trigger Event:
push
-
Statement type: