Skip to content

Commit

Permalink
Merge pull request #12 from aerospike/VEC-90-helm-for-proximus
Browse files Browse the repository at this point in the history
Add aerospike-proximus helm charts
  • Loading branch information
arrowplum authored May 2, 2024
2 parents ab6c1c3 + 7109814 commit 10f6235
Show file tree
Hide file tree
Showing 39 changed files with 2,052 additions and 0 deletions.
26 changes: 26 additions & 0 deletions aerospike-proximus/.helmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
# Patterns to ignore when building packages.
# This supports shell glob matching, relative path matching, and
# negation (prefixed with !). Only one pattern per line.
.DS_Store
# Common VCS dirs
.git/
.gitignore
.bzr/
.bzrignore
.hg/
.hgignore
.svn/
# Common backup files
*.swp
*.bak
*.tmp
*.orig
*~
# Various IDEs
.project
.idea/
*.tmproj
.vscode/
local-env
templates/serviceaccount.yaml
templates/tests/test-connection.yaml
24 changes: 24 additions & 0 deletions aerospike-proximus/Chart.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
apiVersion: v2
name: aerospike-proximus
description: A Helm chart for Kubernetes

# A chart can be either an 'application' or a 'library' chart.
#
# Application charts are a collection of templates that can be packaged into versioned archives
# to be deployed.
#
# Library charts provide useful utilities or functions for the chart developer. They're included as
# a dependency of application charts to inject those utilities and functions into the rendering
# pipeline. Library charts do not define any templates and therefore cannot be deployed.
type: application

# This is the chart version. This version number should be incremented each time you make changes
# to the chart and its templates, including the app version.
# Versions are expected to follow Semantic Versioning (https://semver.org/)
version: 0.1.0

# This is the version number of the application being deployed. This version number should be
# incremented each time you make changes to the application. Versions are not expected to
# follow Semantic Versioning. They should reflect the version the application is using.
# It is recommended to use it with quotes.
appVersion: "0.3.1"
177 changes: 177 additions & 0 deletions aerospike-proximus/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,177 @@
# Aerospike Proximus

This Helm chart allows you to configure and run our official [Aerospike Proximus](https://hub.docker.com/repository/docker/aerospike/aerospike-proximus)
docker image on a Kubernetes cluster.

This helm chart sets up a `StatefulSet` for each proximus instance. We use a `StatefulSet` instead of a `Deployment`, to have stable DNS names for the
deployed proximus pods.

## Prerequisites
- Kubernetes cluster
- Helm v3
- An Aerospike cluster that can connect to Pods in the Kubernetes cluster.
The Aerospike cluster can be deployed in the same Kubernetes cluster using [Aerospike Kubernetes Operator](https://docs.aerospike.com/cloud/kubernetes/operator)
- Ability to deploy a LoadBalancer on K8s in case proximus app runs outside the Kubernetes cluster

## Adding the helm chart repository

Add the `aerospike` helm repository if not already done

```shell
helm repo add aerospike https://aerospike.github.io/helm-charts
```

## Supported configuration

### Configuration

| Parameter | Description | Default |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| `replicaCount` | Configures the number Aerospike Proximus instance pods to run. | '1' |
| `image` | Configures Aerospike Proximus image repository, tag and pull policy. | see [values.yaml](values.yaml) |
| `imagePullSecrets` | For Private docker registries, when authentication is needed. | see [values.yaml](values.yaml) |
| `proximusConfig` | Proximus cluster configuration deployed to `/etc/aerospike-proximus/aerospike-proximus.yml`. | see [values.yaml](values.yaml) |
| `initContainers` | List of initContainers added to each proximus pods for custom cluster behavior. | `[]` |
| `serviceAccount` | Service Account details like name and annotations. | see [values.yaml](values.yaml) |
| `podAnnotations` | Additional pod [annotations](https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/). Should be specified as a map of annotation names to annotation values. | `{}` |
| `podLabels` | Additional pod [labels](https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/). Should be specified as a map of label names to label values. | `{}` |
| `podSecurityContext` | Pod [security context](https://kubernetes.io/docs/tasks/configure-pod-container/security-context/) | `{}` |
| `securityContext` | Container [security context](https://kubernetes.io/docs/tasks/configure-pod-container/security-context/#set-the-security-context-for-a-container) | `{}` |
| `service` | Load-Balancer configuration for more details please refer to a Load-Balancer docs. | `{}` |
| `resources` | Resource [requests and limits](https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/) for the proximus pods. | `{}` |
| `autoscaling` | Enable the horizontal pod auto-scaler. | see [values.yaml](values.yaml) |
| `extraVolumes` | List of additional volumes to attach to the Proximus pod. | see [values.yaml](values.yaml) |
| `extraVolumeMounts` | Extra volume mounts corresponding to the volumes added to `extraVolumes`. | see [values.yaml](values.yaml) |
| `extraSecretVolumeMounts` | Extra secret volume mounts corresponding to the volumes added to `extraVolumes`. | see [values.yaml](values.yaml) |
| `affinity` | [Affinity](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/#affinity-and-anti-affinity) rules if any for the pods. | `{}` |
| `nodeSelector` | [Node selector](https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/#nodeselector) for the pods. | `{}` |
| `tolerations` | [Tolerations](https://kubernetes.io/docs/concepts/scheduling-eviction/taint-and-toleration/) for the pods. | `{}` |

## Deploy the Proximus Cluster

We recommend creating a new `.yaml` for providing configuration values to the helm chart for deployment.
See the [examples](examples) folder for examples.

A sample values yaml file is shown below:

```yaml
replicaCount: 1

image:
tag: "0.3.1"

proximusConfig:
aerospike:
metadata-namespace: "proximus-meta"
seeds:
- aerospike-cluster-0-0.aerospike-cluster.aerospike.svc.cluster.local:
port: 3000
```
Here `replicaCount` is the count of Proximus pods that are deployed.
The proximus configuration is provided as yaml under the key `proximusConfig`.
[comment]: <> (Link to proximus docs should be added)
See [Aerospike Proximus configuration]() for details.

We recommend naming the file with the name of the Proximus cluster. For example if you want to name your Proximus cluster as
`as-proximus`, create a file `as-proximus-values.yaml`.
Once you have created this custom values file, deploy the Proximus cluster, using the following command.

### Create a new namespace
We recommend using `aerospike` namespace for the Proximus cluster. If the namespace does not exist run the following command:
```shell
kubectl create namespace aerospike
```

### Create secrets
Create the secret for aerospike using your Aerospike licence file
```shell
# kubectl --namespace <target namespace> create secret generic aerospike-proximus-secret --from-file=features.conf=<path to features conf file>
kubectl --namespace aerospike create secret generic aerospike-secret --from-file=features.conf=features.conf
```

### Deploy the Proximus cluster

```shell
# helm install --namespace <target namespace> <helm release name/cluster name> -f <path to custom values yaml> aerospike/aerospike-proximus
helm install --namespace aerospike as-proximus -f as-proximus-values.yaml aerospike/as-proximus
```

Here `as-proximus` is the release name for the proximus cluster and also its cluster name.

On successful deployment you should see output similar to below:

```shell
NAME: as-proximus
LAST DEPLOYED: Sun Mar 31 13:47:28 2024
NAMESPACE: aerospike
STATUS: deployed
REVISION: 1
TEST SUITE: None
NOTES:
```

## List pods for the Proximus cluster
To list the pods for the Proximus cluster run the following command:
```shell
# kubectl get pods --namespace aerospike --selector=app=<helm release name>-aerospike-proximus
kubectl get pods --namespace aerospike --selector=app=as-proximus-aerospike-proximus
```

You should see output similar to the following:
```shell
NAME READY STATUS RESTARTS AGE
as-proximus-aerospike-proximus-0 1/1 Running 0 2m32s
```

If you are using [Aerospike Kubernetes Operator](https://docs.aerospike.com/connect/pulsar/from-asdb/configuring),
see [quote-search](examples/quote-search) for reference.

## Get logs for all Proximus instances

```shell
# kubectl -n aerospike logs -f statefulset/<helm release name>-aerospike-proximus
# Skip the -f flag to get a one time dump of the log
kubectl -n aerospike logs -f statefulset/as-proximus-aerospike-proximus
```

## Get logs for one Proximus pod

```shell
# kubectl -n aerospike logs -f <helm release name>-aerospike-proximus-0
# Skip the -f flag to get a one time dump of the log
kubectl -n aerospike logs -f as-proximus-aerospike-proximus-0
```

## Updating Proximus configuration

Edit the `proximusConfig` section in the custom values file and save the changes.

Upgrade the Proximus deployment using the following command.

```shell
#helm upgrade --namespace <target namespace> <helm release name> -f <path to custom values yaml file> aerospike/aerospike-proximus
helm upgrade --namespace aerospike as-proximus -f as-proximus-values.yaml aerospike/aerospike-proximus
```

On successful execution of the command the Proximus pods will undergo a rolling restart and come up with the new configuration.

To verify the changes are applied
- [List the pods](#list-pods-for-the-proximus-cluster)
- [Verify the configuration in proximus logs](#get-logs-for-all-proximus-instances)

**_NOTE:_** The changes might take some time to apply. If you do not see the desired Proximus config try again after some time.

## Scaling up/down the Proximus instances

Edit the `replicaCount` to the desired Proximus instance count and upgrade the Proximus deployment using the following command.

```shell
#helm upgrade --namespace <target namespace> <helm release name> -f <path to custom values yaml file> aerospike/aerospike-proximus
helm upgrade --namespace aerospike as-proximus -f as-proximus-values.yaml aerospike/aerospike-proximus
```

Verify that the Proximus cluster have been scaled.
- [List the pods](#list-pods-for-the-proximus-cluster) and verify the count of Proximus instances is as desired

**_NOTE:_** The changes might take some time to apply. If you do not see the desired count try again after some time.
16 changes: 16 additions & 0 deletions aerospike-proximus/eks/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
# EKS Installation

### Create Local Env
```shell
./install-eks-env.sh
```

### Run `qoute-serch` Example App
```shell
./run-quote-search.sh
```

### Destroy Local Env
```shell
./uninstall-eks-env.sh
```
87 changes: 87 additions & 0 deletions aerospike-proximus/eks/install-eks-env.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
#!/bin/bash -e
WORKSPACE="$(git rev-parse --show-toplevel)"
REGION=""

if [ -z "$REGION" ]; then
echo "Set Region"
exit 1
fi

if [ ! -f "$WORKSPACE/aerospike-proximus/eks/config/features.conf" ]; then
echo "features.conf Not found"
exit 1
fi

eksctl create cluster \
--region="$REGION" \
--name=proximus-eks-cluster \
--nodes=3 \
--node-type=t3.xlarge \
--with-oidc \
--set-kubeconfig-context

eksctl create iamserviceaccount \
--region="$REGION" \
--name ebs-csi-controller-sa \
--namespace kube-system \
--cluster proximus-eks-cluster \
--role-name AmazonEKS_EBS_CSI_DriverRole \
--role-only \
--attach-policy-arn arn:aws:iam::aws:policy/service-role/AmazonEBSCSIDriverPolicy \
--approve

eksctl create addon \
--region="$REGION" \
--name aws-ebs-csi-driver \
--cluster proximus-eks-cluster \
--service-account-role-arn arn:aws:iam::"$(aws sts get-caller-identity \
--query "Account" \
--output text)":role/AmazonEKS_EBS_CSI_DriverRole \
--force

sleep 30
echo "Deploying AKO"
curl -sL https://github.com/operator-framework/operator-lifecycle-manager/releases/download/v0.25.0/install.sh \
| bash -s v0.25.0
kubectl create -f https://operatorhub.io/install/aerospike-kubernetes-operator.yaml
echo "Waiting for AKO"
while true; do
if kubectl --namespace operators get deployment/aerospike-operator-controller-manager &> /dev/null; then
kubectl --namespace operators wait \
--for=condition=available --timeout=180s deployment/aerospike-operator-controller-manager
break
fi
done

echo "Grant permissions to the target namespace"
kubectl create namespace aerospike
kubectl --namespace aerospike create serviceaccount aerospike-operator-controller-manager
kubectl create clusterrolebinding aerospike-cluster \
--clusterrole=aerospike-cluster --serviceaccount=aerospike:aerospike-operator-controller-manager

echo "Set Secrets for Aerospike Cluster"
kubectl --namespace aerospike create secret generic aerospike-secret \
--from-file=features.conf="$WORKSPACE/aerospike-proximus/eks/config/features.conf"
kubectl --namespace aerospike create secret generic auth-secret --from-literal=password='admin123'

echo "Add Storage Class"
kubectl apply -f https://raw.githubusercontent.com/aerospike/aerospike-kubernetes-operator/master/config/samples/storage/eks_ssd_storage_class.yaml

sleep 5
echo "Deploy Aerospike Cluster"
kubectl apply -f "$WORKSPACE/aerospike-proximus/examples/eks/aerospike.yaml"

sleep 5
echo "Waiting for Aerospike Cluster"
while true; do
if kubectl --namespace aerospike get pods --selector=statefulset.kubernetes.io/pod-name &> /dev/null; then
kubectl --namespace aerospike wait pods \
--selector=statefulset.kubernetes.io/pod-name --for=condition=ready --timeout=180s
break
fi
done

sleep 30
echo "Deploy Proximus"
helm install as-proximus-eks "$WORKSPACE/aerospike-proximus" \
--values "$WORKSPACE/aerospike-proximus/examples/eks/as-proximus-eks-values.yaml" --namespace aerospike --wait
Loading

0 comments on commit 10f6235

Please sign in to comment.