How to manage the LXD snap
Among other options, LXD is distributed as a snap (opens in a new tab). The benefit of packaging LXD as a snap is that it makes it possible to include all of LXD's dependencies in one package, and that it allows LXD to be installed on many different Linux distributions. The snap ensures that LXD runs in a consistent environment.
Control updates of the snap
When running LXD in a production environment, you must make sure to have a suitable version of the snap installed on all machines of your LXD cluster.
Choose the right channel and track
Snaps come with different channels that define which release of a snap is installed and tracked for updates. See Channels and tracks (opens in a new tab) in the snap documentation for detailed information.
See Choose your release for more information.
On all tracks, the stable risk level contains all fixes and features for the respective track, but it is only updated when the LXD team decides that a feature is ready and no issues have been revealed by users running the same revision on higher risk levels (edge and candidate).
When installing a snap, specify the channel as follows:
sudo snap install <snap_name> --channel=<channel>For example:
sudo snap install lxd --channel=5.21/stableIf you do not specify a channel, snap will choose the default channel (the latest LTS release).
To see all available channels of the LXD snap, run the following command:
snap info lxdHold and schedule updates
By default, snaps are updated automatically. In the case of LXD, this can be problematic because all machines of a cluster must use the same version of the LXD snap.
Therefore, you should schedule your updates and make sure that all cluster members are in sync regarding the snap version that they use.
Schedule updates
There are two methods for scheduling when your snaps should be updated:
- You can hold snap updates for a specific time, either for specific snaps or for all snaps on your system. After the duration of the hold, or when you remove the hold, your snaps are automatically refreshed.
- You can specify a system-wide refresh window, so that snaps are automatically refreshed only within this time frame. Such a refresh window applies to all snaps.
Hold updates
You can hold snap updates for a specific time or forever, for all snaps or only for the LXD snap. If you want to fully control updates to your LXD deployment, you should put a hold on the LXD snap until you decide to update it.
Enter the following command to indefinitely hold all updates for the LXD snap:
sudo snap refresh --hold lxdWhen you choose to update your installation, use the following commands to remove the hold, update the snap, and hold the updates again:
sudo snap refresh --unhold lxd
sudo snap refresh lxd --cohort="+"
sudo snap refresh --hold lxdSee Hold refreshes (opens in a new tab) in the snap documentation for detailed information about holding snap updates.
Specify a refresh window
Depending on your setup, you might want your snaps to update regularly, but only at specific times that don't disturb normal operation.
You can achieve this by specifying a refresh timer. This option defines a refresh window for all snaps that are installed on the system.
For example, to configure your system to update snaps only between 8:00 am and 9:00 am on Mondays, set the following option:
sudo snap set system refresh.timer=mon,8:00-9:00You can use a similar mechanism (setting refresh.hold) to hold snap updates as well. However, in this case the snaps will be refreshed after 90 days, irrespective of the value of refresh.hold.
See Control updates with system options (opens in a new tab) in the snap documentation for detailed information.
Keep cluster members in sync
The cluster members that are part of the LXD deployment must always run the same version of the LXD snap. This means that when the snap on one of the cluster members is refreshed, it must also be refreshed on all other cluster members before the LXD cluster is operational again.
Snap updates are delivered as progressive releases (opens in a new tab), which means that updated snap versions are made available to different machines at different times. This method can cause a problem for cluster updates if some cluster members are refreshed to a version that is not available to other cluster members yet.
To avoid this problem, use the --cohort="+" flag when refreshing your snaps:
sudo snap refresh lxd --cohort="+"This flag ensures that all machines in a cluster see the same snap revision and are therefore not affected by a progressive rollout.
Use an Enterprise Store proxy
For Snap Store Proxy users
If you previously used the Snap Store Proxy, see the migration guide (opens in a new tab) in the Enterprise Store documentation for instructions on transitioning to the Enterprise Store.
If you manage a large LXD cluster and require absolute control over when updates are applied, consider using the Enterprise Store (opens in a new tab). This proxy application sits between your machines' snap clients and the Snap Store, giving you control over which snap revisions are available for installation.
To get started, follow the Enterprise Store documentation to install (opens in a new tab) and register (opens in a new tab) the service. Once it's running, configure all cluster members to use the proxy; see Configure devices (opens in a new tab) for instructions. You can then override the revision (opens in a new tab) for the LXD snap to control which version is installed:
sudo enterprise-store override lxd <channel>=<revision>For example:
sudo enterprise-store override lxd stable=25846Configure the snap
The LXD snap has several configuration options that control the behavior of the installed LXD server. For example, you can define a LXD user group to achieve a multi-user environment for LXD (see Confine users to specific LXD projects via Unix socket for more information).
See the LXD snap page (opens in a new tab) for a list of available configuration options.
To set any of these options, use the following command:
sudo snap set lxd <key>=<value>For example:
sudo snap set lxd daemon.user.group=lxd-usersTo see all configuration options that are set on the snap, use the following command:
sudo snap get lxdNote This command returns only configuration options that have been explicitly set.
See Configure snaps (opens in a new tab) in the snap documentation for more information about snap configuration options.
Start and stop the daemon
To start and stop the LXD daemon, you can use the start and stop commands of the snap:
sudo snap stop lxd
sudo snap start lxdThese commands are equivalent to running the corresponding systemctl commands:
sudo systemctl stop snap.lxd.daemon.service snap.lxd.daemon.unix.socket
sudo systemctl start snap.lxd.daemon.unix.socket; lxc listStopping the daemon also stops all running instances.
To restart the LXD daemon, use the following command:
sudo systemctl restart snap.lxd.daemonRestarting the daemon stops all running instances. If you want to keep the instances running, reload the daemon instead:
sudo systemctl reload snap.lxd.daemonNote To restart the daemon, you can also use the snap commands. To stop all running instances and restart:
sudo snap restart lxdTo keep the instances running and reload:
sudo snap restart --reload lxdHowever, there is currently a bug in
snapd(opens in a new tab) that causes undesired side effects when using thesnap restartcommand. Therefore, we recommend using thesystemctlcommands instead.