Frequently Asked Questions
Table of contents
- Can I get rich by routing Lightning payments?
- Can I attach the Ext4 formatted hard disk to my Windows computer?
- What do all the Linux commands do?
- Where can I get more information?
- How to upgrade Bitcoin Core?
- How to upgrade LND?
- How to upgrade Electrs
- Why do I need the 32 bit version of Bitcoin when I have a Raspberry Pi 4 with a 64 bit processor?
- Setting a fixed address on the Raspberry Pi
Can I get rich by routing Lightning payments?
Nobody knows. Probably not. You will get minimal fees. I don’t care. Enjoy the ride!
Can I attach the Ext4 formatted hard disk to my Windows computer?
The Ext4 file system is not compatible with standard Windows, but with additional software like Linux File Systems by Paragon Software (they offer a 10 days free trial) it is possible.
What do all the Linux commands do?
This is a (very) short list of common Linux commands for your reference. For a specific command, you can enter man [command]
to display the manual page (type q
to exit).
command | description | example |
---|---|---|
cd | change to directory | cd /home/bitcoin |
ls | list directory content | ls -la /mnt/ext |
cp | copy | cp file.txt newfile.txt |
mv | move | mv file.txt moved_file.txt |
rm | remove | rm temporaryfile.txt |
mkdir | make directory | mkdir /home/bitcoin/newdirectory |
ln | make link | ln -s /target_directory /link |
sudo | run command as superuser | sudo nano textfile.txt |
su | switch to different user account | sudo su bitcoin |
chown | change file owner | chown bitcoin:bitcoin myfile.txt |
chmod | change file permissions | chmod +x executable.script |
nano | text file editor | nano textfile.txt |
tar | archive tool | tar -cvf archive.tar file1.txt file2.txt |
exit | exit current user session | exit |
systemctl | control systemd service | sudo systemctl start bitcoind |
journalctl | query systemd journal | sudo journalctl -u bitcoind |
htop | monitor processes & resource usage | htop |
shutdown | shutdown or restart Pi | sudo shutdown -r now |
Where can I get more information?
If you want to learn more about Bitcoin and are curious about the inner workings of the Lightning Network, the following articles in Bitcoin Magazine offer a very good introduction:
- What is Bitcoin?
- Understanding the Lightning Network
- Bitcoin resources and Lightning Network resources by Jameson Lopp
- Lightning Network resources: lnroute.com
How to upgrade Bitcoin Core?
The latest release can be found on the Github page of the Bitcoin Core project. Make sure to read the Release Notes, as these can include important upgrade information. https://github.com/bitcoin/bitcoin/releases
-
You might want to create a backup of your system first.
-
As “admin” user, stop the lnd and bitcoind system units
$ sudo systemctl stop lnd
$ sudo systemctl stop bitcoind
-
Download, verify, extract and install the Bitcoin Core binaries as described in the Bitcoin section of this guide.
-
Start the bitcoind and lnd system units
$ sudo systemctl start bitcoind
$ sudo systemctl start lnd
:information_source: Please be aware that the internal data structure of Bitcoin Core changed from 0.16 to 0.17. If you download the blockchain using a different computer, make sure to use the same version. If you upgrade to 0.17, the data structure is converted automatically (can take a few hours) and it’s not possible to use that data with older versions anymore.
How to upgrade LND?
Upgrading LND can lead to a number of issues. Please always read the LND release notes completely to understand the changes. These also cover a lot of additional topics and many new features not mentioned here.
-
You might want to create a backup of your system first
-
Check your lnd version
$ lnd --version
Starting with version 0.5, upgrading LND got more reliable. When upgrading from an earlier version (< v0.5), please follow the detailed procedure in the next section, otherwise you can do a standard update described here.
-
As “admin” user, stop lnd system unit
$ sudo systemctl stop lnd
-
Download, verify and install the latest LND binaries as described in the Lightning section of this guide.
-
Restart the services with the new configuration and unlock the wallet with the “bitcoin” user.
$ sudo systemctl restart bitcoind $ sudo systemctl restart lnd $ sudo su - bitcoin $ lncli unlock $ exit
Upgrading LND Version < 0.5
-
I would recommend to close your channels first, as there have been a number of issues with stuck funds that require very technical work to resolve them.
-
As “admin” user, stop lnd system unit.
$ sudo systemctl stop lnd
-
delete the macaroon files.
$ sudo rm /home/bitcoin/.lnd/*.macaroon
- Remove old stuff, then download, verify and install the latest LND binaries
$ cd /home/admin/download $ rm -f lnd-linux* manifest* pgp_keys.asc $ wget https://github.com/lightningnetwork/lnd/releases/download/v0.5-beta/lnd-linux-armv7-v0.5-beta.tar.gz $ wget https://github.com/lightningnetwork/lnd/releases/download/v0.5-beta/manifest-v0.5-beta.txt $ wget https://github.com/lightningnetwork/lnd/releases/download/v0.5-beta/manifest-v0.5-beta.txt.sig $ wget https://keybase.io/roasbeef/pgp_keys.asc $ sha256sum --check manifest-v0.5-beta.txt --ignore-missing > lnd-linux-armv7-v0.5-beta.tar.gz: OK $ gpg ./pgp_keys.asc > BD599672C804AF2770869A048B80CD2BB8BD8132 $ gpg --import ./pgp_keys.asc $ gpg --verify manifest-v0.5-beta.txt.sig > gpg: Good signature from "Olaoluwa Osuntokun <laolu32@gmail.com>" [unknown] > Primary key fingerprint: BD59 9672 C804 AF27 7086 9A04 8B80 CD2B B8BD 8132 > Subkey fingerprint: F803 7E70 C12C 7A26 3C03 2508 CE58 F7F8 E20F D9A2 $ tar -xzf lnd-linux-armv7-v0.5-beta.tar.gz $ sudo install -m 0755 -o root -g root -t /usr/local/bin lnd-linux-armv7-v0.5-beta/* $ lnd --version > lnd version 0.5.0-beta commit=3b2c807288b1b7f40d609533c1e96a510ac5fa6d
- Starting with 0.5 release, LND expects two different ZMQ sockets for blocks and transactions. Edit
bitcoin.conf
, save and exit.$ sudo nano /home/bitcoin/.bitcoin/bitcoin.conf zmqpubrawblock=tcp://127.0.0.1:28332 zmqpubrawtx=tcp://127.0.0.1:28333
- The option
debughtlc
is no longer allowed and needs to be deleted. Editlnd.conf
, save and exit.$ sudo nano /home/bitcoin/.lnd/lnd.conf #debughtlc=true
- Restart the services with the new configuration and unlock the wallet with the “bitcoin” user. This creates a new set of macaroons (explained below).
$ sudo systemctl restart bitcoind $ sudo systemctl restart lnd $ sudo su - bitcoin $ lncli unlock $ exit
The macaroons are now located under the chain data directory for each supported network. For example, the mainnet admin macaroon for Bitcoin is now located here: /home/bitcoin/.lnd/data/chain/bitcoin/mainnet/admin.macaroon
- Copy the new set of macaroons to your admin user, otherwise this user cannot use
lncli
. The new macaroon location also affects the auto-unlock script you might be running.- For mainnet use these commands:
$ rm /home/admin/.lnd/admin.macaroon $ mkdir -p /home/admin/.lnd/data/chain/bitcoin/mainnet/ $ sudo cp /home/bitcoin/.lnd/data/chain/bitcoin/mainnet/admin.macaroon /home/admin/.lnd/data/chain/bitcoin/mainnet/ $ sudo cp /home/bitcoin/.lnd/tls.cert /home/admin/.lnd $ sudo chown -R admin:admin /home/admin/.lnd $ lncli getinfo
- If you’re on testnet, use the commands for mainnet above, but replace the directory “mainnet” with “testnet”. You will also need to always use
lncli --network=testnet
, so for examplelncli --network=testnet getinfo
. See the release notes on how to create an alias to avoid typing this every time.
- For mainnet use these commands:
- Don’t forget to unlock your wallet & check logs
$ lncli unlock
$ sudo journalctl -u lnd -f
How to upgrade Electrs
For upgrading from a prior version, first check what version you have
$ cd /home/admin/rust
$ currentelectrs=$(head -n 1 electrs/RELEASE-NOTES.md | awk '{print v$2}')
$ echo "Current = ${currentelectrs}"
$ electrsgit=$(curl -s https://api.github.com/repos/romanz/electrs/tags | jq -r '.[0].name')
$ echo "Available = ${electrsgit}"
If the available version is newer, then you can proceed with the following
$ # backup the current one
$ mv electrs electrs-v${currentelectrs};
$ # clone the most recent tagged version
$ git clone --branch ${electrsgit} https://github.com/romanz/electrs.git
$ # Build it
$ cd electrs
$ cargo build --locked --release
$ # Stop the service, copy the binary over, and start the service back up
$ sudo systemctl stop electrs
$ sudo cp ./target/release/electrs /usr/local/bin/
$ sudo systemctl start electrs
Why do I need the 32 bit version of Bitcoin when I have a Raspberry Pi 4 with a 64 bit processor?
At the time of this writing (March 2020) there is no 64 bit operating system for the Raspberry Pi developed yet. The 64 bit processors of the Raspberry Pi 4 versions are running in 32 bit compatibility mode with a 32 bit operating system.
Setting a fixed address on the Raspberry Pi
If your router does not support setting a static ip address for a single device, you can also do this directly on the Raspberry Pi.
This can be done by configuring the DHCP-Client (on the Pi) to advertise a static IP address to the DHCP-Server (often the router) before it automatically assigns a different one to the Raspberry Pi.
-
Get ip address of default gateway (router). Run
netstat -r -n
and choose the IP address from the gateway column which is not0.0.0.0
. In my occasion it’s192.168.178.1
. - Configure the static IP address for the Pi, the gateway path and a DNS server. The configuration for the DHCP client (Pi) is located in the
/etc/dhcpcd.conf
file:sudo nano /etc/dhcpcd.conf
The following snippet is an example of a sample configuration. Change the value of
static routers
andstatic domain_name_servers
to the IP of your router (default gateway) from step 1. Be aware of giving the Raspberry Pi an address which is OUTSIDE the range of addresses which are assigned by the DHCP server. You can get this range by looking under the router configurations page and checking for the range of the DHCP addresses. This means, that if the DHCP range goes from192.168.178.1
to192.168.2.99
you’re good to go with the IP192.168.178.100
for your Raspberry Pi.Add the following to the
/etc/dhcpcd.conf
file:# Configuration static IP address (CHANGE THE VALUES TO FIT FOR YOUR NETWORK) interface eth0 static ip_address=192.168.178.100/24 static routers=192.168.178.1 static domain_name_servers=192.168.178.1
- Restart networking system
sudo /etc/init.d/networking restart
« Back: Troubleshooting