Skip to content

Latest commit

 

History

History
144 lines (96 loc) · 8.5 KB

README.md

File metadata and controls

144 lines (96 loc) · 8.5 KB

Ethereum Private Network with Kurtosis

Tests

This repository contains the necessary files to deploy a private Ethereum network using Kurtosis with the Ethereum Package.

TLDR to test this

Prerequisites

With Docker and Kurtosis CLI installed, you can run the following command to deploy the network:

kurtosis run --enclave private-testnet --args-file network_params.yaml .

If you want to run the network in a local Kubernetes cluster, that's outside the scope of the TLDR, but you can find the instructions in the Minikube section.

Reasoning behind this tool selection

As this repository is scoped to deploy a private Ethereum network, the tools selected were chosen to make the deployment as easy as possible. Kurtosis is a tool that allows you to deploy a network of services in a containerized environment, and it provides a simple way to define the network parameters and the services that will be deployed, allowing to integrate existing logging, monitoring, and testing tools used in the Ethereum ecosystem, while keeping an ample amount of flexibility that allows to use different combinations of Execution Layers (ELs) with Consensus Layers (CLs), using custom images, alternate validators, and different networks, like Goerli, Sepolia, Holesky, and others.

Additionally, the Ethereum Package being extended here is supported by multiple DevOps that are part of Ethereum, the Ethereum Foundation, and other organizations, giving a sense of trust and reliability to the package.

Why not use Docker Compose?

While Docker Compose is a great tool to deploy a network of services, it lacks some features that Kurtosis provides, such as the ability to define an API to modify the network, services and the ability to run tests on the network, giving the ability to create a package that can be shared with others—just as the Ethereum Package was built and it's being extended here—.

Why not use Helm?

When talking about packages the next tool that comes to mind is Helm—the package manager for Kubernetes—, but Helm is more focused on deploying applications in a Kubernetes cluster, and you might not be familiar with Kubernetes, and you might not want to learn it just to deploy a private Ethereum network for testing purposes.

Note

If you are looking to deploy a private Ethereum network in a production environment (or public Dev/Testnet networks), you should consider using Helm or other tools that are more focused for this purpose. Consider using https://github.com/ethpandaops/template-devnets or https://github.com/ethpandaops/ethereum-helm-charts

Caveats

Kurtosis is a tool that is still in development, and it might have some rough edges, but it's a great tool to deploy a network of services in a containerized environment, and it provides a simple way to define the network parameters and the services that will be deployed when paired with the Ethereum Package.

Unfortunately, Kurtosis doesn't have a way to easily migrate or deploy using other tools, such as Helm, Argo CD, or others, causing friction when trying to transition from a development environment to a production environment.

Warning

Right now, Kurtosis is best suited for loca/dev/testing use cases and simplifying onboarding to a distributed app. It's missing some features fto use it as a production deployment or infrastructure management tool.

Understanding Kurtosis and the Ethereum Package

The best places to start are:

Advanced topics

What to expect from this package

This package is mainly governed by the configurations in the network_params.yaml file, which is a YAML file that contains the parameters used to deploy the network, including:

  • Execution Layer (EL) and Consensus Layer (CL) configurations
  • Number of nodes
  • Node configurations
  • Network configurations
  • Service configurations
  • Test configurations
  • And more

The network_params.yaml file is the main file that you should look at to understand how the network is configured and what services are being deployed. You can extend this file to add more services, change the network configurations, or add more nodes to the network.

Included services

Nodes Monitoring

Explorers & Scanning

Testing

Services configuration and customization

The default services configuration can be find in the upstream Ethereum Package repository. Further customization can be done by extending the main.star file, which is a Starlark file that allows you to define the services that will be deployed in the network.

Minikube

If you want to run the network in a local Kubernetes cluster, you can use Minikube. To do so, you need to have Minikube installed and running, to do so, you can follow this instructions:

  • Install Minikube
  • Run minikube start
  • Copy these contents to kurtosis-config.yaml file in "$(kurtosis config path)":
config-version: 2
should-send-metrics: true
kurtosis-clusters:
  docker:
    type: "docker"
  minikube:
    type: "kubernetes"
    config:
      kubernetes-cluster-name: "minikube"
      storage-class: "standard"
      enclave-size-in-megabytes: 10
  • Run kurtosis cluster set minikube
  • In another terminal, run kurtosis gateway. This will act as a middle man between your computer's ports and your services deployed on Kubernetes ports and has to stay running as a separate process. More info: https://docs.kurtosis.com/k8s/#iv-configure-kurtosis
  • Run kurtosis engine restart --enclave-pool-size 3 (this step is optional, but it's recommended taking it as it improves the user experience during the enclave creation, specifically regarding speed)
  • Run kurtosis run --enclave private-testnet --args-file network_params.yaml .

Troubleshooting

If your minikube gets exhausted, you can run it with maximum resources available on your machine. This might be a bit overkill, but it's a good way to ensure that you have enough resources to run your Ethereum Network.

minikube start --memory=max --cpus=max

If you're having this error, it might be because your minikube is running out of resources:

ERRO[2024-09-30T19:57:16+01:00] An error occurred connecting to engine '35f9b86b4c674c95a30e075f3104f0e7':
Expected to be able to get a port forwarded connection to engine '35f9b86b4c674c95a30e075f3104f0e7', instead a non-nil error was returned
 --- at /root/project/cli/cli/kurtosis_gateway/live_engine_client_supplier/reconnecting_engine_client_supplier.go:160 (LiveEngineClientSupplier.replaceCurrentEngineInfo) ---
Caused by: Expected to be able to find an api endpoint for Kubernetes portforward to engine '35f9b86b4c674c95a30e075f3104f0e7', instead a non-nil error was returned
 --- at /root/project/cli/cli/kurtosis_gateway/connection/provider.go:69 (GatewayConnectionProvider.ForEngine) ---
Caused by: Expected to find exactly 1 running Kurtosis Engine pod, instead found '0'
 --- at /root/project/cli/cli/kurtosis_gateway/connection/provider.go:137 (GatewayConnectionProvider.getEnginePodPortforwardEndpoint) ---