v1.0.5
Release v1.0.5
Release Date: 13th December 2022
Summary
This patch release contains important fixes and supportability enhancements for issues identified after the release of v1.0.4
Users of prior versions are advised to upgrade to this version. New users are advised to install only this version.
Fixes
- fix(csi-node): cherry-pick wait until filesystem shutdown before disconnect
- Sometimes after/during disconnect we get some page write errors, triggered by a journal
update by the JBD2 worker task.
To get around these, we now wait until the filesystem&jbd2 is shutdown before disconnecting.
- Sometimes after/during disconnect we get some page write errors, triggered by a journal
- fix(csi-node): cherry-pick add noddy sleep between umount and disconnect
- WA for page read errors due to ENXIO. There seems to be some race in the kernel when removing a device with queued IOs.
Although an ugly WA, sleeping between umount and disconnect seems to alleviate this.
- WA for page read errors due to ENXIO. There seems to be some race in the kernel when removing a device with queued IOs.
- fix(csi-node): cherry-pick don't detach if mounts are present
- Eliminates a race condition where detaches were being done even when a device had mount points.
- fix(nvmx): reentrant controller event notification
- Eliminates a potential deadlocks when event listener being notified indirectly triggers the second event notification
action for the same NVMe controller.
- Eliminates a potential deadlocks when event listener being notified indirectly triggers the second event notification
- feat(grpc): per nexus instance locks in grpc api
- Nexus gRPC API is now protected on per-nexus basis instead of global API serialisation, which provides better scalability.
Testing
Mayastor is subject to extensive unit, component and system-level testing throughout the development and release cycle. Resources for system-level (E2E) testing are currently provided by DataCore Software.
At this time, personnel and hardware resource limitations constrain testing by the maintainers to linux builds on x86. This reflects the primary use-case which the maintainers are currently targeting with the OpenEBS Mayastor project. Therefore, the use of Mayastor with other operating systems and/or architectures, if even possible, should be considered serendipitous and wholly experimental.
This release has been subject to End-to-End testing under Ubuntu 20.04.4_LTS (kernel: ubuntu-5.15.0-50-generic)
- Tested k8s versions
- 1.23.7
Known Issues
-
The Pool Operator is unable to provision pools directly using a file as the backing device. The operator attempts to validate any device path supplied in the pool specification as an accessible block device attached to the corresponding Mayastor node. In the case of a file store, there is no block device and the validation fails, causing provisioning of the pool to be aborted. This will be addressed in a future release
- workaround: Mount the file/image as a loopback device (
losetup
) and use the device path of the loopback device in the pool spec
- workaround: Mount the file/image as a loopback device (
-
Deploying an application pod on a worker node which hosts both Mayastor and Prometheus exporter causes that node to restart.
- workaround: Use kernel version 5.13 or later
Getting Started
Mayastor user documentation, including a quick deployment guide, can be found here
Upgrade
Upgrades from versions of Mayastor prior to v1.0.0 are not supported. Any release earlier than v1.0.4 should be removed prior to installing this version.
Upgrades are disruptive - data plane and control plane pods must be unscheduled, and hence all applications using Mayastor volumes must be stopped prior to performing the update. The upgrade process is manual. The K8s definition files corresponding to the deployment of Mayastor components should be patched to reflect the versions of images from this release (see the /deploy) folder in the appropriate repositories and/or the GitBook Quickstart instruction for details of which definition files are affected, and check the v1.0.3 versions to find the appropriate image tag values.
Support
If you are having issues during installation, configuration or upgrade, you can contact us via:
- OpenEBS on Kubernetes Slack community
- Already signed up? Head to our discussions at #openebs
- Raising an issue
"Unsupported" Architectures and Operating Systems (inc. ARM, Raspberry Pi, MacOS)
As described in the section on software testing above, the maintainers build and test Mayastor only on linux, on x86-64. The use of Mayastor in other environments is therefore not necessarily possible, at least without modification. Where possible, this is currently largely coincidental - it is not "fully" tested and therefore this should be considered an entirely experimental use-case.
The maintainers will be pleased to receive contributions in this area, with the following understanding:
- Such PR's will be reviewed for correctness, good practice, licensing compliance and general quality
- PR's will be accepted on the basis that testing by the maintainers is restricted to demonstrating no negative affect on the stability of x86-64 builds
- The maintainers will not perform acceptance testing or "positive release" of such functionality on any other OS or architecture, which is in accordance with their designation of these environments as experimental use cases at this time.
- The maintainers will not provide build artifacts or container images for these environments