=============
How to update
=============
*This page is about updating your system while staying on the same*
:ref:`supported version of Qubes OS ` *. If you’re instead looking to upgrade from your current version of Qubes OS to a newer version, see* :doc:`Upgrade guides ` *.*
It is important to keep your Qubes OS system up-to-date to ensure you
have the latest security updates, as well as the latest non-security
enhancements and bug fixes.
Fully updating your Qubes OS system means updating:
- :ref:`dom0 `
- :ref:`templates `
- :ref:`standalones ` (if you have any)
Security updates
----------------
Security updates are an extremely important part of keeping your Qubes
installation secure. When there is an important security incident, we
will issue a `Qubes Security Bulletin (QSB) `__ via the
`Qubes Security Pack (qubes-secpack) `__. It is
very important to read each new QSB and follow any user instructions it
contains. Most of the time, simply updating your system normally, as
described below, will be sufficient to obtain security updates. However,
in some cases, special action may be required on your part, which will
be explained in the QSB.
Checking for updates
--------------------
By default, the **Qubes Update** tool will appear as an icon in the
Notification Area when updates are available.
|Qube Updates Available|
However, you can also start the tool manually by selecting it in the
Applications Menu under “Qubes Tools.” Even if no updates have been
detected, you can use this tool to check for updates manually at any
time by selecting “Enable updates for qubes without known available
updates,” then selecting all desired items from the list and clicking
“Next.”
.. note::
For information about how templates download updates, please see Why
don’t templates have network access? and the Updates proxy.
By default, most qubes that are connected to the internet will
periodically check for updates for their parent templates. If updates
are available, you will receive a notification as described above.
However, if you have any templates that do *not* have any online child
qubes, you will *not* receive update notifications for them. Therefore,
you should regularly update such templates manually instead.
Installing updates
------------------
The standard way to install updates is with the **Qubes Update** tool.
(However, you can also perform the same action via the `command-line interface <#command-line-interface>`__.)
|Qubes Update|
Simply follow the on-screen instructions, and the tool will download and
install all available updates for you. Note that if you are downloading
updates over Tor (``sys-whonix``), this can take a very long time,
especially if there are a lot of updates available.
Restarting after updating
-------------------------
Certain updates require certain components to be restarted in order for
the updates to take effect:
- QSBs may instruct you to restart certain components after installing
updates.
- Dom0 should be restarted after all **Xen** and **kernel** updates.
- On Intel systems, dom0 should be restarted after all
``microcode_ctl`` updates.
- On AMD systems, dom0 should be restarted after all ``linux-firmware``
updates.
- After updating a template, first shut down the template, then restart
all running qubes based on that template.
AEM resealing after updating
----------------------------
If you use :doc:`Anti Evil Maid (AEM) `, you’ll have
to “reseal” after certain updates. It’s common for QSBs to contain
instructions to this effect. See the relevant QSB and the `AEM
README `__
for details.
Command-line interface
----------------------
.. DANGER::
Warning: Updating with direct commands such as qubes-dom0-update, dnf
update, and apt update is not recommended, since these bypass
built-in Qubes OS update security measures. Instead, we strongly
recommend using the Qubes Update tool or its command-line
equivalents, as described below. (By contrast, installing packages
using direct package manager commands is fine.)
Advanced users may wish to perform updates via the command-line
interface. The recommended way to do this is by applying the following
two Salt states. **Applying these two Salt states is the same as updating via the Qubes Update tool.**
- :ref:`update.qubes-dom0 `
- :ref:`update.qubes-vm `
In your update qube, a terminal window opens that displays the progress
of operations and output as it is logged. At the end of the process,
logs are sent back to dom0. You answer any yes/no prompts in your dom0
terminal window.
Advanced users may also be interested in learning :doc:`how to enable the testing repos `.
Upgrading to avoid EOL
----------------------
The above covers updating *within* a given operating system (OS)
release. Eventually, however, most OS releases will reach **end-of-life (EOL)**, after which point they will no longer be supported. This
applies to Qubes OS itself as well as OSes used in
:doc:`templates ` (and
:doc:`standalones `, if you have any).
**It’s very important that you use only supported releases so that you continue to receive security updates.** This means that you *must*
periodically upgrade Qubes OS and your templates before they reach EOL.
You can always see which versions of Qubes OS and select templates are
supported on :doc:`Supported releases `.
In the case of Qubes OS itself, we will make an
`announcement `__ when a supported Qubes OS
release is approaching EOL and another when it has actually reached EOL,
and we will provide :doc:`instructions for upgrading to the next stable supported Qubes OS release `.
Periodic upgrades are also important for templates. For example, you
might be using a :doc:`Fedora template `. The
`Fedora Project `__ is independent of the Qubes
OS Project. They set their own
`schedule `__
for when each Fedora release reaches EOL. You can always find out when
an OS reaches EOL from the upstream project that maintains it. We also
pass along any EOL notices we receive for official template OSes as a
convenience to Qubes users (see the :ref:`supported template releases `).
The one exception to all this is the specific release used for dom0 (not
to be confused with Qubes OS as a whole), which :ref:`doesn’t have to be upgraded `.
.. |Qube Updates Available| image:: /attachment/doc/r4.0-qube-updates-available.png
.. |Qubes Update| image:: /attachment/doc/r4.0-software-update.png