lnd
Run and interact with lnd Lightning Network daemon in Docker. Use for Lightning development, testing payment channels on regtest, managing lnd containers, and calling lnd RPC endpoints (getinfo, connect, open/close channels, pay/receive). Supports bitcoind, btcd, and neutrino backends.
$ インストール
git clone https://github.com/Roasbeef/claude-files /tmp/claude-files && cp -r /tmp/claude-files/skills/lnd ~/.claude/skills/claude-files// tip: Run this command in your terminal to install the skill
name: lnd description: Run and interact with lnd Lightning Network daemon in Docker. Use for Lightning development, testing payment channels on regtest, managing lnd containers, and calling lnd RPC endpoints (getinfo, connect, open/close channels, pay/receive). Supports bitcoind, btcd, and neutrino backends.
LND Lightning Network Skill
LND (Lightning Network Daemon) is a complete implementation of a Lightning Network node. This skill helps you run lnd in Docker for development and testing, with support for multiple backends.
Prerequisites
- Docker and Docker Compose installed
- (Optional)
ghCLI for building from GitHub PRs
Quick Start
Start the full regtest stack (Bitcoin Core + LND):
cd ~/.claude/skills/lnd/templates
docker-compose up -d --build # First time: builds lnd from source (~3-5 min)
docker-compose up -d # Subsequent runs: uses cached image
This starts:
lnd-bitcoind: Bitcoin Core 30 in regtest mode with ZMQlnd: LND built from local source
Notes:
- LND is built from source at
/users/roasbeef/gocode/src/github.com/lightningnetwork/lnd - First build takes ~3-5 minutes to compile Go code
- Uses
--noseedbackupfor testing (no wallet seed required)
Check status:
~/.claude/skills/lnd/scripts/lncli.sh getinfo
Backend Options
LND supports three backend options:
| Backend | Description | Best For |
|---|---|---|
| bitcoind | Bitcoin Core | Production, regtest development, interop testing |
| btcd | btcd (Go implementation) | Simnet testing, fast iteration |
| neutrino | Light client (BIP 157/158) | Testnet, mobile simulation |
Standalone Mode (bitcoind backend - default)
cd ~/.claude/skills/lnd/templates
docker-compose up -d
Shared Mode (interop with eclair)
# First start eclair's stack
cd ~/.claude/skills/eclair/templates
docker-compose up -d
# Then start lnd using eclair's bitcoind
cd ~/.claude/skills/lnd/templates
docker-compose -f docker-compose-shared.yml up -d
btcd Mode (simnet)
cd ~/.claude/skills/lnd/templates
docker-compose -f docker-compose-btcd.yml up -d
Neutrino Mode (light client)
cd ~/.claude/skills/lnd/templates
docker-compose -f docker-compose-neutrino.yml up -d
# Or with signet
NETWORK=signet docker-compose -f docker-compose-neutrino.yml up -d
Docker Management
Build Image (from lnd source)
# Build from current source
~/.claude/skills/lnd/scripts/docker-build.sh
# Build from a specific branch
~/.claude/skills/lnd/scripts/docker-build.sh --branch simple-taproot-chans
# Build from a GitHub PR
~/.claude/skills/lnd/scripts/docker-build.sh --pr 1234
# Build from a specific commit
~/.claude/skills/lnd/scripts/docker-build.sh --commit abc123
# Quick PR build (convenience wrapper)
~/.claude/skills/lnd/scripts/build-pr.sh 1234
Start Containers
# Start standalone stack (bitcoind + lnd)
~/.claude/skills/lnd/scripts/docker-start.sh
# Start in shared mode (uses external bitcoind)
~/.claude/skills/lnd/scripts/docker-start.sh --shared
# Start with btcd backend
~/.claude/skills/lnd/scripts/docker-start.sh --btcd
# Start in neutrino mode
~/.claude/skills/lnd/scripts/docker-start.sh --neutrino
# Rebuild before starting
~/.claude/skills/lnd/scripts/docker-start.sh --build
Stop Containers
# Stop containers (preserve data)
~/.claude/skills/lnd/scripts/docker-stop.sh
# Stop and remove volumes (clean state)
~/.claude/skills/lnd/scripts/docker-stop.sh --clean
View Logs
docker logs -f lnd
docker logs -f lnd-bitcoind
Essential lncli Operations
All commands use lncli.sh wrapper which auto-detects the lnd container.
Node Information
# Get node info
~/.claude/skills/lnd/scripts/lncli.sh getinfo
# Get wallet balance (on-chain)
~/.claude/skills/lnd/scripts/lncli.sh walletbalance
# Get channel balance (Lightning)
~/.claude/skills/lnd/scripts/lncli.sh channelbalance
Wallet & Addresses
# Get new address (native SegWit)
~/.claude/skills/lnd/scripts/lncli.sh newaddress p2wkh
# Get new address (nested SegWit)
~/.claude/skills/lnd/scripts/lncli.sh newaddress np2wkh
# Get new Taproot address
~/.claude/skills/lnd/scripts/lncli.sh newaddress p2tr
# Send on-chain
~/.claude/skills/lnd/scripts/lncli.sh sendcoins --addr=<address> --amt=<satoshis>
Connect to Peers
# Connect by URI
~/.claude/skills/lnd/scripts/lncli.sh connect <pubkey>@<host>:9735
# List connected peers
~/.claude/skills/lnd/scripts/lncli.sh listpeers
# Disconnect
~/.claude/skills/lnd/scripts/lncli.sh disconnect <pubkey>
Channel Management
# Open channel
~/.claude/skills/lnd/scripts/lncli.sh openchannel --node_key=<pubkey> --local_amt=1000000
# List channels
~/.claude/skills/lnd/scripts/lncli.sh listchannels
# Get channel balance
~/.claude/skills/lnd/scripts/lncli.sh channelbalance
# Close channel cooperatively
~/.claude/skills/lnd/scripts/lncli.sh closechannel --funding_txid=<txid> --output_index=<n>
# Force close channel
~/.claude/skills/lnd/scripts/lncli.sh closechannel --funding_txid=<txid> --output_index=<n> --force
Payments
# Create invoice
~/.claude/skills/lnd/scripts/lncli.sh addinvoice --amt=<satoshis> --memo="test payment"
# Decode invoice
~/.claude/skills/lnd/scripts/lncli.sh decodepayreq <bolt11_invoice>
# Pay invoice
~/.claude/skills/lnd/scripts/lncli.sh sendpayment --pay_req=<bolt11_invoice>
# List payments
~/.claude/skills/lnd/scripts/lncli.sh listpayments
# List invoices
~/.claude/skills/lnd/scripts/lncli.sh listinvoices
Regtest Development Workflow
1. Start the Stack
cd ~/.claude/skills/lnd/templates
docker-compose up -d
2. Initialize Regtest Environment
# Automated setup: mines blocks, funds lnd wallet
~/.claude/skills/lnd/scripts/regtest-setup.sh
Or manually:
# Mine blocks for coinbase maturity
~/.claude/skills/lnd/scripts/mine.sh 101
# Get lnd address
LND_ADDR=$(~/.claude/skills/lnd/scripts/lncli.sh newaddress p2wkh | jq -r '.address')
# Send funds to lnd
~/.claude/skills/lnd/scripts/bitcoin-cli.sh sendtoaddress $LND_ADDR 10
# Confirm transaction
~/.claude/skills/lnd/scripts/mine.sh 1
# Check balance
~/.claude/skills/lnd/scripts/lncli.sh walletbalance
3. Open a Channel (with second node)
# Connect to peer
~/.claude/skills/lnd/scripts/lncli.sh connect <nodeId>@<host>:9735
# Open 1M sat channel
~/.claude/skills/lnd/scripts/lncli.sh openchannel --node_key=<nodeId> --local_amt=1000000
# Mine blocks to confirm channel
~/.claude/skills/lnd/scripts/mine.sh 6
# Check channel status
~/.claude/skills/lnd/scripts/lncli.sh listchannels
4. Send a Payment
# On receiving node: create invoice
INVOICE=$( lncli addinvoice --amt=50000 --memo="test" | jq -r '.payment_request')
# On sending node: pay invoice
~/.claude/skills/lnd/scripts/lncli.sh sendpayment --pay_req=$INVOICE
Multi-Node Testing
Run multiple lnd nodes for peer-to-peer testing:
Start Multi-Node Stack
# Start alice and bob nodes
~/.claude/skills/lnd/scripts/docker-start.sh --multi --build
# Or with docker-compose directly
cd ~/.claude/skills/lnd/templates
docker-compose -f docker-compose-multi.yml up -d --build
Initialize Multi-Node Environment
# Full setup: fund wallets and open channel between alice and bob
~/.claude/skills/lnd/scripts/multi-node-setup.sh
# Or without channel
~/.claude/skills/lnd/scripts/multi-node-setup.sh --no-channel
Multi-Node Commands
# Use --node flag to specify which node
~/.claude/skills/lnd/scripts/lncli.sh --node alice getinfo
~/.claude/skills/lnd/scripts/lncli.sh --node bob getinfo
# Get pubkeys
ALICE_PUBKEY=$(~/.claude/skills/lnd/scripts/lncli.sh --node alice getinfo | jq -r '.identity_pubkey')
BOB_PUBKEY=$(~/.claude/skills/lnd/scripts/lncli.sh --node bob getinfo | jq -r '.identity_pubkey')
# Connect nodes
~/.claude/skills/lnd/scripts/lncli.sh --node alice connect ${BOB_PUBKEY}@lnd-bob:9735
# Open channel
~/.claude/skills/lnd/scripts/lncli.sh --node alice openchannel --node_key=$BOB_PUBKEY --local_amt=1000000
# Send payment from alice to bob
INVOICE=$(~/.claude/skills/lnd/scripts/lncli.sh --node bob addinvoice --amt=10000 | jq -r '.payment_request')
~/.claude/skills/lnd/scripts/lncli.sh --node alice sendpayment --pay_req=$INVOICE
Multi-Node Ports
| Node | P2P Port | gRPC Port | REST Port |
|---|---|---|---|
| alice | 9735 | 10009 | 8080 |
| bob | 9736 | 10010 | 8081 |
| charlie | 9737 | 10011 | 8082 |
Interop Testing with Eclair
Test channel operations between lnd and eclair:
# Terminal 1: Start eclair stack
cd ~/.claude/skills/eclair/templates
docker-compose up -d
~/.claude/skills/eclair/scripts/regtest-setup.sh
# Terminal 2: Start lnd with shared bitcoind
cd ~/.claude/skills/lnd/templates
docker-compose -f docker-compose-shared.yml up -d --build
# Wait for lnd to sync, then run setup
sleep 10
~/.claude/skills/lnd/scripts/regtest-setup.sh --quick
# Get eclair's pubkey
ECLAIR_PUBKEY=$(docker exec eclair eclair-cli -p devpassword getinfo | jq -r '.nodeId')
echo "Eclair pubkey: $ECLAIR_PUBKEY"
# Connect lnd to eclair
~/.claude/skills/lnd/scripts/lncli.sh connect ${ECLAIR_PUBKEY}@eclair:9735
# Open channel from lnd to eclair
~/.claude/skills/lnd/scripts/lncli.sh openchannel --node_key=$ECLAIR_PUBKEY --local_amt=1000000
# Mine to confirm
~/.claude/skills/eclair/scripts/mine.sh 6
# Check channels on both sides
~/.claude/skills/lnd/scripts/lncli.sh listchannels
docker exec eclair eclair-cli -p devpassword channels
Custom Arguments and Profiles
Pass extra arguments to lnd via LND_EXTRA_ARGS:
# Enable REST API on different port
LND_EXTRA_ARGS="--restlisten=0.0.0.0:8081" docker-compose up -d
# Enable debug logging for specific subsystems
LND_EXTRA_ARGS="--debuglevel=HSWC=trace,PEER=debug" docker-compose up -d
# Multiple extra args
LND_EXTRA_ARGS="--protocol.wumbo-channels --maxchansize=500000000" docker-compose up -d
Build Tags
LND supports various build tags for optional features:
| Tag | Description |
|---|---|
signrpc | Signing RPC service |
walletrpc | Wallet RPC service |
chainrpc | Chain RPC service |
invoicesrpc | Invoices RPC service |
routerrpc | Router RPC service |
peersrpc | Peers RPC service |
neutrinorpc | Neutrino RPC service |
watchtowerrpc | Watchtower RPC service |
kvdb_sqlite | SQLite database backend |
kvdb_postgres | PostgreSQL database backend |
dev | Development features |
Build with custom tags:
~/.claude/skills/lnd/scripts/docker-build.sh --tags "signrpc walletrpc routerrpc dev"
Helper Scripts
| Script | Description |
|---|---|
docker-build.sh | Build lnd image with branch/PR/commit support |
docker-start.sh | Start containers with mode selection |
docker-stop.sh | Stop containers, optionally clean volumes |
lncli.sh | Wrapper for lncli with container and node auto-detection |
bitcoin-cli.sh | Wrapper for bitcoin-cli |
mine.sh | Mine regtest blocks |
regtest-setup.sh | Initialize regtest with funded wallet |
multi-node-setup.sh | Initialize multi-node with funded wallets and channels |
build-pr.sh | Quick PR build convenience wrapper |
Environment Variables
| Variable | Description | Default |
|---|---|---|
LND_SOURCE | Path to lnd source directory | /users/roasbeef/gocode/src/github.com/lightningnetwork/lnd |
LND_IMAGE | Docker image tag | lnd:local |
LND_DEBUG | Log level | debug |
LND_EXTRA_ARGS | Additional lnd arguments | (empty) |
NETWORK | Bitcoin network | regtest |
BACKEND | Backend: bitcoind, btcd, neutrino | bitcoind |
Ports
| Port | Service | Description |
|---|---|---|
| 9735 | Lightning | Peer-to-peer Lightning protocol |
| 10009 | gRPC | LND RPC (for lncli) |
| 8080 | REST | REST API |
| 18443 | Bitcoin RPC | Bitcoin Core RPC (regtest) |
| 28332 | ZMQ | Block notifications |
| 28333 | ZMQ | Transaction notifications |
Troubleshooting
"transport: Error while dialing dial tcp: connection refused"
- LND is still starting up. Wait a few seconds and retry.
- Check logs:
docker logs lnd
"unable to find a path to destination"
- No route to the destination. Check channel balances.
- Run:
lncli.sh listchannelsto see local/remote balances
Channel stuck in "pending open"
- Mine blocks to confirm:
~/.claude/skills/lnd/scripts/mine.sh 6
"insufficient funds available"
- Check wallet balance:
lncli.sh walletbalance - Fund wallet using regtest-setup.sh
"rpc error: code = Unknown desc = chain backend is still syncing"
- LND is syncing with the blockchain. Wait for sync to complete.
- Check:
lncli.sh getinfoand look atsynced_to_chain
Build fails with "go: module requires Go X.Y"
- Update Go version or use
--prodflag for production Dockerfile
Further Reading
- API Reference - gRPC and REST API documentation
- LND GitHub - Official repository
- LND Documentation - Official docs
- BOLT Specifications - Lightning Network protocol specs
