Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Operator yaml to helm chart #292

Merged
merged 9 commits into from
Apr 11, 2024
6 changes: 3 additions & 3 deletions .github/ISSUE_TEMPLATE/bug-report.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,9 @@ labels: Bug
**The output of the following commands will help us better understand what's going on**:
(Pasting long output into a [GitHub gist](https://gist.github.com) or other [Pastebin](https://pastebin.com/) is fine.)

* `kubectl logs -f openebs-lvm-controller-0 -n kube-system -c openebs-lvm-plugin`
* `kubectl logs -f openebs-lvm-node-[xxxx] -n kube-system -c openebs-lvm-plugin`
* `kubectl get pods -n kube-system`
* `kubectl logs -f openebs-lvm-localpv-controller-7b6d6b4665-fk78q -n openebs -c openebs-lvm-plugin`
* `kubectl logs -f openebs-lvm-node-[xxxx] -n openebs -c openebs-lvm-plugin`
* `kubectl get pods -n openebs`
* `kubectl get lvmvol -A -o yaml`

**Anything else you would like to add:**
Expand Down
5 changes: 5 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,11 @@ jobs:
cni: calico
start-args: '--install-addons=false'

- name: Set up Helm
uses: azure/setup-helm@v4
with:
version: v3.14.3

- name: Build images locally
run: make lvm-driver-image || exit 1;

Expand Down
5 changes: 5 additions & 0 deletions .github/workflows/pull_request.yml
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,11 @@ jobs:
kubernetes-version: ${{ matrix.kubernetes }}
cni: calico
start-args: '--install-addons=false'

- name: Set up Helm
uses: azure/setup-helm@v4
with:
version: v3.14.3

- name: Build images locally
run: make lvm-driver-image || exit 1;
Expand Down
4 changes: 2 additions & 2 deletions Adopters.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# OpenEBS LVM-LocalPV Adopters
# OpenEBS LocalPV-LVM Adopters

Abhinandan-Purkait marked this conversation as resolved.
Show resolved Hide resolved
This is the list of organizations and users that publicly shared details of how they are using OpenEBS LVM-LocalPV CSI driver for running their Stateful workloads.
This is the list of organizations and users that publicly shared details of how they are using OpenEBS LocalPV-LVM CSI driver for running their Stateful workloads.

[click here](https://github.com/openebs/openebs/issues/2719) to see the list of organizations/users who have publicly shared the usage of OpenEBS.
4 changes: 2 additions & 2 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Contributing to LVM-LocalPV
# Contributing to LocalPV-LVM

LVM LocalPV uses the standard GitHub pull requests process to review and accept contributions. There are several areas that could use your help. For starters, you could help in improving the sections in this document by either creating a new issue describing the improvement or submitting a pull request to this repository. The issues are maintained at [lvm-localpv/issues](https://github.com/openebs/lvm-localpv/issues) repository.

Expand All @@ -9,7 +9,7 @@ LVM LocalPV uses the standard GitHub pull requests process to review and accept

## Steps to Contribute

LVM-LocalPV is an Apache 2.0 Licensed project and all your commits should be signed with Developer Certificate of Origin. See [Sign your work](#sign-your-work).
LocalPV-LVM is an Apache 2.0 Licensed project and all your commits should be signed with Developer Certificate of Origin. See [Sign your work](#sign-your-work).

* Find an issue to work on or create a new issue. The issues are maintained at [lvm-localpv/issues](https://github.com/openebs/lvm-localpv/issues). You can pick up from a list of [good-first-issues](https://github.com/openebs/lvm-localpv/labels/good%20first%20issue).
* Claim your issue by commenting your intent to work on it to avoid duplication of efforts.
Expand Down
84 changes: 36 additions & 48 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
## OpenEBS - LVM-LocalPV CSI Driver
## OpenEBS - LocalPV-LVM CSI Driver
[![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2Fopenebs%2Flvm-localpv.svg?type=shield)](https://app.fossa.io/projects/git%2Bgithub.com%2Fopenebs%2Flvm-localpv?ref=badge_shield)
[![CII Best Practices](https://bestpractices.coreinfrastructure.org/projects/3523/badge)](https://bestpractices.coreinfrastructure.org/en/projects/4548)
[![Slack](https://img.shields.io/badge/chat!!!-slack-ff1493.svg?style=flat-square)](https://kubernetes.slack.com/messages/openebs)
Expand All @@ -7,26 +7,26 @@
[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fopenebs%2Flvm-localpv.svg?type=shield)](https://app.fossa.com/projects/git%2Bgithub.com%2Fopenebs%2Flvm-localpv?ref=badge_shield)


| [![Linux LVM2](https://github.com/openebs/website/blob/main/website/public/images/png/LVM_logo_1.png "Linux LVM2")](https://github.com/openebs/website/blob/main/website/public/images/png/LVM_logo_1.png) | The OpenEBS LVM-LocalPV Data-Engine is a mature and well deployed production grade CSI driver for dynamically provisioning Node Local Volumes into a K8s cluster utilizing the LINUX LVM2 Data / storage Mgmt stack as the storage backend. It integrates LVM2 into the OpenEBS platform and exposes many LVM2 services and capabilities. |
| [![Linux LVM2](https://github.com/openebs/website/blob/main/website/public/images/png/LVM_logo_1.png "Linux LVM2")](https://github.com/openebs/website/blob/main/website/public/images/png/LVM_logo_1.png) | The OpenEBS LocalPV-LVM Data-Engine is a mature and well deployed production grade CSI driver for dynamically provisioning Node Local Volumes into a K8s cluster utilizing the LINUX LVM2 Data / storage Mgmt stack as the storage backend. It integrates LVM2 into the OpenEBS platform and exposes many LVM2 services and capabilities. |
| :--- | :--- |
<BR>

## Overview
LVM-LocalPV CSI Driver becasme GA in August 2021 (with the release v0.8.0). It is now a a very mature product and a core component of the OpenEBS storage platform.
Due to the major adoption of LVM-LocalPV (+50,000 users), this Data-Engine is now being unified and integrated into the core OpenEBS Storage platform; instead of being maintained as an external Data-Engine within our project.
LocalPV-LVM CSI Driver becasme GA in August 2021 (with the release v0.8.0). It is now a a very mature product and a core component of the OpenEBS storage platform.
Due to the major adoption of LocalPV-LVM (+50,000 users), this Data-Engine is now being unified and integrated into the core OpenEBS Storage platform; instead of being maintained as an external Data-Engine within our project.

Our [2024 Roadmap is here](https://github.com/openebs/openebs/blob/main/ROADMAP.md). It defines a rich set of new featrues, which covers the integration of LVM-LocalPV into the core OpenEBS platform.<br>
Please review this roadmp and feel free to pass back any feedback on it, as well as recommend and suggest new ideas regarding LVM-LocalPV. We welcome all your feedback.
Our [2024 Roadmap is here](https://github.com/openebs/openebs/blob/main/ROADMAP.md). It defines a rich set of new featrues, which covers the integration of LocalPV-LVM into the core OpenEBS platform.<br>
Please review this roadmp and feel free to pass back any feedback on it, as well as recommend and suggest new ideas regarding LocalPV-LVM. We welcome all your feedback.
<br>
<BR>

> **LVM-LocalPV is very popular** : Live OpenEBS systems actively report back product metrics every day, to our Global Anaytics metrics engine (unless disabled by the user).
> **LocalPV-LVM is very popular** : Live OpenEBS systems actively report back product metrics every day, to our Global Anaytics metrics engine (unless disabled by the user).
> Here are our key project popularity metrics as of: 01 Mar 2024 <BR>
>
> :rocket: &nbsp; OpenEBS is the #1 deployed Storage Platform for Kubernetes <BR>
> :zap: &nbsp; LVM-LocalPV is the 3rd most deployed Data-Engine within the platform <BR>
> :sunglasses: &nbsp; LVM-LocalPV has +50,000 Daily Acive Users <BR>
> :sunglasses: &nbsp; LVM-LocalPV has +120,000 Global instllations <BR>
> :zap: &nbsp; LocalPV-LVM is the 3rd most deployed Data-Engine within the platform <BR>
> :sunglasses: &nbsp; LocalPV-LVM has +50,000 Daily Acive Users <BR>
> :sunglasses: &nbsp; LocalPV-LVM has +120,000 Global instllations <BR>
> :floppy_disk: &nbsp; +49 Million OpenEBS Volumes have been deployed globally <BR>
> :tv: &nbsp; We have +8 Million Global OpenEBS installations <BR>
> :star: &nbsp; We are the [#1 GitHub Star ranked](https://github.com/openebs/website/blob/main/website/public/images/png/github_star-history-2024_Feb_1.png) K8s Data Storage platform <BR>
Expand All @@ -38,7 +38,7 @@ Please review this roadmp and feel free to pass back any feedback on it, as well


## Project info
The orignal v1.0 dev roadmap [is here ](https://github.com/orgs/openebs/projects/30). This tracks our base historical engineering development work and is now somewhat out of date. We will be publish an updated 2024 Unified Roadmp soon, as ZFS-LoalPV is now being integrated and unified into the core OpenEBS storage platform.<BR>
The orignal v1.0 dev roadmap [is here ](https://github.com/orgs/openebs/projects/30). This tracks our base historical engineering development work and is now somewhat out of date. We will be publish an updated 2024 Unified Roadmp soon, as LocalPV-LVM is now being integrated and unified into the core OpenEBS storage platform.<BR>

<BR>

Expand All @@ -48,10 +48,10 @@ The orignal v1.0 dev roadmap [is here ](https://github.com/orgs/openebs/projects


> [!IMPORTANT]
> Before installing the LVM-LocalPV driver please make sure your Kubernetes Cluster meets the following prerequisites:
> Before installing the LocalPV-LVM driver please make sure your Kubernetes Cluster meets the following prerequisites:
> 1. All the nodes must have LVM2 utils package installed
> 2. All the nodes must have dm-snapshot Kernel Module loaded - (Device Mapper Snapshot)
> 4. You have access to install RBAC components into kube-system namespace. The OpenEBS LVM driver components are installed in kube-system namespace to allow them to be flagged as system critical components.
> 4. You have access to install RBAC components into <OPENEBS> namespace.
<BR>

> [!NOTE]
Expand All @@ -64,7 +64,7 @@ The orignal v1.0 dev roadmap [is here ](https://github.com/orgs/openebs/projects

> | Name | Version |
> | :--- | :--- |
> | K8S | 1.20+ |
> | K8S | 1.23+ |
> | Distro | Alpine, Arch, CentOS, Debian, Fedora, NixOS, SUSE, Talos, RHEL, Ubuntu |
> | Kernel | oldest supported kernel is 2.6 |
> | LVM2 | 2.03.21 |
Expand All @@ -75,7 +75,7 @@ The orignal v1.0 dev roadmap [is here ](https://github.com/orgs/openebs/projects

## Setup

Find the disk which you want to use for the LVM-LocalPV. Note: For testing you can use the loopback device.
Find the disk which you want to use for the LocalPV-LVM. Note: For testing you can use the loopback device.

```
truncate -s 1024G /tmp/disk.img
Expand All @@ -84,8 +84,8 @@ sudo losetup -f /tmp/disk.img --show

> [!NOTE]
> - This is the old maual config process <BR>
> - LVM-LocalPV will num dynamically provision the VG fro you <BR>
> - The PV, VG and LV names will be dynamically provisioned by OpenEBS LVM-LocalPV as K8s unique entities (for safety, you cannot provide your own PV, VG or LV names)
> - LocalPV-LVM will num dynamically provision the VG fro you <BR>
> - The PV, VG and LV names will be dynamically provisioned by OpenEBS LocalPV-LVM as K8s unique entities (for safety, you cannot provide your own PV, VG or LV names)

Create the Volume group on all the nodes, which will be used by the LVM2 Driver for provisioning the volumes

Expand All @@ -98,45 +98,33 @@ sudo vgcreate lvmvg /dev/loop0 ## here lvmvg is the volume group name to b

## Installation

Install the latest release of OpenEBS LVM2 LVM-LocalPV driver by running the following command. Note: All nodes must be running the same verison of LVM-LocalPV, LMV2, device-mapper & dm-snapshot.
Install the latest release of OpenEBS LVM2 LocalPV-LVM driver by running the following command. Note: All nodes must be running the same verison of LocalPV-LVM, LMV2, device-mapper & dm-snapshot.

**NOTE:** Installation using operator YAMLs is not the supported way any longer.
We can install the latest release of OpenEBS LVM driver by running the following command:
```bash
helm repo add openebs https://openebs.github.io/openebs
helm repo update
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

helm install openebs --namespace openebs openebs/openebs --create-namespace
```
$ kubectl apply -f https://openebs.github.io/charts/lvm-operator.yaml
```

If you want to fetch a versioned manifest, you can use the manifests for a
specific OpenEBS release version, for example:

```
$ kubectl apply -f https://raw.githubusercontent.com/openebs/charts/gh-pages/versioned/3.0.0/lvm-operator.yaml
```

**NOTE:** For some Kubernetes distributions, the `kubelet` directory must be changed at all relevant places in the YAML powering the operator (both the `openebs-lvm-controller` and `openebs-lvm-node`).

- For `microk8s`, we need to change the kubelet directory to `/var/snap/microk8s/common/var/lib/kubelet/`, we need to replace `/var/lib/kubelet/` with `/var/snap/microk8s/common/var/lib/kubelet/` at all the places in the operator yaml and then we can apply it on microk8s.
**NOTE:** If you are running a custom Kubelet location, or a Kubernetes distribution that uses a custom Kubelet location, the `kubelet` directory must be changed on the helm values at install-time using the flag option `--set lvm-localpv.lvmNode.kubeletDir=<your-directory-path>` in the `helm install` command.

- For `microk8s`, we need to change the kubelet directory to `/var/snap/microk8s/common/var/lib/kubelet/`, we need to replace `/var/lib/kubelet/` with `/var/snap/microk8s/common/var/lib/kubelet/`.
- For `k0s`, the default directory (`/var/lib/kubelet`) should be changed to `/var/lib/k0s/kubelet`.

- For `RancherOS`, the default directory (`/var/lib/kubelet`) should be changed to `/opt/rke/var/lib/kubelet`.

Verify that the LVM driver Components are installed and running using below command :

```
$ kubectl get pods -n kube-system -l role=openebs-lvm
```

Depending on number of nodes, you will see one lvm-controller pod and lvm-node daemonset running
on the nodes.

Verify that the LVM driver Components are installed and running using below command. Depending on number of nodes, you will see one lvm-controller pod and lvm-node daemonset running on the nodes :
```bash
$ kubectl get pods -n openebs -l role=openebs-lvm
NAME READY STATUS RESTARTS AGE
openebs-lvm-localpv-controller-7b6d6b4665-fk78q 5/5 Running 0 11m
openebs-lvm-localpv-node-mcch4 2/2 Running 0 11m
openebs-lvm-localpv-node-pdt88 2/2 Running 0 11m
openebs-lvm-localpv-node-r9jn2 2/2 Running 0 11m
```
NAME READY STATUS RESTARTS AGE
openebs-lvm-controller-0 5/5 Running 0 35s
openebs-lvm-node-54slv 2/2 Running 0 35s
openebs-lvm-node-9vg28 2/2 Running 0 35s
openebs-lvm-node-qbv57 2/2 Running 0 35s

```
Once LVM driver is successfully installed, we can provision volumes.
Once LVM driver is installed and running we can provision a volume.

### Deployment

Expand All @@ -156,7 +144,7 @@ parameters:
provisioner: local.csi.openebs.io
```

Check the doc on [storageclasses](docs/storageclasses.md) to know all the supported parameters for LVM-LocalPV
Check the doc on [storageclasses](docs/storageclasses.md) to know all the supported parameters for LocalPV-LVM

##### VolumeGroup Availability

Expand Down
32 changes: 16 additions & 16 deletions ci/ci-test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,12 @@

set -e

LVM_OPERATOR="$(realpath deploy/lvm-operator.yaml)"
LVM_CHART=deploy/helm/charts
SNAP_CLASS="$(realpath deploy/sample/lvmsnapclass.yaml)"

export OPENEBS_NAMESPACE="openebs"
export LVM_NAMESPACE="openebs"

export TEST_DIR="tests"
export NAMESPACE="kube-system"

# allow override
if [ -z "${KUBECONFIG}" ]
Expand Down Expand Up @@ -70,7 +70,7 @@ cleanup() {

kubectl delete pvc -n openebs lvmpv-pvc
kubectl delete -f "${SNAP_CLASS}"
kubectl delete -f "${LVM_OPERATOR}"
helm uninstall openebs-lvmlocalpv -n "$OPENEBS_NAMESPACE"

# always return true
return 0
Expand Down Expand Up @@ -99,29 +99,29 @@ sudo modprobe dm_thin_pool

# Prepare env for running BDD tests
# Minikube is already running
kubectl apply -f "${LVM_OPERATOR}"
helm install openebs-lvmlocalpv "$LVM_CHART" -n "$OPENEBS_NAMESPACE" --create-namespace --dependency-update --set analytics.enabled=false
kubectl apply -f "${SNAP_CLASS}"

dumpAgentLogs() {
NR=$1
AgentPOD=$(kubectl get pods -l app=openebs-lvm-node -o jsonpath='{.items[0].metadata.name}' -n "$NAMESPACE")
kubectl describe po "$AgentPOD" -n "$NAMESPACE"
AgentPOD=$(kubectl get pods -l app=openebs-lvm-node -o jsonpath='{.items[0].metadata.name}' -n "$OPENEBS_NAMESPACE")
kubectl describe po "$AgentPOD" -n "$OPENEBS_NAMESPACE"
printf "\n\n"
kubectl logs --tail="${NR}" "$AgentPOD" -n "$NAMESPACE" -c openebs-lvm-plugin
kubectl logs --tail="${NR}" "$AgentPOD" -n "$OPENEBS_NAMESPACE" -c openebs-lvm-plugin
printf "\n\n"
}

dumpControllerLogs() {
NR=$1
ControllerPOD=$(kubectl get pods -l app=openebs-lvm-controller -o jsonpath='{.items[0].metadata.name}' -n "$NAMESPACE")
kubectl describe po "$ControllerPOD" -n "$NAMESPACE"
ControllerPOD=$(kubectl get pods -l app=openebs-lvm-controller -o jsonpath='{.items[0].metadata.name}' -n "$OPENEBS_NAMESPACE")
kubectl describe po "$ControllerPOD" -n "$OPENEBS_NAMESPACE"
printf "\n\n"
kubectl logs --tail="${NR}" "$ControllerPOD" -n "$NAMESPACE" -c openebs-lvm-plugin
kubectl logs --tail="${NR}" "$ControllerPOD" -n "$OPENEBS_NAMESPACE" -c openebs-lvm-plugin
printf "\n\n"
}

isPodReady(){
[ "$(kubectl get po "$1" -o 'jsonpath={.status.conditions[?(@.type=="Ready")].status}' -n "$NAMESPACE")" = 'True' ]
[ "$(kubectl get po "$1" -o 'jsonpath={.status.conditions[?(@.type=="Ready")].status}' -n "$OPENEBS_NAMESPACE")" = 'True' ]
}

isDriverReady(){
Expand All @@ -136,7 +136,7 @@ waitForLVMDriver() {

i=0
while [ "$i" -le "$period" ]; do
lvmDriver="$(kubectl get pods -l role=openebs-lvm -o 'jsonpath={.items[*].metadata.name}' -n "$NAMESPACE")"
lvmDriver="$(kubectl get pods -l role=openebs-lvm -o 'jsonpath={.items[*].metadata.name}' -n "$OPENEBS_NAMESPACE")"
if isDriverReady "$lvmDriver"; then
return 0
fi
Expand All @@ -155,7 +155,7 @@ waitForLVMDriver

cd $TEST_DIR

kubectl get po -n "$NAMESPACE"
kubectl get po -n "$OPENEBS_NAMESPACE"

set +e

Expand Down Expand Up @@ -186,10 +186,10 @@ echo "get sc details"
kubectl get sc --all-namespaces -oyaml

echo "get lvm volume details"
kubectl get lvmvolumes.local.openebs.io -n openebs -oyaml
kubectl get lvmvolumes.local.openebs.io -n "$OPENEBS_NAMESPACE" -oyaml

echo "get lvm snapshot details"
kubectl get lvmsnapshots.local.openebs.io -n openebs -oyaml
kubectl get lvmsnapshots.local.openebs.io -n "$OPENEBS_NAMESPACE" -oyaml

exit 1
fi
Expand Down
2 changes: 1 addition & 1 deletion design/lvm/persistent-volume-claim/access_mode.md
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ spec:

### Test Plan

- Provision an application with LVM-LocalPV supported access mode and verify accessibility of volume from application.
- Provision an application with LocalPV-LVM supported access mode and verify accessibility of volume from application.
- Provision an application with unsupported access modes and verify that volume should not get provisioned.
- Provision multiple applications on the same volume and verify that only one application instance should be in running state.

Expand Down
10 changes: 5 additions & 5 deletions design/lvm/resize_workflow.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
title: LVM-LocalPV Volume Expansion
title: LocalPV-LVM Volume Expansion
authors:
- "@pawanpraka1"
owners:
Expand All @@ -9,11 +9,11 @@ last-updated: 2021-05-28
status: Implemented
---

# LVM-LocalPV Volume Expansion
# LocalPV-LVM Volume Expansion

## Table of Contents

- [LVM-LocalPV Volume Expansion](#lvm-localpv-volume-expansion)
- [LocalPV-LVM Volume Expansion](#lvm-localpv-volume-expansion)
- [Table of Contents](#table-of-contents)
- [Summary](#summary)
- [Motivation](#motivation)
Expand All @@ -33,13 +33,13 @@ status: Implemented

## Summary

This proposal charts out the design details to implement expansion workflow on LVM-LocalPV Volumes.
This proposal charts out the design details to implement expansion workflow on LocalPV-LVM Volumes.

## Motivation

### Goals

- As a user, I should be able to resize the volumes provisioned via LVM-LocalPV by updating the size
- As a user, I should be able to resize the volumes provisioned via LocalPV-LVM by updating the size
on PersistentVolumeClaim(PVC).

### Non-Goals
Expand Down
Loading
Loading