Use Stratis to Manage Local Storage on RHEL 8 / CentOS 8

How to install Stratis on CentOS 8 / RHEL 8?. Stratis is a local storage-management solution for Linux focused on simplicity and ease of use. It uses Linux’s devicemapper subsystem and the XFS filesystem. Stratis also gives you access to advanced storage features such as:
- Thin provisioning
- File system snapshots
- Pool-based management
- Monitoring.
As a system administrator, you can easily set up new storage and manage complex storage configurations integrated by the Stratis high-level system. It is a hybrid user-and-kernel local storage management system that uses the concept of a storage pool.
Stratis is the new local storage manager for RHEL 8. You can check other RHEL 8 new Features on Red Hat Enterprise Linux 8 (RHEL 8) New Features & Review
Stratis Terminologies
When working with Stratis, you’ll often come across the following terminologies:
- blockdev: This is a block device, such as a disk or a disk partition.
- pool: A pool is composed of one or more block devices with a fixed total size, equal to the size of the block devices.
- filesystem: Each pool can contain one or more file systems, which store files. A filesystem does not have a fixed total size since it is thinly provisioned. If the size of the data approaches the virtual size of the file system, Stratis grows the thin volume and the file system automatically.
Stratis pools are located under the /dev/stratis/<poolname> directory.
Stratis Supported devices
Stratis works with the following block devices:
- iSCSI
- LVM logical volumes
- Device Mapper Multipath
- hard drives
- LUKS
- SSDs
- NVMe storage devices
- mdraid
Stratis Software components
Stratis provides two software components:
- stratisd daemon: This manages collections of block devices, and provides a D-Bus API.
- stratis-cli: This provides a command-line tool stratiswhich itself uses the D-Bus API to communicate with stratisd.
Step 1: Install Stratis on RHEL 8 / CentOS 8
RHEL 8 is distributed withstratisd and stratis-cli which can be easily installed using yum package management tool.
sudo yum -y install stratisd stratis-cliYou can get full package details using rpm command:
# rpm -qi stratisd stratis-cli
Name        : stratisd
Version     : 2.4.2
Release     : 2.el8
Architecture: x86_64
Install Date: Mon 05 Jun 2023 10:57:36 PM UTC
Group       : Unspecified
Size        : 13527243
License     : MPLv2.0
Signature   : RSA/SHA256, Tue 09 Nov 2021 03:01:31 PM UTC, Key ID 15af5dac6d745a60
Source RPM  : stratisd-2.4.2-2.el8.src.rpm
Build Date  : Tue 09 Nov 2021 02:35:59 PM UTC
Build Host  : ord1-prod-x86build004.svc.aws.rockylinux.org
Relocations : (not relocatable)
Packager    : [email protected]
.....
Name        : stratis-cli
Version     : 2.4.2
Release     : 1.el8
Architecture: noarch
Install Date: Mon 05 Jun 2023 10:57:36 PM UTC
Group       : Unspecified
Size        : 311001
License     : ASL 2.0
Signature   : RSA/SHA256, Tue 09 Nov 2021 03:00:53 PM UTC, Key ID 15af5dac6d745a60
Source RPM  : stratis-cli-2.4.2-1.el8.src.rpm
Build Date  : Tue 09 Nov 2021 02:29:36 PM UTC
Build Host  : ord1-prod-x86build003.svc.aws.rockylinux.org
Relocations : (not relocatable)
Packager    : [email protected]
Step 2: Start Stratis service
After installing Stratis packages, you’ll need to start the service and enable it.
systemctl enable --now stratisdConfirm service status:
$ systemctl status stratisd
● stratisd.service - Stratis daemon
   Loaded: loaded (/usr/lib/systemd/system/stratisd.service; enabled; vendor preset: enabled)
   Active: active (running) since Mon 2023-06-05 22:58:27 UTC; 11s ago
     Docs: man:stratisd(8)
 Main PID: 71943 (stratisd)
    Tasks: 6 (limit: 23036)
   Memory: 1.6M
   CGroup: /system.slice/stratisd.service
           └─71943 /usr/libexec/stratisd --log-level debug
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z INFO  libstratis::stratis::run] stratis daemon version 2.4.2 started
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z INFO  libstratis::stratis::run] Using StratEngine
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z INFO  libstratis::engine::strat_engine::liminal::identify] Beginning initial search for Stratis block devices
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z DEBUG libstratis::stratis::run] 0: thread started
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z DEBUG libstratis::stratis::run] 1: thread started
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z DEBUG libstratis::stratis::run] 2: thread started
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z DEBUG libstratis::stratis::run] 3: thread started
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z INFO  libstratis::stratis::ipc_support::dbus_support] D-Bus API is available
Jun 05 22:58:27 rocky8.mylab.io stratisd[71943]: [2023-06-05T22:58:27Z DEBUG libstratis::stratis::run] 4: thread started
Jun 05 22:58:27 rocky8.mylab.io systemd[1]: Started Stratis daemon.
Step 3: Creating a Stratis pool
For this, you’ll require block devices which are not in use or mounted to create Stratis pool from. The block devices should be at least 1 GiB in size each.
On my RHEL 8 server, I have the following block devices:
# lsblk
NAME          MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sr0            11:0    1 1024M  0 rom  
vda           252:0    0   20G  0 disk 
├─vda1        252:1    0    1G  0 part /boot
└─vda2        252:2    0   19G  0 part 
  ├─rhel-root 253:0    0   17G  0 lvm  /
  └─rhel-swap 253:1    0    2G  0 lvm  [SWAP]
vdb           252:16   0   10G  0 disk 
vdc           252:32   0   10G  0 disk 
vdd           252:48   0   10G  0 disk 
vde           252:64   0   10G  0 disk
I’ll create the first pool with single block device /dev/vdb and the other pool with three block devices /dev/vdc,/dev/vdd,/dev/vdd
These block devices should not have a partition table, confirm with:
sudo blkid -p /<devicepath>If it has a partition table and you want to use it, first clear a device so that it can be used by Stratis.
sudo wipefs -a /<devicepath>Create a pool with one block device
To create a pool with one block device /dev/vdb use:
sudo stratis pool create mypool1 /dev/vdbList available pools with:
$ sudo stratis pool list
Name       Total Physical Size  Total Physical Used
mypool1                 10 GiB               52 MiBCreate a pool with three block device
Now let’s create another pool with three block devices /dev/vdc,/dev/vdd,/dev/vdd
sudo stratis pool create mypool2 /dev/vdc /dev/vdd /dev/vdeYou should now have two pools:
$ sudo stratis pool list
Name       Total Physical Size  Total Physical Used
mypool1                 10 GiB               52 MiB
mypool2                 30 GiB               60 MiBFrom the output, we can see that the size of the volume is the summation of all block devices raw storage.
Step 4: Creating a filesystem from the pool
Once you have your pools ready, you can create a Stratis file system on a pool using the syntax:
sudo stratis fs create <poolname>  <filesystemname>See examples below.
Create a filesystem on mypool1
sudo stratis fs create mypool1 logsCreate a filesystem on mypool2
sudo stratis fs create mypool2  data
sudo stratis fs create mypool2  webTo list created filesystems, use:
$ sudo stratis fs list
Pool Name  Name  Used     Created            Device                     
mypool1    logs  546 MiB  Dec 11 2018 01:00  /dev/stratis/mypool1/logs  
mypool2    data  546 MiB  Dec 11 2018 01:04  /dev/stratis/mypool2/dataYou can also limit output to specified pool:
$ sudo stratis fs list mypool2
Pool Name  Name  Used     Created            Device                     
mypool2    data  546 MiB  Dec 11 2018 01:04  /dev/stratis/mypool2/data  
mypool2    web   546 MiB  Dec 11 2018 01:06  /dev/stratis/mypool2/webThe lsblk output should look similar to below:
$ sudo lsblk 
NAME                                                                                        MAJ:MIN RM  SIZE RO TYPE    MOUNTPOINT
sr0                                                                                          11:0    1 1024M  0 rom     
vda                                                                                         252:0    0   20G  0 disk    
├─vda1                                                                                      252:1    0    1G  0 part    /boot
└─vda2                                                                                      252:2    0   19G  0 part    
  ├─rhel-root                                                                               253:0    0   17G  0 lvm     /
  └─rhel-swap                                                                               253:1    0    2G  0 lvm     [SWAP]
vdb                                                                                         252:16   0   10G  0 disk    
└─stratis-1-private-68bf465c93eb4aa98ed2264b38d8c42a-physical-originsub                     253:2    0  1.8G  0 stratis 
  ├─stratis-1-private-68bf465c93eb4aa98ed2264b38d8c42a-flex-thinmeta                        253:3    0   16M  0 stratis 
  │ └─stratis-1-private-68bf465c93eb4aa98ed2264b38d8c42a-thinpool-pool                      253:6    0  1.8G  0 stratis 
  │   ├─stratis-1-68bf465c93eb4aa98ed2264b38d8c42a-thin-fs-217bee04c2f14266b496eaada54a0311 253:12   0    1T  0 stratis 
  │   └─stratis-1-68bf465c93eb4aa98ed2264b38d8c42a-thin-fs-1f563ecb6e0c497ab3fc24d5b2e33fe1 253:13   0    1T  0 stratis 
  ├─stratis-1-private-68bf465c93eb4aa98ed2264b38d8c42a-flex-thindata                        253:4    0  1.8G  0 stratis 
  │ └─stratis-1-private-68bf465c93eb4aa98ed2264b38d8c42a-thinpool-pool                      253:6    0  1.8G  0 stratis 
  │   ├─stratis-1-68bf465c93eb4aa98ed2264b38d8c42a-thin-fs-217bee04c2f14266b496eaada54a0311 253:12   0    1T  0 stratis 
  │   └─stratis-1-68bf465c93eb4aa98ed2264b38d8c42a-thin-fs-1f563ecb6e0c497ab3fc24d5b2e33fe1 253:13   0    1T  0 stratis 
  └─stratis-1-private-68bf465c93eb4aa98ed2264b38d8c42a-flex-mdv                             253:5    0   16M  0 stratis 
vdc                                                                                         252:32   0   10G  0 disk    
vdd                                                                                         252:48   0   10G  0 disk    
vde                                                                                         252:64   0   10G  0 disk    
└─stratis-1-private-557de29f274a45d583c62cafbab8edd6-physical-originsub                     253:7    0  816M  0 stratis 
  ├─stratis-1-private-557de29f274a45d583c62cafbab8edd6-flex-thinmeta                        253:8    0   16M  0 stratis 
  │ └─stratis-1-private-557de29f274a45d583c62cafbab8edd6-thinpool-pool                      253:11   0  768M  0 stratis 
  ├─stratis-1-private-557de29f274a45d583c62cafbab8edd6-flex-thindata                        253:9    0  768M  0 stratis 
  │ └─stratis-1-private-557de29f274a45d583c62cafbab8edd6-thinpool-pool                      253:11   0  768M  0 stratis 
  └─stratis-1-private-557de29f274a45d583c62cafbab8edd6-flex-mdv                             253:10   0   16M  0 stratisStep 5: Mounting a Stratis file system
To mount the file system, use the entries that Stratis maintains in the /dev/stratis/ directory. See examples below:
sudo mkdir /data
sudo mount /dev/stratis/mypool2/data /dataI’ll also mount /dev/stratis/mypool2/web
sudo mount /dev/stratis/mypool2/web /srvCheck currents mount points:
$ sudo df -hT | grep stratisThe output is:

Add a persistent mount point to /etc/fstab
To configure persistent mount, get the UUID of the filesystem.
# blkid -p /dev/stratis/mypool2/web
/dev/stratis/mypool2/web: UUID="7d3b49be-51d5-499c-b12b-b5ebe118c416" TYPE="xfs" USAGE="filesystem"
# blkid -p /dev/stratis/mypool2/data
/dev/stratis/mypool2/data: UUID="a6f40f25-140c-43e3-97af-e9e771f08a54" TYPE="xfs" USAGE="filesystem"Copy the printed UUID and add mount options to /etc/fstab file
echo "UUID=7d3b49be-51d5-499c-b12b-b5ebe118c416 /srv xfs defaults 0 0" | sudo tee -a /etc/fstab
echo "UUID=a6f40f25-140c-43e3-97af-e9e771f08a54 /data xfs defaults 0 0" | sudo tee -a /etc/fstabTest:
sudo umount /data
sudo umount /srv
sudo mount -aOther Stratis Administration Commands
Below are other administrative tasks you can perform on Stratis Pools.
Removing a Stratis file system
Before you can remove Stratis file system, you need to unmount it
sudo umount /mountpointThen destroy it:
sudo stratis filesystem destroy <poolname<  <filesystemname>Example
sudo umount /srv
sudo stratis filesystem destroy mypool2 webConfirm:
$  sudo stratis filesystem list mypool2
Pool Name  Name  Used     Created            Device                     
mypool2    data  546 MiB  Dec 11 2018 01:04  /dev/stratis/mypool2/dataAdd a disk to an existing pool
To add another disk to the pool, use:
sudo stratis pool add-data <poolname> /<devicepath>Example:
sudo stratis pool add-data mypool1 /dev/vdfConfirm:
$ sudo stratis pool list 
Name       Total Physical Size  Total Physical Used
mypool1                 20 GiB             1.12 GiB
mypool2                 30 GiB              606 MiBCreate Stratis snapshots
Stratis Snapshot is a read/writeable thinly provisioned point in time copy of the source FS.
To create Stratis snapshot, use:
sudo stratis fs snapshot <poolname> <fsname> <snapshotname>Example:
sudo stratis fs snapshot  mypool2  web websnapshot-$(date +%Y-%m-%d)Confirm:
$ sudo stratis filesystem list mypool2
Pool Name  Name                    Used     Created            Device                                       
mypool2    web                     546 MiB  Dec 11 2018 01:06  /dev/stratis/mypool2/web                     
mypool2    websnapshot-2018-12-11  546 MiB  Dec 11 2018 03:34  /dev/stratis/mypool2/websnapshot-2018-12-11  
mypool2    data                    546 MiB  Dec 11 2018 01:04  /dev/stratis/mypool2/dataYou can mount and operate Snapshot independent of the source file system.
sudo  mount /dev/stratis/mypool2/websnapshot-2018-12-11 /mnt
for i in {1..10}; do sudo touch /mnt/$i.txt; done
ls /mnt
ls /srv
sudo umount /mntRevert a Stratis file system to a previous snapshot
It is possible to revert a Statis file system to the previously created snapshot. See below
First Unmount and remove the original file system:
sudo umount /srv
sudo stratis filesystem destroy mypool2 webThen create a copy of the snapshot under the name of the original file system:
sudo  stratis filesystem snapshot mypool2  websnapshot-2018-12-11 webMount the snapshot
sudo mount /dev/stratis/mypool2/web /srvThis filesystem should contain the data we added to the snapshot
$ ls /srv/
10.txt     1.txt  3.txt  5.txt  7.txt  9.txt
1..10.txt  2.txt  4.txt  6.txt  8.txtAlso change UUID on /etc/fstab to match new filesystem UUID.
# blkid -p /dev/stratis/mypool2/web
/dev/stratis/mypool2/web: UUID="110b737f-2117-4624-8c97-c3def8b2a539" TYPE="xfs" USAGE="filesystem"
# grep srv /etc/fstab 
UUID=110b737f-2117-4624-8c97-c3def8b2a539 /srv xfs defaults 0 0Removing a Stratis snapshot
To remove the snapshot, unmount the snapshot.
sudo unmount /snapmountpointNow destroy the snapshot:
sudo stratis filesystem destroy <poolname> <snapshotname>Example:
sudo stratis filesystem destroy mypool2 websnapshot-2018-12-11Check:
$ sudo stratis filesystem list mypool2
Pool Name  Name  Used     Created            Device                     
mypool2    web   546 MiB  Dec 11 2018 03:58  /dev/stratis/mypool2/web   
mypool2    data  546 MiB  Dec 11 2018 01:04  /dev/stratis/mypool2/dataRenaming a file system
To rename a file system, use the syntax:
sudo stratis filesystem rename <poolname> <old-fsname>  <new-fsname>The example below renames logs filesystem to backups
sudo stratis filesystem rename mypool1  logs  backupsConfirm:
$ sudo stratis filesystem list mypool1
Pool Name  Name     Used     Created            Device                        
mypool1    backups  546 MiB  Dec 11 2018 01:00  /dev/stratis/mypool1/backupsRemoving a Stratis pool
To completely destroy a Stratis pool, you need to:
- Unmount all file systems on the pool
- Destroy the file systems:
- Destroy the pool
In below example, we will destroy mypool2
1. List available file systems
$ sudo stratis filesystem list mypool2
Pool Name  Name  Used     Created            Device                     
mypool2    data  546 MiB  Dec 11 2018 01:04  /dev/stratis/mypool2/data2. Unmount the file systems
sudo umount /dev/stratis/mypool2/data3. Destroy file system:
sudo stratis filesystem destroy mypool2 data4. Destroy the pool
sudo stratis pool destroy mypool24. Verify that the pool no longer exists:
$ sudo stratis pool list
Name       Total Physical Size  Total Physical Used
mypool1                 20 GiB             1.12 GiB6. Remove /etc/fstab lines for destroyed file system
sudo vim /etc/fstabYou have learned how to install and use Stratis to manage layered local storage on RHEL 8 and Fedora Linux distributions. My next articles will cover the installation and usage of Stratis on CentOS 7, Debian and Ubuntu.
Similar guides:
Install and Configure NFS Server on RHEL 8 / CentOS 8
 
				 
					


