Skip to content

Umbrel migration from Raspberry Pi to NUC / Laptop running Linux

Notifications You must be signed in to change notification settings

indomitorum/Umbrel-migration-Pi-to-NUC

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 

Repository files navigation

Umbrel Migration from Raspberry Pi to NUC / Laptop running Linux

I chose Debian OS as it’s meant to be better for running a node keeping the file system in better order. In case of drive failure, Debian is superior at recovering bad blocks and repairing them but you can use Ubuntu if you prefer or even Mint.

Installation of Linux and Umbrel in new machine

  1. Install the Linux OS flavour of choice in your machine
  2. Update it
  • sudo apt update & sudo apt upgrade & sudo reboot
  1. Install Umbrel on Linux
  • https://github.com/getumbrel/umbrel#-installation
  • Scroll down to Installation Requirements and install docker / Python / docker compose, fswatch, jq, rsync, curl, git
  • Create an Umbrel directory - mkdir umbrel & cd umbrel
  • Download Umbrel in the above directory
  • Run Umbrel on new machine : sudo ./scripts/start
  • Let it sync a few blocks

Migration Process

Raspberry Pi

  1. ssh in to the R Pi
  2. I recommend uninstalling all apps as when I tested the migration with apps, I run into problems. If you want to keep for example LNDg database so you don’t lose anything, before deleting it:
  • stop LNDg (GUI or ~/umbrel/scripts/app stop lndg)
  • Copy the database from ~/umbrel/app-data/lndg/db.sqlite3 to ~/umbrel
  1. Uninstall all apps
  2. sudo scripts/stop
  3. Ensuring the channel.db file integrity is crucial so you don’t end up penalised starting the new node with an old / corrupted channel.db which would be a disaster.
  • cd umbrel/lnd/data/graph/mainnet
  • sha256sum channel.db > checksum
  • now let’s check its ok first with sha256sum –c checksum. Output should be: OK . it can take a while if your channel.db is big.
  1. sudo systemctl stop umbrel-startup
  2. Check everything is down: docker ps or docker-compose ps from ~/umbrel
  3. Check bitcoin (debug.log) and lnd (lnd.log) logs for shutdown complete
  4. Disconnect SSD from Pi. Turn off Pi

Linux machine – NUC / Gigabyte / Laptop

  1. Stop scripts: sudo ~/umbrel/scripts/stop
  2. Connect Raspberry Pi SSD and mount it in a directory of your choice in the new machine.
  3. Create a directory to act as a mount point. Example: sudo mkdir /media/mymountpoint. https://linuxize.com/post/how-to-mount-and-unmount-file-systems-in-linux/
  4. Copy the whole Raspberry Pi ~/umbrel directory to the new machine
  • Rsync –azhP /media/mymountpoint/umbrel/ ~/umbrel
  • DO NOT forget the trailing slash on the source so that rsync does not create the source folder on the destination and only copies the directory’s files This will take a while as it copies everything including the blockchain (2-3 hrs is not unheard of).
  • Double check where the source umbrel directory is with the files as sometimes it is ~/umbrel/umbrel/
  1. Once its finished copying the ~/umbrel directory drom Pi to new machine, check the channel.db integrity:
  • From the channel.db directory (where channel.db is) in the new machine run sha256sum –c checksum. Output should be : OK. If it isn’t, DO NOT start the new machine as you can lose funds.
  1. Backup your lnd.conf for example lnd.conf_bak as we will reconfigure and delete it.
  2. From ~/umbrel, run: sudo rm –rf lnd/tls* && rm –f lnd/lnd.conf && sudo scripts/configure
  3. sudo reboot
  4. Add the old lnd.conf lines to the new one carefully one by one.
  5. ~/umbrel/scripts/start

Optional

LNDg database

  1. Reinstall it with GUI or CLI
  2. Once installed, the database that we had saved ~/umbrel/db.sqlite3 can be copied to where the app resides. Example: rsync –azhP ~/umbrel/dbsqlite3 ~/umbrel/app-data/lndg/db.sqlite3

Umbrel autorestart

A service unit needs to be created so umbrel starts otherwise if you restart from GUI, Umbrel will not restart automatically in your new Linux machine

  • Set a new service unit as follows
  • Sudo nano /etc/systemd/system/umbrel.service

[Unit]
Description=umbrel.service
After=network.target
Wants=network.target
StartLimitIntervalSec=0

[Service]
Type=forking
Restart=always
RemainAfterExit=yes
RestartSec=1
User=root
ExecStart=path-to-umbrel-scripts/start
ExecStop=path-to-umbrel-scripts/stop

[Install]
WantedBy=multi-user.target

  • Start service : systemctl start umbrel.service
  • Add it to start (init): systemctl enable.service

If you run into problems, issues, DM me on Telegram : indomitorum (indomitus).

IndomitusBTC ⚡

[email protected]

Twitter: @indomitorum

About

Umbrel migration from Raspberry Pi to NUC / Laptop running Linux

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published