With the recent introduction of the kvdb
interface LND can support multiple
database backends allowing experimentation with the storage model as well as
improving robustness through eg. replicating essential data.
Building on kvdb
in v0.11.0 we're adding experimental etcd
support to LND. As this is an unstable feature heavily in development, it still
has many rough edges for the time being. It is therefore highly recommended to
not use LND on etcd
in any kind of production environment especially not
on bitcoin mainnet.
To create a dev build of LND with etcd support use the following command:
⛰ make tags="kvdb_etcd"
The important tag is the kvdb_etcd
, without which the binary is built without
the etcd driver.
For development it is advised to set the GOFLAGS
environment variable to
"-tags=test"
otherwise gopls
won't work on code in channeldb/kvdb/etcd
directory.
To start your local etcd instance for testing run:
⛰ ./etcd \
--auto-tls \
--advertise-client-urls=https://127.0.0.1:2379 \
--listen-client-urls=https://0.0.0.0:2379 \
--max-txn-ops=16384 \
--max-request-bytes=104857600
The large max-txn-ops
and max-request-bytes
values are currently required in
case of running LND with the full graph in etcd. These parameters have been
tested to work with testnet LND.
To run LND with etcd, additional configuration is needed, specified either
through command line flags or in lnd.conf
.
Sample command line:
⛰ ./lnd-debug \
--db.backend=etcd \
--db.etcd.host=127.0.0.1:2379 \
--db.etcd.certfile=/home/user/etcd/bin/default.etcd/fixtures/client/cert.pem \
--db.etcd.keyfile=/home/user/etcd/bin/default.etcd/fixtures/client/key.pem \
--db.etcd.insecure_skip_verify
Sample lnd.conf
(with other setting omitted):
[db]
db.backend=etcd
db.etcd.host=127.0.0.1:2379
db.etcd.cerfile=/home/user/etcd/bin/default.etcd/fixtures/client/cert.pem
db.etcd.keyfile=/home/user/etcd/bin/default.etcd/fixtures/client/key.pem
db.etcd.insecure_skip_verify=true
Optionally users can specify db.etcd.user
and db.etcd.pass
for db user
authentication. If the database is shared, it is possible to separate our data
from other users by setting db.etcd.namespace
to an (already existing) etcd
namespace. In order to test without TLS, users are able to set db.etcd.disabletls
flag to true
.
This is currently not supported.
As mentioned before this is an experimental feature, and with that your data may be lost. Use at your own risk!