Introduction to PMEM-CSI for Kubernetes*
Intel PMEM-CSI is a CSI storage driver for container orchestrators like Kubernetes. It makes local persistent memory (PMEM) available as a filesystem volume to container applications. Currently, PMEM-CSI can utilize non-volatile memory devices that can be controlled via the libndctl utility library. In this readme, we use persistent memory to refer to a non-volatile dual in-line memory module (NVDIMM).
The v1.1 release is the latest feature release and is regularly updated with newer base images and bug fixes. Older releases are no longer supported.
Documentation is part of the source code for each release and also available in rendered form for easier reading:
- latest 1.1.x release
- latest 1.0.x release
- latest 0.9.x release
- latest 0.8.x release
- latest 0.7.x release
- latest documentation, in development
Supported Kubernetes versions
PMEM-CSI implements the CSI specification version 1.x, which is only supported by Kubernetes versions >= v1.13. The following table summarizes the status of support for PMEM-CSI on different Kubernetes versions:
Kubernetes version | Required alpha feature gates | Support status |
---|---|---|
1.13 | CSINodeInfo, CSIDriverRegistry, CSIBlockVolume | unsupported 1 |
1.14 | unsupported 2 | |
1.15 | CSIInlineVolume | unsupported 3 |
1.16 | unsupported 4 | |
1.17 | unsupported 5 | |
1.18 | unsupported 6 | |
1.19 | unsupported 6 | |
1.20 | unsupported 6 | |
1.21 | untested | |
1.22 | supported | |
1.23 | supported | |
1.24 | supported | |
1.25 | supported |
1 Several relevant features are only available in alpha
quality in Kubernetes 1.13 and the combination of skip attach and
block volumes is completely broken, with the
fix only being
available in later versions. The external-provisioner v1.0.1 for
Kubernetes 1.13 lacks the --strict-topology
flag and therefore late
binding is unreliable. It's also a release that is not supported
officially by upstream anymore.
2 Lacks support for ephemeral inline volumes. Not supported officially by upstream anymore.
3 Not supported officially by upstream anymore.
4 No longer supported by current external-provisioner 2.0.0 because support for the v1beta CSI APIs was removed. Also not supported officially by upstream anymore.
5 Kubernetes 1.17 uses deprecated beta storage APIs.
6 Storage capacity tracking is expected to be enabled. It became beta in Kubernetes 1.21.
Feature status
PMEM-CSI is under active development. New features are added continuously and old features may be removed. To minimize the impact of feature changes on production usage, the project uses the following approach:
- New features are considered alpha while their API and usage are under discussion.
- Stable features are supported and tested across up- and downgrades between all supported PMEM-CSI releases. Whether a release is still supported is documented in the release notes.
- Alpha features may be removed at any time. Stable features will be marked as deprecated first and then may be removed after half a year. Deprecations are announced in the release notes of the release that deprecates the feature.
The following table lists the features that are stable:
Feature | Introduced in |
---|---|
LVM mode | v0.5.0 |
Direct mode | v0.5.0 |
Persistent volumes | v0.5.0 |
CSI Ephemeral volumes | v0.6.0 |
Raw block volumes | v0.6.0 |
Capacity-aware pod scheduling | v0.7.0 |
Operator API | v0.9.0 |
Release notes are prepared only for major new releases (such as v0.6.0) but not for automatic updates (such as v0.6.1). For more information on releases, see release management.
Demo
Click the image to watch the animated demo on asciinema.org:
License
All of the source code required to build PMEM-CSI is available under
Open Source licenses. The source code files identify the external Go
modules that are used. Binaries are distributed as container images on
Docker* Hub. Those images contain license texts under
/usr/local/share/package-licenses
and source code under
/usr/local/share/package-sources
.