OpenEBS helps Developers and Platform SREs easily deploy Kubernetes Stateful Workloads that require fast and highly reliable container attached storage. OpenEBS can be deployed on any Kubernetes cluster - either in cloud, on-premise (virtual or bare metal) or developer system (minikube).
OpenEBS Data Engines and Control Plane are implemented as micro-services, deployed as containers and orchestrated by Kubernetes itself. An added advantage of being a completely Kubernetes native solution is that administrators and developers can interact and manage OpenEBS using all the wonderful tooling that is available for Kubernetes like kubectl, Helm, Prometheus, Grafana, etc.
OpenEBS turns any storage available on the Kubernetes worker nodes into local or distributed Kubernetes Persistent Volumes.
Local Volumes are accessible only from a single node in the cluster. Pods using Local Volume have to be scheduled on the node where volume is provisioned. Local Volumes are typically preferred for distributed workloads like Cassandra, MongoDB, Elastic, etc that are distributed in nature and have high availability built into them. Depending on the type of storage attached to the Kubernetes worker, OpenEBS offers different flavors of Local PV - Hostpath, LVM and ZFS.
Replicated Volumes as the name suggests, are those that have their data synchronously replicated to multiple nodes. Volumes can sustain node failures. The replication also can be setup across availability zones helping applications move across availability zones. OpenEBS offers Replicated PV Mayastor as an replicated storage solution, which provides high availability and high performance.
OpenEBS can run on any Kubernetes 1.23+ cluster in a matter of minutes. See the Quickstart Guide to OpenEBS for detailed instructions.
OpenEBS Helm chart is a unified Helm chart that pulls together engine specific charts. The engine charts are included as dependencies.
openebs
├── (default) Local PV HostPath
├── (default) Local PV LVM
├── (default) Local PV ZFS
└── (default) Replicated PV Mayastor
- Local PV Hostpath Prerequisites
- Local PV LVM Prerequisites
- Local PV ZFS Prerequisites
- Replicated PV Mayastor Prerequisites
Before installing OpenEBS Helm chart, the OpenEBS Helm repository needs to be added to the Helm client.
helm repo add openebs https://openebs.github.io/openebs
helm repo update
helm install openebs --namespace openebs openebs/openebs --create-namespace
The above commands will install OpenEBS LocalPV Hostpath, OpenEBS LocalPV LVM, OpenEBS LocalPV ZFS and OpenEBS Mayastor components in openebs namespace with chart name as openebs.
Replicated PV Mayastor can be excluded during the installation with the following command:
helm install openebs --namespace openebs openebs/openebs --set engines.replicated.mayastor.enabled=false --create-namespace
To view the chart and get the following output.
helm ls -n openebs
NAME NAMESPACE REVISION UPDATED STATUS CHART APP VERSION
openebs openebs 1 2024-07-07 09:13:00.903321318 +0000 UTC deployed openebs-4.1.0 4.1.0
As a next step verify the installation and do the post installation steps.
For more details on customizing and installing OpenEBS please see the chart values.
helm ls --all
helm delete `<RELEASE NAME>` -n `<RELEASE NAMESPACE>`
Tip: Prior to deleting the Helm chart, make sure all the storage volumes and pools are deleted.
Repository | Name | Version |
---|---|---|
openebs-crds | 4.1.0 | |
https://openebs.github.io/dynamic-localpv-provisioner | localpv-provisioner | 4.1.0 |
https://openebs.github.io/lvm-localpv | lvm-localpv | 1.6.0 |
https://openebs.github.io/mayastor-extensions | mayastor | 2.7.0 |
https://openebs.github.io/zfs-localpv | zfs-localpv | 2.6.0 |
Key | Type | Default | Description |
---|---|---|---|
engines.local.lvm.enabled | bool | true |
|
engines.local.zfs.enabled | bool | true |
|
engines.replicated.mayastor.enabled | bool | true |
|
localpv-provisioner.rbac.create | bool | true |
|
lvm-localpv.crds.csi.volumeSnapshots.enabled | bool | false |
|
lvm-localpv.crds.lvmLocalPv.enabled | bool | true |
|
mayastor.crds.csi.volumeSnapshots.enabled | bool | false |
|
mayastor.csi.node.initContainers.enabled | bool | true |
|
mayastor.etcd.clusterDomain | string | "cluster.local" |
Kubernetes Cluster Domain |
mayastor.localpv-provisioner.enabled | bool | false |
|
openebs-crds.csi.volumeSnapshots.enabled | bool | true |
|
openebs-crds.csi.volumeSnapshots.keep | bool | true |
|
preUpgradeHook | object | {"image":{"pullPolicy":"IfNotPresent","registry":"docker.io","repo":"bitnami/kubectl","tag":"1.25.15"}} |
Configuration options for pre-upgrade helm hook job. |
preUpgradeHook.image.pullPolicy | string | "IfNotPresent" |
The imagePullPolicy for the container |
preUpgradeHook.image.registry | string | "docker.io" |
The container image registry URL for the hook job |
preUpgradeHook.image.repo | string | "bitnami/kubectl" |
The container repository for the hook job |
preUpgradeHook.image.tag | string | "1.25.15" |
The container image tag for the hook job |
release.version | string | "4.1.0" |
|
zfs-localpv.crds.csi.volumeSnapshots.enabled | bool | false |
|
zfs-localpv.crds.zfsLocalPv.enabled | bool | true |