Stratis 3.0.0
Summary
Stratis 3.0.0 includes many internal improvements, bug fixes, and user-visible changes.
Owner
- Name: Dennis Keefe, Anne Mulhern, John Baublitz
- Email: dkeefe@redhat.com, amulhern@redhat.com, jbaublitz@redhat.com
Current status
- Targeted release: Fedora 36
- Last updated: 2021-10-27
- FESCo issue: <will be assigned by the Wrangler>
- Tracker bug: <will be assigned by the Wrangler>
- Release notes tracker: <will be assigned by the Wrangler>
Detailed Description
stratisd 3.0.0
stratisd 3.0.0 includes a number of significant internal improvements and a few bug fixes.
In stratisd 3.0.0 the D-Bus API has undergone a revision and the prior
interfaces are all removed. The FetchProperties
interfaces that
were supported by all objects have been removed. The values that were
previously obtainable via the FetchProperties
methods
are now conventional D-Bus properties. The possible values of error codes
returned by the D-Bus methods have been reduced to 0 and 1, with the usual
interpretation.
stratisd
bug fixes:
- The
--prompt
option was not passed tostratis-min
in the
stratis-fstab-setup
script; this prevented the user from entering the
password necessary to unlock an encrypted pool during boot. This is
no longer the case.
stratisd
was not immediately updating the devicemapper device stack when
a cache was initialized with the result that the cache was not immediately put in use. This is no longer the case.
stratisd
was not immediately updating the Clevis encryption info associated
with a pool on a command to bind an encrypted pool with Clevis. This problem has been corrected.
stratisd
was sending an incorrect D-Bus signal on a pool name change; this
has been fixed.
- Previously, when
stratisd-min
, which runs during boot before D-Bus
functionality is available, gave way to stratisd
when the D-Bus had been set
up, it was possible for inconsistencies to arise if the Stratis engine was
performing an operation which required invoking a distinct executable. The
executable might be terminated during its execution, and stratisd-min
would
take the action appropriate to the command failure before exiting. Now, systemd
is instructed to send a kill signal only to stratisd-min
and not to any of
stratisd-min
's child processes when shutting down stratisd-min
.
Other stratisd
improvements:
- Handling of errors returned by internal methods is improved; a chaining
mechanism has been introduced and the error chains can be scrutinized programatically to identify expected scenarios like rollback failures.
- A set of states indicating that a pool has reduced capability have been
added internally and are published on the D-Bus. A pool's capability is reduced on an error being returned internally which contains, somewhere in its chain, the appropriate identifying error variant.
- The code used to roll back failed encryption operations on a list of
pool devices has been refactored and generalized. It is now capable of returning an error that can be used to identify a restricted pool capability due to a rollback failure.
stratisd
uses sha-256 instead of sha-1 for Clevis-related encryption
operations to conform with Clevis's own usage.
stratisd
exits more elegantly and less frequently if it encounters an
error during execution of the distinct tasks that are assigned to the individual threads that it manages internally.
- In preparation for edition 2021 of the Rust language,
stratisd
source code
has been updated to conform entirely to edition 2018 recommendations.
Detailed Description
stratis-cli 3.0.0
Users of the Stratis CLI may observe the following changes:
- It is now possible to set the filesystem logical size when creating a
filesystem.
- It is possible to rebind a pool using a Clevis tang server or with a key
in the kernel keyring.
- Filesystem and pool list output have been extended and improved. The pool
listing includes an Alerts
column. Currently this column is used to indicate
whether the pool is in a restricted operation mode. A new subcommand,
stratis pool explain
, which provides a fuller explanation of the codes
displayed in the Alerts
column has been added. The filesystem listing
now displays a filesystem's logical size.
- With encrypted pools it was previously possible for the display of block
device paths to change format if stratisd
was restarted after an encrypted
pool had been created. Now the display of the block device paths is consistent
across stratisd
restarts.
- Previously, if a user specified the same device using two different paths
when creating or extending a pool the different paths would be
interpreted as two different devices and an error would be returned when
stratisd
attempted to initialize the device a second time. Now, the
different paths are canonicalized eagerly, and converted into a single
canonical representation of the device, stratisd
initializes the device only
once, and no error is returned.
Feedback
Benefits to Fedora
Users of Fedora will now benefit from Stratis 2.3.0 by:
- Having the ability to set the filesystem size at create time
- Changing the passphrase or NBDE server using the rebind option
Scope
- Proposal owners:
- Update existing stratis-cli package to specify new release
- Update existing stratisd package to specify new release
- Other developers: N/A
- Release engineering: Self Contained
- Policies guidelines: N/A
- Trademark approval: N/A
Upgrade/compatibility impact
- Reviewing information on this topic
How To Test
- Reviewing details about testing the filesystem size
- Reviewing details about testing the rebind command
User Experience
Other than the changes mentioned above the user experience will be the same.
Dependencies
Still reviewing package requirements
- ibblkid-rs
- stratisd_proc_macros
- libblkid-rs
Contingency Plan
- Contingency mechanism:
- Contingency deadline: N/A
- Blocks release? No
- Blocks product? No
Documentation
This content can be viewed on our Developer’s blog - not complete yet -
- Waiting for developer's blog to be posted, draft is here:
- Changelogs for stratisd
- Changelogs for stratis-cli
Release Notes
Includes recent version of Stratis