CLBOSS The C-Lightning Node Manager
CLBOSS is an automated manager for C-Lightning forwarding nodes.
CLBOSS is effectively a bunch of heuristics modules wired together to a regular clock to continuously monitor your node.
Its design goal is to make it so that running a Lightning Network node is as simple as installing C-Lightning and CLBOSS, putting some amount of funds of 0.1BTC or more, and making sure you have continuous Internet and power to the hardware running it.
Current versions of CLBOSS might not achieve this goal yet perfectly, but hopefully with enough effort and iteration and raw coding and etc etc it will someday be as unusual to manually manage a Lightning node as writing (as opposed to reading) machine language is unusual today.
I hope CLBOSS can make the transition from pre-Lightning to post-Lightning much smoother in practice.
So far CLBOSS can do the following automatically:
- Open channels to other, useful nodes when fees are low and there are onchain funds
- Acquire incoming capacity via
boltz.exchange
swaps. - Rebalance open channels by self-payment (including JIT rebalancer).
- Set forwarding fees so that they're competitive to other nodes
Dependencies
If you are installing from some official source release tarball, you only need the below packages installed on a Debian or Debian-derived systems:
build-essential
pkg-config
libev-dev
libcurl4-gnutls-dev
libsqlite3-dev
Equivalent packages have a good probability of existing in non-Debian-derived distributions as well.
The following dependency is technically optional, but is strongly recommended (CLBOSS will check it at runtime so you do not need it while building):
dnsutils
If you have to build directly from github.com, you need the below Debian packages in addition:
git
automake
autoconf-archive
A design goal of CLBOSS is to reduce the above dependencies even further.
Installing
From an official source release, just:
./configure && make
sudo make install # or su first, then make install
This will install clboss
as a standard executable, usually in
/usr/local/bin/
by default.
You will then need to modify your lightning.conf
to add the
path to which clboss
as a plugin
or important-plugin
of
lightningd
.
From a git clone, you first need to execute:
autoreconf -i
Then run the ./configure && make && sudo make install
.
You can then add a plugin=/path/to/clboss
or
important-plugin=/path/to/clboss
setting to your C-Lightning
configuration file.
Operating
A goal of CLBOSS is that you never have to monitor or check your node, or CLBOSS, at all.
Nevertheless, CLBOSS exposes a few commands as well. Many of them are undocumented commands for internal testing, but some may be of interest to curious node operators, or those who have special use-cases.
clboss-status
This simply displays a bunch of status about a few of the modules CLBOSS has. Possibly the most interesting are these:
channel_candidates
- An array of nodes that we plan to eventually build channels to in the future, if we ever get onchain funds.score
only reaches up to 24 and saturates. Candidates are generally scored by the uptime they appear to have (CLBOSS tries toconnect
to them).internet
- Whether CLBOSS thinks we are online or offline right now. We generally check connectivity every 10 minutes, so you could be offline for shorter than that before CLBOSS notices. CLBOSS does not perform uptime measurements on other nodes if we are offline.onchain_feerate
- Sampled onchain feerate fornormal
, as well as whether CLBOSS currently thinks we are in a low-feerate or high-feerate time period. Also displayed is the various thresholds. If CLBOSS is inhigh fees
judgment, then if sampled feerates fall belowhi_to_lo
it switches tolow fees
. Vice versa, if it is inlow fees
it switches tohigh fees
if feerates go abovelo_to_hi
.init_mid
is the boundary used when CLBOSS starts up. CLBOSS tries to hold off on onchain activity (e.g. opening channels, swapping offchain funds to onchain addresses) during high fee periods except in extremis (e.g. you have no channels at all, or you have no or very little incoming liquidity).peer_metrics
- Various metrics on nodes we currently have channels to. Possibly the most interesting isconnect_rate
, which is the uptime we think they have.age
is in seconds. The metrics shown are for the last 3 days, though CLBOSS stores the raw statistics for the past two months.
clboss-externpay
If CLBOSS is managing a node for a custodial service, then you should
decodepay
the invoices provided by clients whose funds you are
custodying, and pass the payment_hash
as the sole argument to
clboss-externpay
.
CLBOSS gathers data for statistics by also monitoring pay
commands.
If pay
tries to route to a payee via a peer, but the payment
fails, CLBOSS considers it a failing of that peer, which should
really be monitoring its own peers and consider them bad and close
channels with them if delivering by those fails too often, with
the logic applied transitively (so even a remote failure is always
blamed on the first hop, because it should be monitoring its own
next hops, which should be monitoring their own next hops...).
Knowing that CLBOSS does this, a client of a custodial service can craft an unredeemable invoice in order to mess with those statistics, making a particular peer of the custodial service appear to be failing.
clboss-externpay
closes this attack by specifically ignoring
payments that match the given payment_hash
.
You should not use it when paying invoices to your employees or stakeholders, as presumably those have incentives aligned with you. Presumably they want to get paid, so would give you invoices they can redeem perfectly well.
clboss-ignore-onchain
, clboss-notice-onchain
Suppose you have the following story:
- You have a popular C-Lightning forwarding node that you are happily not managing because you are using CLBOSS The Automated C-Lightning Node Manager.
- A friend asks a favor to get some incoming liquidity.
- You should really talk them into running C-Lightning and CLBOSS themselves to get incoming liquidity
- You decide to help them out and give them some capacity.
- You take some funds from cold storage and send it onchain to your C-Lightning node.
- CLBOSS is so awesome, it takes those onchain funds and puts them into channels it has chosen rather than channels you wanted to choose.
- You end up not being able to help your friend.
- At this point you talk them into running C-Lightning and CLBOSS.
To help with this user story, CLBOSS provides the
clboss-ignore-onchain
command.
After executing this command, CLBOSS will temporarily ignore
onchain funds (with the side effect that it will not try to
get its own incoming liquidity by moving offchain funds to
onchain addresses, since those funds would end up being ignored
by CLBOSS instead of being managed).
CLBOSS will continue to rebalance your offchain funds, monitor
peers, check that channel candidates have high uptime, look for
new channel candidates, manage channel fees, and so on.
Then, you can perform onchain actions manually, such as moving cold storage into your Lightning node and making a channel manually for a friend.
clboss-ignore-onchain
accepts an optional hours
argument, a
number of hours that it will ignore onchain funds.
If not specified, this defaults to 24 hours.
Once you have completed any manual onchain funds management,
you can run clboss-notice-onchain
in order to let CLBOSS
resume normal operation.
In any case, clboss-ignore-onchain
is temporary and even
if you forget to issue clboss-notice-onchain
CLBOSS will
resume managing onchain funds at some point.
--clboss-min-onchain=<satoshis>
Pass this option to lightningd
in order to specify a target
amount that CLBOSS will leave onchain.
The amount specified must be an ordinary number, and must be
in satoshis unit, without any trailing units or other strings.
The default is "30000", or about 0.0003 BTC. The intent is that this minimal amount will be used in the future, by C-Lightning, to manage anchor-commitment channels, or post-Taproot Decker-Russell-Osuntokun channels. These channel types need some small amount of onchain funds to unilaterally close, so it is not recommended to set it to 0.
The amount specified is a ballpark figure, and CLBOSS may leave slightly lower or slightly higher than this amount.