2021-04-14 12:26:52 +02:00
Backup Storage
==============
2020-10-02 16:12:57 +02:00
2020-11-10 10:15:44 +01:00
.. _storage_disk_management:
2020-10-02 16:12:57 +02:00
Disk Management
---------------
.. image :: images/screenshots/pbs-gui-disks.png
2022-11-28 12:47:16 +01:00
:target: _images/pbs-gui-disks.png
2020-10-02 16:12:57 +02:00
:align: right
:alt: List of disks
2023-11-24 18:43:43 +01:00
`Proxmox Backup`_ Server comes with a set of disk utilities, which are
2022-05-17 09:43:14 +02:00
accessed using the `` disk `` subcommand or the web interface. This subcommand
allows you to initialize disks, create various filesystems, and get information
about the disks.
2020-10-02 16:12:57 +02:00
To view the disks connected to the system, navigate to **Administration ->
2021-10-11 13:11:44 +02:00
Storage/Disks** in the web interface or use the `` list `` subcommand of
2020-10-02 16:12:57 +02:00
`` disk `` :
.. code-block :: console
# proxmox-backup-manager disk list
┌──────┬────────┬─────┬───────────┬─────────────┬───────────────┬─────────┬────────┐
│ name │ used │ gpt │ disk-type │ size │ model │ wearout │ status │
╞══════╪════════╪═════╪═══════════╪═════════════╪═══════════════╪═════════╪════════╡
│ sda │ lvm │ 1 │ hdd │ 34359738368 │ QEMU_HARDDISK │ - │ passed │
├──────┼────────┼─────┼───────────┼─────────────┼───────────────┼─────────┼────────┤
│ sdb │ unused │ 1 │ hdd │ 68719476736 │ QEMU_HARDDISK │ - │ passed │
├──────┼────────┼─────┼───────────┼─────────────┼───────────────┼─────────┼────────┤
│ sdc │ unused │ 1 │ hdd │ 68719476736 │ QEMU_HARDDISK │ - │ passed │
└──────┴────────┴─────┴───────────┴─────────────┴───────────────┴─────────┴────────┘
To initialize a disk with a new GPT, use the `` initialize `` subcommand:
.. code-block :: console
# proxmox-backup-manager disk initialize sdX
.. image :: images/screenshots/pbs-gui-disks-dir-create.png
2022-11-28 17:15:42 +01:00
:target: _images/pbs-gui-disks-dir-create.png
2020-10-02 16:12:57 +02:00
:align: right
:alt: Create a directory
You can create an `` ext4 `` or `` xfs `` filesystem on a disk using `` fs
2021-10-11 13:11:44 +02:00
create`` , or by navigating to **Administration -> Storage/Disks -> Directory**
in the web interface and creating one from there. The following command creates
an `` ext4 `` filesystem and passes the `` --add-datastore `` parameter, in order to
2023-07-11 09:56:51 +02:00
automatically create a datastore on the disk. This will
2020-10-02 16:12:57 +02:00
create a datastore at the location `` /mnt/datastore/store1 `` :
.. code-block :: console
2023-07-11 09:56:51 +02:00
# proxmox-backup-manager disk fs create store1 --disk sdX --filesystem ext4 --add-datastore true
2020-10-02 16:12:57 +02:00
.. image :: images/screenshots/pbs-gui-disks-zfs-create.png
:align: right
:alt: Create ZFS
You can also create a `` zpool `` with various raid levels from **Administration
2021-10-11 13:11:44 +02:00
-> Storage/Disks -> ZFS** in the web interface, or by using `` zpool create `` . The command
2023-07-11 09:56:51 +02:00
below creates a mirrored `` zpool `` using two disks and
2020-11-05 14:36:28 +01:00
mounts it under `` /mnt/datastore/zpool1 `` :
2020-10-02 16:12:57 +02:00
.. code-block :: console
2023-07-11 09:56:51 +02:00
# proxmox-backup-manager disk zpool create zpool1 --devices sdX,sdY --raidlevel mirror
2020-10-02 16:12:57 +02:00
.. note :: You can also pass the `` --add-datastore `` parameter here, to automatically
create a datastore from the disk.
You can use `` disk fs list `` and `` disk zpool list `` to keep track of your
filesystems and zpools respectively.
Proxmox Backup Server uses the package smartmontools. This is a set of tools
used to monitor and control the S.M.A.R.T. system for local hard disks. If a
disk supports S.M.A.R.T. capability, and you have this enabled, you can
display S.M.A.R.T. attributes from the web interface or by using the command:
.. code-block :: console
# proxmox-backup-manager disk smart-attributes sdX
.. note :: This functionality may also be accessed directly through the use of
the `` smartctl `` command, which comes as part of the smartmontools package
(see `` man smartctl `` for more details).
.. _datastore_intro:
2020-11-10 09:24:06 +01:00
:term: `Datastore`
2020-10-02 16:12:57 +02:00
-----------------
2022-05-17 13:27:37 +02:00
.. image :: images/screenshots/pbs-gui-datastore-summary.png
2022-11-28 17:15:42 +01:00
:target: _images/pbs-gui-datastore-summary.png
2022-05-17 13:27:37 +02:00
:align: right
:alt: Datastore Usage Overview
2020-10-02 16:12:57 +02:00
A datastore refers to a location at which backups are stored. The current
2020-10-07 14:03:48 +02:00
implementation uses a directory inside a standard Unix file system (`` ext4 `` ,
2020-10-02 16:12:57 +02:00
`` xfs `` or `` zfs `` ) to store the backup data.
Datastores are identified by a simple *ID* . You can configure this
when setting up the datastore. The configuration information for datastores
is stored in the file `` /etc/proxmox-backup/datastore.cfg `` .
.. note :: The `File Layout`_ requires the file system to support at least *65538*
subdirectories per directory. That number comes from the 2\ :sup: `16`
pre-created chunk namespace directories, and the `` . `` and `` .. `` default
directory entries. This requirement excludes certain filesystems and
2021-10-11 13:11:43 +02:00
filesystem configurations from being supported for a datastore. For example,
2020-10-02 16:12:57 +02:00
`` ext3 `` as a whole or `` ext4 `` with the `` dir_nlink `` feature manually disabled.
Datastore Configuration
~~~~~~~~~~~~~~~~~~~~~~~
2020-11-06 15:46:26 +01:00
.. image :: images/screenshots/pbs-gui-datastore-content.png
2022-11-28 17:15:42 +01:00
:target: _images/pbs-gui-datastore-content.png
2020-10-02 16:12:57 +02:00
:align: right
2022-05-17 13:27:09 +02:00
:alt: Datastore Content Overview
2020-10-02 16:12:57 +02:00
2021-10-11 13:11:43 +02:00
You can configure multiple datastores. A minimum of one datastore needs to be
2020-10-02 16:12:57 +02:00
configured. The datastore is identified by a simple *name* and points to a
directory on the filesystem. Each datastore also has associated retention
settings of how many backup snapshots for each interval of `` hourly `` ,
`` daily `` , `` weekly `` , `` monthly `` , `` yearly `` as well as a time-independent
2020-10-05 17:01:29 +02:00
number of backups to keep in that store. :ref: `backup-pruning` and
2021-10-11 13:11:43 +02:00
:ref: `garbage collection <client_garbage-collection>` can also be configured to
run periodically, based on a configured schedule (see
:ref: `calendar-event-scheduling` ) per datastore.
2020-10-02 16:12:57 +02:00
2020-11-10 10:15:44 +01:00
.. _storage_datastore_create:
2020-10-02 16:12:57 +02:00
Creating a Datastore
^^^^^^^^^^^^^^^^^^^^
2022-05-17 13:27:09 +02:00
.. image :: images/screenshots/pbs-gui-datastore-create.png
2022-11-28 17:15:42 +01:00
:target: _images/pbs-gui-datastore-create.png
2020-10-02 16:12:57 +02:00
:align: right
:alt: Create a datastore
2020-11-06 15:46:26 +01:00
You can create a new datastore from the web interface, by clicking **Add
Datastore** in the side menu, under the ** Datastore** section. In the setup
window:
2020-10-02 16:12:57 +02:00
* *Name* refers to the name of the datastore
* *Backing Path* is the path to the directory upon which you want to create the
datastore
* *GC Schedule* refers to the time and intervals at which garbage collection
runs
* *Prune Schedule* refers to the frequency at which pruning takes place
2020-11-06 15:46:26 +01:00
* *Prune Options* set the amount of backups which you would like to keep (see
:ref: `backup-pruning` ).
* *Comment* can be used to add some contextual information to the datastore.
2020-10-02 16:12:57 +02:00
Alternatively you can create a new datastore from the command line. The
2021-10-11 13:11:43 +02:00
following command creates a new datastore called `` store1 `` on
:file: `/backup/disk1/store1`
2020-10-02 16:12:57 +02:00
.. code-block :: console
# proxmox-backup-manager datastore create store1 /backup/disk1/store1
Managing Datastores
^^^^^^^^^^^^^^^^^^^
2021-10-11 13:11:43 +02:00
To list existing datastores from the command line, run:
2020-10-02 16:12:57 +02:00
.. code-block :: console
# proxmox-backup-manager datastore list
┌────────┬──────────────────────┬─────────────────────────────┐
│ name │ path │ comment │
╞════════╪══════════════════════╪═════════════════════════════╡
│ store1 │ /backup/disk1/store1 │ This is my default storage. │
└────────┴──────────────────────┴─────────────────────────────┘
You can change the garbage collection and prune settings of a datastore, by
editing the datastore from the GUI or by using the `` update `` subcommand. For
example, the below command changes the garbage collection schedule using the
`` update `` subcommand and prints the properties of the datastore with the
`` show `` subcommand:
.. code-block :: console
# proxmox-backup-manager datastore update store1 --gc-schedule 'Tue 04:27'
# proxmox-backup-manager datastore show store1
┌────────────────┬─────────────────────────────┐
│ Name │ Value │
╞════════════════╪═════════════════════════════╡
│ name │ store1 │
├────────────────┼─────────────────────────────┤
│ path │ /backup/disk1/store1 │
├────────────────┼─────────────────────────────┤
│ comment │ This is my default storage. │
├────────────────┼─────────────────────────────┤
│ gc-schedule │ Tue 04:27 │
├────────────────┼─────────────────────────────┤
│ keep-last │ 7 │
├────────────────┼─────────────────────────────┤
│ prune-schedule │ daily │
└────────────────┴─────────────────────────────┘
Finally, it is possible to remove the datastore configuration:
.. code-block :: console
# proxmox-backup-manager datastore remove store1
.. note :: The above command removes only the datastore configuration. It does
not delete any data from the underlying directory.
File Layout
^^^^^^^^^^^
After creating a datastore, the following default layout will appear:
.. code-block :: console
# ls -arilh /backup/disk1/store1
276493 -rw-r--r-- 1 backup backup 0 Jul 8 12:35 .lock
276490 drwxr-x--- 1 backup backup 1064960 Jul 8 12:35 .chunks
`.lock` is an empty file used for process locking.
2021-10-11 13:11:43 +02:00
The `.chunks` directory contains folders, starting from `0000` and increasing in
hexadecimal values until `ffff` . These directories will store the chunked data,
categorized by checksum, after a backup operation has been executed.
2020-10-02 16:12:57 +02:00
.. code-block :: console
# ls -arilh /backup/disk1/store1/.chunks
545824 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 ffff
545823 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 fffe
415621 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 fffd
415620 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 fffc
353187 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 fffb
344995 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 fffa
144079 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 fff9
144078 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 fff8
144077 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 fff7
...
403180 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 000c
403179 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 000b
403177 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 000a
402530 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0009
402513 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0008
402509 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0007
276509 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0006
276508 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0005
276507 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0004
276501 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0003
276499 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0002
276498 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0001
276494 drwxr-x--- 2 backup backup 4.0K Jul 8 12:35 0000
276489 drwxr-xr-x 3 backup backup 4.0K Jul 8 12:35 ..
276490 drwxr-x--- 1 backup backup 1.1M Jul 8 12:35 .
2022-05-17 18:12:42 +02:00
Once you've uploaded some backups or created namespaces, you may see the backup
2023-11-24 18:43:46 +01:00
type (`ct` , `vm` , `host` ) and the start of the namespace hierarchy (`ns` ).
2022-05-17 13:29:02 +02:00
2022-05-17 13:30:11 +02:00
.. _storage_namespaces:
2022-05-17 13:29:02 +02:00
Backup Namespaces
~~~~~~~~~~~~~~~~~
2022-05-17 18:12:42 +02:00
A datastore can host many backups, as long as the underlying storage is large
enough and provides the performance required for a user's use case.
However, without any hierarchy or separation, it's easy to run into naming conflicts,
2022-05-17 13:29:02 +02:00
especially when using the same datastore for multiple Proxmox VE instances or
multiple users.
The backup namespace hierarchy allows you to clearly separate different users
2022-05-17 18:12:42 +02:00
or backup sources in general, avoiding naming conflicts and providing a
2022-05-17 13:29:02 +02:00
well-organized backup content view.
2022-05-17 18:12:42 +02:00
Each namespace level can host any backup type, CT, VM or Host, but also other
namespaces, up to a depth of 8 levels, where the root namespace is the first
2022-05-17 13:29:02 +02:00
level.
Namespace Permissions
^^^^^^^^^^^^^^^^^^^^^
You can make the permission configuration of a datastore more fine-grained by
setting permissions only on a specific namespace.
2022-05-17 18:12:42 +02:00
To view a datastore, you need a permission that has at least an `AUDIT` ,
2022-05-17 13:29:02 +02:00
`MODIFY` , `READ` or `BACKUP` privilege on any namespace it contains.
2022-05-17 18:12:42 +02:00
To create or delete a namespace, you require the modify privilege on the parent
namespace. Thus, to initially create namespaces, you need to have a permission
with an access role that includes the `MODIFY` privilege on the datastore itself.
2022-05-17 13:29:02 +02:00
2022-05-17 18:12:42 +02:00
For backup groups, the existing privilege rules still apply. You either need a
privileged enough permission or to be the owner of the backup group; nothing
changed here.
2022-05-17 13:29:02 +02:00
.. todo :: continue
2022-05-17 13:28:50 +02:00
Options
~~~~~~~
.. image :: images/screenshots/pbs-gui-datastore-options.png
2022-11-28 17:15:42 +01:00
:target: _images/pbs-gui-datastore-options.png
2022-05-17 13:28:50 +02:00
:align: right
:alt: Datastore Options
There are a few per-datastore options:
* :ref: `Notifications <maintenance_notification>`
* :ref: `Maintenance Mode <maintenance_mode>`
* Verification of incoming backups
2022-10-20 09:40:54 +02:00
2022-11-28 11:13:06 +01:00
.. _datastore_tuning_options:
2022-10-20 09:40:54 +02:00
Tuning
^^^^^^
2022-11-28 14:26:41 +01:00
There are some tuning related options for the datastore that are more advanced:
2022-10-20 09:40:54 +02:00
* `` chunk-order `` : Chunk order for verify & tape backup:
You can specify the order in which Proxmox Backup Server iterates the chunks
when doing a verify or backing up to tape. The two options are:
- `inode` (default): Sorts the chunks by inode number of the filesystem before iterating
over them. This should be fine for most storages, especially spinning disks.
- `none` Iterates the chunks in the order they appear in the
index file (.fidx/.didx). While this might slow down iterating on many slow
storages, on very fast ones (for example: NVMEs) the collecting and sorting
can take more time than gained through the sorted iterating.
2023-11-08 12:32:22 +01:00
This option can be set with:
2022-10-20 09:40:54 +02:00
2023-11-08 12:32:22 +01:00
.. code-block :: console
2022-10-20 09:40:54 +02:00
2023-11-08 12:32:22 +01:00
# proxmox-backup-manager datastore update <storename> --tuning 'chunk-order=none'
2022-10-20 09:40:54 +02:00
2022-10-28 09:34:48 +02:00
* `` sync-level `` : Datastore fsync level:
You can set the level of syncing on the datastore for chunks, which influences
the crash resistance of backups in case of a powerloss or hard shutoff.
There are currently three levels:
datastore: make 'filesystem' the default sync-level
rationale is that it makes the backup much safer than 'none', but does not
incur a big of a performance hit as 'file'.
here some benchmark:
data to be backed up:
~14GiB semi-random test images between 12kiB and 4GiB
that results in ~11GiB chunks (more than ram available on the target)
PBS setup:
virtualized (on an idle machine), PBS itself was also idle
8 cores (kvm64 on Intel 12700k) and 8 GiB memory
all virtual disks are on LVM with discard and iothread on
the HDD is a 4TB Seagate ST4000DM000 drive, and the NVME is a 2TB
Crucial CT2000P5PSSD8
i tested each disk with ext4/xfs/zfs (default created with the gui)
with 5 runs each, inbetween the caches are flushed and the filesystem synced
i removed the biggest and smallest result and from the remaining 3
results built the average (percentage is relative to the 'none' result)
result:
test none filesystem file
hdd - ext4 125.67s 140.39s (+11.71%) 358.10s (+184.95%)
hdd - xfs 92.18s 102.64s (+11.35%) 351.58s (+281.41%)
hdd - zfs 94.82s 104.00s (+9.68%) 309.13s (+226.02%)
nvme - ext4 60.44s 60.26s (-0.30%) 60.47s (+0.05%)
nvme - xfs 60.11s 60.47s (+0.60%) 60.49s (+0.63%)
nvme - zfs 60.83s 60.85s (+0.03%) 60.80s (-0.05%)
So all in all, it does not seem to make a difference for nvme drives,
for hdds 'filesystem' increases backup time by ~10%, while
for 'file' it largely depends on the filesystem, but always
in the range of factor ~3 - ~4
Note that this does not take into account parallel actions, such as gc,
verify or other backups.
Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2022-11-04 10:49:34 +01:00
- `none` : Does not do any syncing when writing chunks. This is fast
2022-10-28 09:34:48 +02:00
and normally OK, since the kernel eventually flushes writes onto the disk.
The kernel sysctls `dirty_expire_centisecs` and `dirty_writeback_centisecs`
are used to tune that behaviour, while the default is to flush old data
after ~30s.
datastore: make 'filesystem' the default sync-level
rationale is that it makes the backup much safer than 'none', but does not
incur a big of a performance hit as 'file'.
here some benchmark:
data to be backed up:
~14GiB semi-random test images between 12kiB and 4GiB
that results in ~11GiB chunks (more than ram available on the target)
PBS setup:
virtualized (on an idle machine), PBS itself was also idle
8 cores (kvm64 on Intel 12700k) and 8 GiB memory
all virtual disks are on LVM with discard and iothread on
the HDD is a 4TB Seagate ST4000DM000 drive, and the NVME is a 2TB
Crucial CT2000P5PSSD8
i tested each disk with ext4/xfs/zfs (default created with the gui)
with 5 runs each, inbetween the caches are flushed and the filesystem synced
i removed the biggest and smallest result and from the remaining 3
results built the average (percentage is relative to the 'none' result)
result:
test none filesystem file
hdd - ext4 125.67s 140.39s (+11.71%) 358.10s (+184.95%)
hdd - xfs 92.18s 102.64s (+11.35%) 351.58s (+281.41%)
hdd - zfs 94.82s 104.00s (+9.68%) 309.13s (+226.02%)
nvme - ext4 60.44s 60.26s (-0.30%) 60.47s (+0.05%)
nvme - xfs 60.11s 60.47s (+0.60%) 60.49s (+0.63%)
nvme - zfs 60.83s 60.85s (+0.03%) 60.80s (-0.05%)
So all in all, it does not seem to make a difference for nvme drives,
for hdds 'filesystem' increases backup time by ~10%, while
for 'file' it largely depends on the filesystem, but always
in the range of factor ~3 - ~4
Note that this does not take into account parallel actions, such as gc,
verify or other backups.
Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
2022-11-04 10:49:34 +01:00
- `filesystem` (default): This triggers a `` syncfs(2) `` after a backup, but before
2022-10-28 09:34:48 +02:00
the task returns `OK` . This way it is ensured that the written backups
are on disk. This is a good balance between speed and consistency.
Note that the underlying storage device still needs to protect itself against
powerloss to flush its internal ephemeral caches to the permanent storage layer.
- `file` With this mode, a fsync is triggered on every chunk insertion, which
makes sure each and every chunk reaches the disk as soon as possible. While
this reaches the highest level of consistency, for many storages (especially
slower ones) this comes at the cost of speed. For many users the `filesystem`
mode is better suited, but for very fast storages this mode can be OK.
This can be set with:
.. code-block :: console
# proxmox-backup-manager datastore update <storename> --tuning 'sync-level=filesystem'
If you want to set multiple tuning options simultaneously, you can separate them
with a comma, like this:
.. code-block :: console
# proxmox-backup-manager datastore update <storename> --tuning 'sync-level=filesystem,chunk-order=none'
2022-11-25 13:10:34 +01:00
.. _ransomware_protection:
2022-11-28 12:11:18 +01:00
Ransomware Protection & Recovery
--------------------------------
2022-11-25 13:10:34 +01:00
`Ransomware <https://en.wikipedia.org/wiki/Ransomware> `_ is a type of malware
that encrypts files until a ransom is paid. Proxmox Backup Server includes
2022-11-28 12:11:18 +01:00
features that help mitigate and recover from ransomware attacks by offering
2022-11-28 15:34:00 +01:00
off-server and off-site synchronization and easy restoration from backups.
2022-11-25 13:10:34 +01:00
2022-11-28 12:11:18 +01:00
Built-in Protection
~~~~~~~~~~~~~~~~~~~
2022-11-28 10:25:23 +01:00
Proxmox Backup Server does not rewrite data for existing blocks. This means
2022-11-28 12:11:18 +01:00
that a compromised Proxmox VE host or any other compromised system that uses
the client to back up data cannot corrupt or modify existing backups in any
way.
2022-11-25 13:10:34 +01:00
2022-11-28 12:11:18 +01:00
The 3-2-1 Rule with Proxmox Backup Server
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2022-11-25 13:10:34 +01:00
2022-11-28 12:11:18 +01:00
The `3-2-1 rule <https://en.wikipedia.org/wiki/Backup#Storage> `_ is simple but
effective in protecting important data from all sorts of threats, be it fires,
2022-11-28 15:34:00 +01:00
natural disasters or attacks on your infrastructure by adversaries.
2022-11-28 12:11:18 +01:00
In short, the rule states that one should create *3* backups on at least *2*
different types of storage media, of which *1* copy is kept off-site.
Proxmox Backup Server provides tools for storing extra copies of backups in
remote locations and on various types of media.
2022-11-28 15:34:00 +01:00
By setting up a remote Proxmox Backup Server, you can take advantage of the
2022-11-28 12:11:18 +01:00
:ref: `remote sync jobs <backup_remote>` feature and easily create off-site
copies of your backups.
This is recommended, since off-site instances are less likely to be infected by
ransomware in your local network.
2022-11-28 15:34:00 +01:00
You can configure sync jobs to not remove snapshots if they vanished on the
2022-11-28 12:11:18 +01:00
remote-source to avoid that an attacker that took over the source can cause
deletions of backups on the target hosts.
2022-11-28 15:34:00 +01:00
If the source-host became victim of a ransomware attack, there is a good chance
that sync jobs will fail, triggering an :ref:`error notification
2022-11-28 12:11:18 +01:00
<maintenance_notification> `.
It is also possible to create :ref: `tape backups <tape_backup>` as a second
2022-11-28 15:34:00 +01:00
storage medium. This way, you get an additional copy of your data on a
different storage medium designed for long-term storage. Additionally, it can
2022-11-28 16:02:25 +01:00
easily be moved around, be it to an off-site location or, for example, into an
2022-11-28 15:34:00 +01:00
on-site fireproof vault for quicker access.
2022-11-28 12:11:18 +01:00
Restrictive User & Access Management
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2022-11-28 15:34:00 +01:00
Proxmox Backup Server offers a comprehensive and fine-grained :ref:`user and
2022-11-28 12:11:18 +01:00
access management <user_mgmt>` system. The ` Datastore.Backup` privilege, for
example, allows only to create, but not to delete or alter existing backups.
The best way to leverage this access control system is to:
2022-11-28 15:34:00 +01:00
2022-11-28 12:11:18 +01:00
- Use separate API tokens for each host or Proxmox VE Cluster that should be
able to back data up to a Proxmox Backup Server.
- Configure only minimal permissions for such API tokens. They should only have
a single permission that grants the `DataStore` access role on a very narrow
ACL path that is restricted to a specific namespace on a specific datastore,
for example `/datastore/tank/pve-abc-cluster` .
.. tip :: One best practice to protect against ransomware is not to grant delete
permissions, but to perform backup pruning directly on Proxmox Backup Server
using :ref: `prune jobs <maintenance_prune_jobs>` .
2022-11-28 15:34:00 +01:00
Please note that the same also applies for sync jobs. By limiting a sync user's
or an access token's right to only write backups, not delete them, compromised
2022-11-28 12:11:18 +01:00
clients cannot delete existing backups.
Ransomware Detection
~~~~~~~~~~~~~~~~~~~~
A Proxmox Backup Server might still get compromised within insecure networks,
if physical access to the server is attained, or due to weak or insufficiently
protected credentials.
If that happens, and your on-site backups are encrypted by ransomware, the
SHA-256 checksums of the backups will not match the previously recorded ones
anymore, hence, restoring the backup will fail.
2022-11-25 13:10:34 +01:00
2022-11-28 10:25:23 +01:00
To detect ransomware inside a compromised guest, it is recommended to
frequently test restoring and booting backups. Make sure to restore to a new
guest and not to overwrite your current guest.
In the case of many backed-up guests, it is recommended to automate this
2022-11-28 15:34:00 +01:00
restore testing. If this is not possible, restoring random samples from the
backups periodically (for example, once a week or month), is advised'.
2022-11-25 13:10:34 +01:00
2022-11-28 10:25:23 +01:00
In order to be able to react quickly in case of a ransomware attack, it is
recommended to regularly test restoring from your backups. Make sure to restore
to a new guest and not to overwrite your current guest.
Restoring many guests at once can be cumbersome, which is why it is advisable
to automate this task and verify that your automated process works. If this is
not feasible, it is recommended to restore random samples from your backups.
2022-11-28 15:34:00 +01:00
While creating backups is important, verifying that they work is equally
2022-11-28 10:46:50 +01:00
important. This ensures that you are able to react quickly in case of an
emergency and keeps disruption of your services to a minimum.
2022-11-25 13:10:34 +01:00
2022-11-28 15:34:01 +01:00
:ref: `Verification jobs <maintenance_verification>` can also assist in detecting
a ransomware presence on a Proxmox Backup Server. Since verification jobs
regularly check if all backups still match the checksums on record, they will
start to fail if a ransomware starts to encrypt existing backups. Please be
aware, that an advanced enough ransomware could circumvent this mechanism.
Hence, consider verification jobs only as an additional, but not a sufficient
protection measure.
2022-11-25 13:10:34 +01:00
2022-11-28 12:11:18 +01:00
General Prevention Methods and Best Practices
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2022-11-25 13:10:34 +01:00
2022-11-28 10:25:23 +01:00
It is recommended to take additional security measures, apart from the ones
offered by Proxmox Backup Server. These recommendations include, but are not
limited to:
2022-11-25 13:10:34 +01:00
* Keeping the firmware and software up-to-date to patch exploits and
vulnerabilities (such as
`Spectre <https://en.wikipedia.org/wiki/Spectre_(security_vulnerability)> `_ or
`Meltdown <https://en.wikipedia.org/wiki/Meltdown_(security_vulnerability)> `_ ).
* Following safe and secure network practices, for example using logging and
2022-11-28 12:11:18 +01:00
monitoring tools and dividing your network so that infrastructure traffic and
user or even public traffic are separated, for example by setting up VLANs.
2022-11-28 15:34:00 +01:00
* Set up a long-term retention. Since some ransomware might lay dormant a
2022-11-28 12:11:18 +01:00
couple of days or weeks before starting to encrypt data, it can be that
older, existing backups are compromised. Thus, it is important to keep at
least a few backups over longer periods of time.
2022-11-25 13:10:34 +01:00
For more information on how to avoid ransomware attacks and what to do in case
2022-11-28 15:34:00 +01:00
of a ransomware infection, see official government recommendations like `CISA's
2022-11-28 12:11:18 +01:00
(USA) guide <https://www.cisa.gov/stopransomware/ransomware-guide>`_ or EU
resources like ENSIA's `Threat Landscape for Ransomware Attacks
<https://www.enisa.europa.eu/publications/enisa-threat-landscape-for-ransomware-attacks> `_
or `nomoreransom.org <https://www.nomoreransom.org/en/index.html> `_ .