Node Operator
Search…
SNO Applications
Powered By GitBook
How do I migrate my node to a new device?
To migrate your Node to a new drive or computer, you first need to copy both the contents of your storage folder, as well as your identity folder to the new location.
Windows
Linux
ARM-based OS
macOS
Your default identity folder is located in: %APPDATA%\Storj\Identity\storagenode
Your default orders folder is located in "%ProgramFiles%\Storj\Storage Node\orders"
To migrate your Windows storage node you can follow this guide: How to migrate the Windows GUI node from one physical location to another? The only difference - you do not need to share folders, since they are available locally, just use the local paths.
Also, you can enable WSL, install Ubuntu from the Microsoft store and use the Migrating with rsync guide. In this case your drives are mounted automatically. For example, D: disk will be mounted to the /mnt/d.
To migrate from the Docker installation to a Windows GUI, please, follow this guide: Migrating from Docker CLI to a GUI Install on Windows.
To migrate from the Windows GUI to the Docker installation, please, follow this guide: Migrating from Windows GUI installation to a Docker CLI.
Your default identity folder is located in: ~/.local/share/storj/identity/storagenode
Your default orders folder is located in the data location.
On Raspberry Pi, by default your identity folder is located in (the path may be different for other ARM platforms): /home/pi/.local/share/storj/identity/storagenode
Your default orders folder is located in the data location.
Your default identity folder is located in: "/Users/USER/Library/Application Support/Storj/identity/storagenode"
Your default orders folder is located in the data location.

Migrating with rsync

We will assume that your parameters look like this:
    the source folder where the existing identity is located is /mnt/storj/identity/storagenode;
    the source folder where the existing stored data is located is /mnt/storj/storagenode/storage;
    the source folder where the existing orders folder is located is /mnt/storj/storagenode/orders;
    the destination folder the existing identity will be copied to is/mnt/storj2/storagenode-new/identity;
    the destination folder the existing stored data will be copied to is /mnt/storj2/storagenode-new/storage.
    the destination folder the existing orders will be copied to is /mnt/storj2/storagenode-new/orders.
To migrate your identity, orders and data to the new location, you can use the rsync command (please, replace the example paths mentioned above to your own!):
    1.
    Open a new terminal
    2.
    Keep your original storage node running
    3.
    Copy the identity:
1
rsync -aP /mnt/storj/identity/storagenode/ /mnt/storj2/storagenode-new/identity/
Copied!
4. Copy the orders
1
rsync -aP /mnt/storj/storagenode/orders/ /mnt/storj2/storagenode-new/orders/
Copied!
5. Copy the data
1
rsync -aP /mnt/storj/storagenode/storage/ /mnt/storj2/storagenode-new/storage/
Copied!
6. Repeat running the orders (step 4.) and data copying command (step 5.) a few more times until the difference would be negligible, then
8. Remove the old container
1
docker rm storagenode
Copied!
9. Run the copying command with a --delete parameter to remove deleted files from the destination:
1
rsync -aP --delete /mnt/storj/storagenode/orders/ /mnt/storj2/storagenode-new/orders/
Copied!
1
rsync -aP --delete /mnt/storj/storagenode/storage/ /mnt/storj2/storagenode-new/storage/
Copied!
10. Now you can copy config.yaml file and revocation.db to the new location:
1
cp /mnt/storj/storagenode/config.yaml /mnt/storj2/storagenode-new/
2
cp /mnt/storj/storagenode/revocation.db /mnt/storj2/storagenode-new/revocation.db
Copied!
11. After you copied over all the necessary files, update your --mount parameters in your docker run command. For our example, it will look like this (we only show a partial example of the new--mount parameter lines, not the entire docker run command!):
1
--mount type=bind,source=/mnt/storj2/storagenode-new/identity,destination=/app/identity \
2
--mount type=bind,source=/mnt/storj2/storagenode-new,destination=/app/config \
Copied!
The network-attached storage location could work, but it is neither supported nor recommended!
Please, note - we intentionally specified/mnt/storj2/storagenode-new as the data source in the --mount parameter and not /mnt/storj2/storagenode-new/storage because the storagenode docker container will add a subfolder calledstorage to the path automatically. So please, make sure that your data folder contains a storage subfolder with all the data inside (blobs folder, database files, etc.), otherwise the node will start from scratch since it can't find the data in the right subfolder and will be disqualified in a few hours.
Last modified 1mo ago
Copy link