upgrading - QuickStart
The process of upgrading your node is quite simple.
Upgrade nodectl
sudo nodectl upgrade_nodectl
with the -v
option.
sudo nodectl upgrade_nodectl -v <version_number>
If you don't use the `-v`` option with nodectl, it will automatically check the current version of nodectl on your node and show you if there are any updates available. You can then choose which version to upgrade to from the list provided.
Upgrade nodectl components of your node
After a successful upgrade of nodectl to the latest version. You can supply the --nodectl_only
option. This will instruct the upgrade
feature to upgrade only components of your VPS (node) that nodectl requires, related to the new version of nodectl.
sudo nodectl upgrade --nodectl_only
The advantage to this option is that the node will not handle any Tessellation related features, and therefor, will not take your node off the cluster, saving you time and not affecting the node's uptime.
Upgrade Tessellation
sudo nodectl upgrade
This option will handle both Tessellation and nodectl related features. It will take your node off the cluster to perform the upgrade, and return it to the cluster afterwards.
What questions will be asked?
nodectl will begin the upgrade process and offer you prompts whenever a question needs to be answered.
The following are recommended answers to these questions:
Do you want to continue the upgrade?
This is just a confirmation that you are ready to start the process, in case you accidentally initiated, or changed your mind.
recommendation: y
What version of Tessellation?
nodectl will auto populate the current version of Tessellation for you. You can hit enter to accept the default.
recommendation: just hit enter to accept the default.
Do you want to encrypt your passphrase?
As of v2.13.0
, nodectl has a new feature that will allow you to encrypt your node's hot wallet passphrase in the configuration. This will further increase your security if your configuration file is obtained or viewed by someone other than the owner of the wallet (p12 keystore file).
recommendation: y
Do you want to clear your backups?
nodectl will offer the ability to clean out your backup folder that may be holding a few older configurations or files. It is mostly safe to enter y to this option.
recommendation: y
CONSIDERATION
As of v2.13.0
and later, nodectl has the ability to encrypt the p12 passphrase present in the cn-config.yaml
configuration file that allows nodectl to operate properly.
If you choose to encrypt your passphrase during the upgrade, you should not clear your backups until after you have confirmed your node is in full working order. This will allow you to access your backups to restore your configuration, in the unlikely event it is required.
In this situation, recommendation: n
It is recommended to keep the backups in place until it is confirmed that your node is working properly. Once confirmed, you can clean up the files using the clean files command. This ensures that your system remains stable and secure before making any changes.
Do you want to clear your uploads?
nodectl will offer the ability to clean out your uploads folder that may be holding a few older archived zip files that have been requested and created, in the past. It is safe to enter y to this option.
recommendation: y
Do you want to clear your logs?
nodectl will offer the ability to clean out your log folder that may be holding a lot of log files. It is safe to enter y to this option.
recommendation: y
During the join process
You may be asked if you want to continue watching, skip, or cancel the upgrade procedure as your node attempts to rejoin the network cluster. You can refer to the DownloadInProgress blocker section of the upgrade walk through section for further details.
recommendation: s
The upgrade will skip the attempt to join the layer1 cluster, and continue the rest of the upgrade. After a short wait you can use the status command with the -p
option against the layer0 cluster to verify you are back online.
Non Interactive
The upgrade
command has the option -ni
. This option will tell nodectl to enter non-interactive mode.
In non-interactive mode, you will not be prompted to answer any questions, all the defaults will be automatically selected for you.
Exception: In the event a critical issue is identified by nodectl, you will be prompted to answer a question. This also applies to more critical security questions that may not be of value to use any particular "default" value.
sudo nodectl upgrade -ni
Passphrase Exclusion
If you do not have your p12 passphrase in your configuration (advanced users) you can issue the --pass
option at the command line followed by your passphrase to initiate the upgrade.
SUGGESTION
You should utilize passphrase encryption over not supplying the passphrase for our p12 keystore. This will prevent the need to supply the passphrase on the command line before every command.
This will eliminate the concern of having bash history cached at the terminal session.
sudo nodectl upgrade --pass <p12 passphrase here>
sudo nodectl upgrade -ni --pass <p12 passphrase here>
Dedicated Version
If you would like to upgrade your node to a specific version of Tessellation you can use the -p <profile>
and -v <version>
options.
Ordering
The order of the flags for this particular command are important. The profile must come before the version. You can enter multiple profiles that run different versions this way from the command line.
sudo nodectl upgrade -p dag-l0 -v v2.2.1