Skip to content

lncapital/scaling-lightning

 
 

Repository files navigation

ScalingLN Twitter Banner

Scaling Lightning - A Testing Toolkit for the Lightning Network

This initiative aims to build a testing toolkit for the Lightning Network protocol, its implementations, and applications that depend on the Lightning Network.

The goal is to collaborate as an industry to help scale the Lightning Network and the applications that depend on it.

Current Roadmap

Getting started

The project is still far from complete.

Requirements:

  • Kubernetes.

    • If you are developing locally you can use Docker Desktop and enable Kubernetes in the dashboard.
    • Alternatively minikube has been tested to work. Please use minikube tunnel to enable traefik to get an "external" ip which the library and cli requires to communicate in to the sidecar clients.
    • SL has also been tested on Digital Ocean's hosted K8s cluster
    • Please let us know if you have run SL on a different cluster distribution such as Kind, K3s K0s or any other cloud provider
  • You also need Helm 3 and Helmfile. If you are on a Mac you can install them with Homebrew

      brew install helm helmfile
    
    • On Windows you can install using Scoop

      scoop install helm helmfile
      
  • Helm Diff:

    helm plugin install https://github.com/databus23/helm-diff
    
    • On Windows the plugin install does not complete correctly and you need to download the binary manually from https://github.com/databus23/helm-diff/releases . Unzip the diff.exe file and put it in the helm/plugins/helm-diff/bin folder (the bin folder has to be created). You can find the folder by running "helm env HELM_DATA_HOME"
  • Traefik:

    helm repo add traefik https://traefik.github.io/charts
    helm repo update
    helm install traefik traefik/traefik -n sl-traefik --create-namespace -f https://raw.githubusercontent.com/scaling-lightning/scaling-lightning/main/charts/traefik-values.yml
    

Starting a Network

To spin up an example network with 2 cln nodes and 4 lnd nodes, run:

go run . start -f examples/helmfiles/public.yaml

To destroy the network run:

go run . stop -f examples/helmfiles/public.yaml

Example CLI Commands

# list nodes on the network (names were taken from the helmfile)
go run . list

# get wallet balance of node named bitcoind
go run . walletbalance -n bitcoind

# get wallet balance of node named lnd2
go run . walletbalance -n lnd2

# send on-chain 1 million satoshis from bitcoind to cln1
go run . send -f bitcoind -t cln1 -a 1000000

# get the pubkey of a node named lnd1
go run . pubkey -n lnd1

# peer lnd1 and cln1 from lnd1
go run . connectpeer -f lnd1 -t cln1

# open channel between cln1 and lnd1 with a local balance on cln1 of 70k satoshis
go run . openchannel -f cln1 -t lnd1 -a 70000

# have bitcoind generate some blocks and pay itself the block reward
go run . generate -n bitcoind

Run the above from code instead of CLI

See examples/go/example_test.go. This test takes around 3 minutes to pass on an M1 Macbook Pro so you may need to adjust your test runner's default timeout.

Example go test command with extra timeout:

go test -run ^TestMain$ github.com/scaling-lightning/scaling-lightning/examples/go -count=1 -v -timeout=15m

Helpful Kubernetes commands

# list pods
kubectl -n sl get pods

# describe cln1 pod in more detail
kubectl -n sl describe pod cln1-0

# view logs of lnd1 node
kubectl -n sl logs -f lnd1-0

# view logs of a crashed bitcoind pod
kubectl -n sl logs -previous bitcoind-0

# view logs of lnd1's scaling lightning sidecar client (it handles our api requests and forwards them to the node)
kubectl -n sl logs -f -c lnd-client lnd1-0

# same for cln and bitcoind
kubectl -n sl logs -f -c cln-client cln1-0 
kubectl -n sl logs -f -c bitcoind-client bitcoind-0

# get shell into lnd1
kubectl -n sl exec -it lnd1-0 -- bash

# view loadbalancer public ip from traefik
kubectl -n sl-traefik get services

# destroy all scaling lightning nodes
kubectl delete namespace sl

# uninstall traefik
kubectl delete namespace sl-traefik

# uninstall traefik alternative
helm uninstall traefik -n sl-traefik

Note that the above commands assume you are using the default kubeconfig and context. You would need to add --kubeconfig path/to/file.yml or --context mycluster to all of the above commands if you wanted to look at a different cluster.

Your own configuration

This project is still in its infancy, so we don't have a lot of configuration options yet. Please take a look in the examples directory for examples of different networks.

Why is this important?

Currently, there are unknowns and untested assumptions about how the Lightning Network and its applications will react to shocks in transaction volume, channels, nodes, gossip messages, etc.

Having a set of tools and a signet Lightning Network will help:

  • Developers test their applications.
  • Researchers verify their assumptions.
  • Operators test their infrastructure.
  • Novices learn how the Lightning Network and various applications work in a somewhat realistic environment without risking real coins.

How will it work?

We are still in the early stages of planning, but the first tool we are building will be a tool to quickly generate one or more Lightning Nodes. These nodes can connect either to a public signet Lightning Network or a private Regtest Lightning Network for any combination of LN implementations (CLN, LND, LDK, Acinq etc.).

Other tools, made specifically for testing isolated parts of the protocol, are also relevant. These can help developers and researchers test their assumptions in an isolated environment. An example of this is The Million Channels Project developed by Rusty Russell to test gossip.

How is this different from Polar?

While Polar is an excellent project it is fundamentally different from what we want to achieve with the Scaling Lightning initiative. Polar is a desktop application meant to manually build a network through a drag and drop interface, which is great for novices and simple projects. However, it's not something that is suitable for a developer or testing environment at a startup or as a researcher. We have discussed and considered using parts of Polar or altering Polar, but it's not the right direction to go for Scaling Lightning.

Project milestones

This is an outline of the project's milestones. We will further detail these milestones using the features of GitHub's milestones and project management tools:

  • Create a basic kubernetes setup for running a Lightning Network.
  • Improve configurability and ease of use.
  • [-] Create a client for communication with Lightning Nodes.
    • LND
    • CLN
    • LDK
    • Eclair
  • [-] Create a client for communication with Bitcoin Nodes.
    • Bitcoind
    • btcd
  • [-] Create a library for programmatically interacting with the clients.
  • [-] Create a cli version of the library.
  • Create a tool for generating or simulating network activity.
  • Create a website to host the documentation, using Docusaurus.
  • Thoroughly document the project and provide instructions for use.
  • Document and provide links to supporting development resources.

How can you help?

  • We need developers to contribute to the toolkit.
  • We invite operators to run nodes on the Signet Lightning Network.
  • We encourage researchers to help design general tools relevant to them.
  • Donate to the project to help fund development and maintain the signet Lightning Network.

How can you reach us?

If you have any questions or want to join the project you can reach us here:

About

A Testing Toolkit for the Lightning Network

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 91.0%
  • Smarty 5.5%
  • Makefile 1.7%
  • Dockerfile 1.6%
  • Shell 0.2%