Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

multi: add migrate-db command #21

Draft
wants to merge 5 commits into
base: main
Choose a base branch
from
Draft

multi: add migrate-db command #21

wants to merge 5 commits into from

Conversation

guggero
Copy link
Member

@guggero guggero commented Jul 4, 2022

This is work in progress and NOT recommended to be used with production/mainnet data!

@kiwiidb
Copy link

kiwiidb commented Jul 14, 2022

Using this code I was getting an error:
Runtime error: db connection set not initialized
I started looking around and found that you were probably missing this: https://github.com/lightningnetwork/lnd/blob/master/lncfg/db.go#L140

So I added a quick patch: getAlby@0ffcae3
(should be a config param probably).

And then I was able to do the migration. The last logs were:

2022-07-14 10:41:42.534 LNDINIT: Opened destination DB
2022-07-14 10:41:42.535 LNDINIT: Checking tombstone marker on source DB
2022-07-14 10:41:42.536 LNDINIT: Checking DB version of source DB
2022-07-14 10:41:42.537 LNDINIT: Checking if migration was already applied to target DB
2022-07-14 10:41:42.540 LNDINIT: Starting the migration to the target backend
2022-07-14 10:41:42.540 LNDINIT: Copying top-level bucket 'waddrmgr'
2022-07-14 10:41:48.981 LNDINIT: Committing bucket 'waddrmgr'
2022-07-14 10:41:48.983 LNDINIT: Copying top-level bucket 'wtxmgr'
2022-07-14 10:41:49.016 LNDINIT: Committing bucket 'wtxmgr'
2022-07-14 10:41:49.017 LNDINIT: Creating 'wallet created' marker
2022-07-14 10:41:49.024 LNDINIT: Committing 'wallet created' marker

It seems everything has migrated succesfully, so I would say that a log line indicating this would also be useful.

@twofaktor
Copy link

twofaktor commented Apr 15, 2024

Hello, what happened with this PR? Have been it abandoned? I think this is very useful to migrate an existing bbolt to postgres and following this guide

Thanks!

@ziggie1984
Copy link

This is an important PR we need to focus on to allow nodes to finally migrate from kv to native sql. cc @saubyk

@Roasbeef
Copy link
Member

Roasbeef commented Oct 2, 2024

sqlite should be added here: https://github.com/lightninglabs/lndinit/pull/21/files#diff-00eb92ba2060dddcdbce2dba1dc551065557b5ebcf98e47e70946e1b50ffd243R453

The top-level bucket structure might also have changed somewhat, so we should update that aspect.

One other thing is we'll need to figure out a way to ensure that all the data has truly been migrated (eg: we don't forget some other top level bucket recently added).

Copy link

@saubyk saubyk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Still testing, but wanted to note some comments

cmd_migrate_db.go Outdated Show resolved Hide resolved

### Using postgres as the destination remote database

Prepare a user and database as described in the [Postgres](postgres.md)
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

data migration (e.g. disable any `systemd` or other scripts that start/stop
`lnd`).

NOTE: If you were using the experimental `etcd` cluster mode that was introduced
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should be a WARNING/CAUTION instead of NOTE

```

If you weren't running a watchtower server, you can remove the line with
`--source.bolt.tower-dir`.
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should end with a section advising user to run the migrated node with the updated db config settings

@ziggie1984 ziggie1984 self-assigned this Nov 5, 2024
@ziggie1984
Copy link

ziggie1984 commented Nov 7, 2024

One other thing is we'll need to figure out a way to ensure that all the data has truly been migrated (eg: we don't forget some other top level bucket recently added).

so you mean having the db files constant here (channeldb, towerdb etc) is not enough but we need to also make sure every new bucket is in the new db ? Hmm not sure I understand this one? Because as long as we iterate through each bucket in the db file, there shouldn't be a problem that we miss a bucket ?

@ziggie1984
Copy link

ziggie1984 commented Nov 19, 2024

Migration now supports sqlite as well. Keep in mind this is still an experimental feature because we need to implement some consistency checks.

This PR still needs some work:

  1. Need to do the migration in batches, because memory issues can be a problem
  2. Add consistency checks: Base level: Compare the two dbs and make sure every key-value pair was successfully copied
    Do some structural data tests for example compare the Channels from the old db and the new migrated db.
  3. This only works if you run LND 18.3 otherwise we do not allow the migration.
  4. Add a wtclient.db check so that we only migrate if the specific version is met.

Example for the sqlite migration:

 lndinit -v migrate-db  --network regtest --source.bolt.data-dir /LND-DIR/data   --dest.backend sqlite  --dest.sqlite.data-dir /LND-DIR/data

make sure the data-dir for the sqlite directory is the same as the boltdb otherwise you need to copy the new files into the other directory when starting lnd.

for postgress:

 lndinit -v migrate-db  --network regtest --source.bolt.data-dir /LND-DIR/data  --dest.backend postgres  --dest.postgres.dsn="postgres://lnd_migration:lnd_migration@localhost:5432/lnd_migration_db?sslmode=disable"

make sure you create a db in postgres before otherwise the opening of the db will fail.

Also make sure you choose the correct network, otherwise the bolt.db will not be found in the LND dir.

@feelancer21
Copy link

feelancer21 commented Dec 15, 2024

@ziggie1984
I am testing the sqlite migration for my watchtower node. It seems that the migration routine is looking for the watchtower.db in $HOME/.lnd and not in the specified source.bolt.data-dir <- solved with using tower-dir parameters

Edit:
moreover per default the routine is looking for $HOME/.lnd/data/bitcoin/mainnet/watchtower.db and not for $HOME/.lnd/data/watchtower/bitcoin/mainnet/watchtower.db

Edit2:
A runtime error occurred. I think that the memory ran out because watchtower.db has a size of ~60G, the memory 8G and the memory was almost completely used up at the end.

2024-12-15 12:44:39.625 LNDINIT: Migrating DB with prefix towerserverdb
2024-12-15 12:44:39.625 LNDINIT: Opening bbolt backend at /home/feelancer21/.lnd/data/bitcoin/mainnet/watchtower.db for prefix 'towerserverdb'
2024-12-15 14:05:53.255 LNDINIT: Opening sqlite backend with prefix 'towerserverdb'
2024-12-15 14:05:53.321 LNDINIT: Opened destination DB
2024-12-15 14:05:53.321 LNDINIT: Checking tombstone marker on source DB
2024-12-15 14:05:53.322 LNDINIT: Checking DB version of source DB
2024-12-15 14:05:53.322 LNDINIT: Checking if migration was already applied to target DB
2024-12-15 14:05:53.330 LNDINIT: Starting the migration to the target backend
2024-12-15 14:05:53.331 LNDINIT: Copying top-level bucket 'lookout-tip-bucket'
2024-12-15 14:05:53.331 LNDINIT: Committing bucket 'lookout-tip-bucket'
2024-12-15 14:05:53.335 LNDINIT: Copying top-level bucket 'metadata-bucket'
2024-12-15 14:05:53.336 LNDINIT: Committing bucket 'metadata-bucket'
2024-12-15 14:05:53.339 LNDINIT: Copying top-level bucket 'sessions-bucket'
2024-12-15 14:05:59.461 LNDINIT: Committing bucket 'sessions-bucket'
2024-12-15 14:05:59.580 LNDINIT: Copying top-level bucket 'update-index-bucket'
2024-12-15 15:36:29.131 LNDINIT: Committing bucket 'update-index-bucket'
2024-12-15 15:41:59.768 LNDINIT: Copying top-level bucket 'updates-bucket'
2024-12-15 17:38:34.307 LNDINIT: Runtime error: error enumerating top level buckets: error copying bucket 'updates-bucket': error creating bucket '1b12e646e05eb7698a7db9ddbdfd9def': context deadline exceeded

@jkuchar
Copy link

jkuchar commented Jan 2, 2025

Any plans for releasing this feature? It can be released in beta and used at own risk. What is the level of risk loosing money because of broken migration? Is there any way to "dry run" migration and ensure that lnd after the migration is in correct state?

@ziggie1984
Copy link

Any plans for releasing this feature? It can be released in beta and used at own risk. What is the level of risk loosing money because of broken migration? Is there any way to "dry run" migration and ensure that lnd after the migration is in correct state?

This feature will be released alongside with LND 19. Currently this feature is not ready for big databases. There is data-consistency checks in the making which will make sure the db migrated correctly.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants