Skip to content

Commit

Permalink
Add Helm chart for the RabbitMQ connector
Browse files Browse the repository at this point in the history
Signed-off-by: Han Verstraete (OpenFaaS Ltd) <[email protected]>
  • Loading branch information
welteki committed Dec 2, 2024
1 parent f43e633 commit 88c1937
Show file tree
Hide file tree
Showing 7 changed files with 526 additions and 1 deletion.
6 changes: 5 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,8 @@ verify-charts:
arkade chart verify --verbose=$(VERBOSE) -f ./chart/postgres-connector/values.yaml && \
arkade chart verify --verbose=$(VERBOSE) -f ./chart/queue-worker/values.yaml && \
arkade chart verify --verbose=$(VERBOSE) -f ./chart/sns-connector/values.yaml && \
arkade chart upgrade --verbose=$(VERBOSE) -w -f ./chart/federated-gateway/values.yaml
arkade chart verify --verbose=$(VERBOSE) -f ./chart/rabbitmq-connector/values.yaml && \
arkade chart verify --verbose=$(VERBOSE) -f ./chart/federated-gateway/values.yaml

verify-chart:
@echo Verifying helm chart images in remote registries && \
Expand All @@ -109,6 +110,7 @@ upgrade-charts:
arkade chart upgrade --verbose=$(VERBOSE) -w -f ./chart/postgres-connector/values.yaml && \
arkade chart upgrade --verbose=$(VERBOSE) -w -f ./chart/queue-worker/values.yaml && \
arkade chart upgrade --verbose=$(VERBOSE) -w -f ./chart/sns-connector/values.yaml && \
arkade chart upgrade --verbose=$(VERBOSE) -w -f ./chart/rabbitmq-connector/values.yaml && \
arkade chart upgrade --verbose=$(VERBOSE) -w -f ./chart/federated-gateway/values.yaml

bump-charts:
Expand All @@ -122,6 +124,7 @@ bump-charts:
arkade chart bump --file ./chart/postgres-connector/Chart.yaml -w && \
arkade chart bump --file ./chart/queue-worker/Chart.yaml -w && \
arkade chart bump --file ./chart/sns-connector/Chart.yaml -w && \
arkade chart bump --file ./chart/rabbitmq-connector/Chart.yaml -w && \
arkade chart bump --file ./chart/federated-gateway/Chart.yaml -w

charts-only:
Expand All @@ -136,6 +139,7 @@ charts-only:
helm package postgres-connector/ && \
helm package queue-worker/ && \
helm package sns-connector/ && \
helm package rabbitmq-connector/ && \
helm package federated-gateway/
mv chart/*.tgz docs/
helm repo index docs --url https://openfaas.github.io/faas-netes/ --merge ./docs/index.yaml
Expand Down
22 changes: 22 additions & 0 deletions chart/rabbitmq-connector/.helmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
# 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
*~
# Various IDEs
.project
.idea/
*.tmproj
.vscode/
19 changes: 19 additions & 0 deletions chart/rabbitmq-connector/Chart.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
apiVersion: v1
description: Invoke OpenFaaS functions from RabbitMQ messages.
name: rabbitmq-connector
version: 0.1.0
sources:
- https://github.com/openfaas/faas-netes
home: https://www.openfaas.com
icon: https://raw.githubusercontent.com/openfaas/media/master/OpenFaaS_logo_stacked_opaque.png
keywords:
- openfaas
- faas
- serverless
- rabbitmq
- events
maintainers:
- name: alexellis
email: [email protected]
- name: welteki
email: [email protected]
149 changes: 149 additions & 0 deletions chart/rabbitmq-connector/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,149 @@
# OpenFaaS Pro RabbitMQ Connector

The RabbitMQ connector can be used to invoke OpenFaaS functions from messages on a RabbitMQ queue.

## Prerequisites

- Purchase a license

You will need an OpenFaaS License

Contact us to find out more [openfaas.com/pricing](https://www.openfaas.com/pricing)

- Install OpenFaaS

You must have a working OpenFaaS installed.

## Configure secrets

- Create the required secret with your OpenFaaS Pro license code:

```bash
$ kubectl create secret generic \
-n openfaas \
openfaas-license \
--from-file license=$HOME/.openfaas/LICENSE
```

## Configure values.yaml

```yaml
rabbitmqURL: "amqp://rabbitmq.rabbitmq.svc.cluster.local:5672"

queues:
- name: queue1
durable: true
```
Use the `queues` parameter to configure a list of queues to which the connector should subscribe. When a message is received on a queue, the connector will attempt to invoke any function that has the queue name listed in its `topic` annotation.

Queue configuration:

- `name` - The name of the queue. (Required)
- `durable` - Specifies whether the queue should survive broker restarts.
- `nowait` - Whether to wait for confirmation from the server when declaring the queue.
- `autodelete` - Whether the queue should be deleted automatically when no consumers are connected.
- `exclusive` - Specifies whether the queue should be exclusive to the connection that created it.

By default the connector does not use any form of authentication for the RabbitMQ connection.

Create Kubernetes secrets with username and password to connect to RabbitMQ if required.

```sh
kubectl create secret generic \
rabbitmq-username \
-n openfaas \
--from-file username=./rabbitmq-username.txt
kubectl create secret generic \
rabbitmq-password \
-n openfaas \
--from-file password=./rabbitmq-password.txt
```

To enable username and password authentication add to following parameters with the Kubernetes secret name for the username and password to the `values.yaml`.

```yaml
rabbitmqUsernameSecret: rabbitmq-username
rabbitmqPasswordSecret: rabbitmq-password
```

If your RabbitMQ requires a TLS connection make sure to use `amqps://` as the scheme in the url.

Optionally you can configure a custom CA cert for the connector:

```sh
kubectl create secret generic \
rabbitmq-ca \
-n openfaas \
--from-file ca-cert=./ca-cert.pem
```

`values.yaml`:

```yaml
caSecret: "rabbitmq-ca"
```

## Install the chart

- Add the OpenFaaS chart repo and deploy the `rabbitmq-connector` chart. We recommend installing it in the same namespace as the rest of OpenFaaS

```sh
$ helm repo add openfaas https://openfaas.github.io/faas-netes/
$ helm repo update && \
helm upgrade rabbitmq-connector openfaas/rabbitmq-connector \
--install \
--namespace openfaas \
-f values.yaml
```

> The above command will also update your helm repo to pull in any new releases.

## Configuration

Additional rabbitmq-connector options in `values.yaml`.

| Parameter | Description | Default |
| ------------------------ | ---------------------------------------------------------------------------------------------------------------------------------- | ------------------------------ |
| `topics` | A single topic or list of comma separated topics to consume. | `faas-request` |
| `replicas` | The number of replicas of this connector, should be set to the size of the partition for the given topic, or a higher lower value. | `1` |
| `rabbitmqURL` | URL used for connecting to a RabbitMQ node. | `amqp://rabbitmq:5672` |
| `queues` | List of queues the connector should subscribe to. | `[]` |
| `asyncInvocation` | For long running or slow functions, offload to asychronous function invocations and carry on processing the stream | `false` |
| `upstreamTimeout` | Maximum timeout for upstream function call, must be a Go formatted duration string. | `2m` |
| `rebuildInterval` | Interval for rebuilding function to topic map, must be a Go formatted duration string. | `30s` |
| `gatewayURL` | The URL for the OpenFaaS gateway. | `http://gateway.openfaas:8080` |
| `printResponse` | Output the response of calling a function in the logs. | `true` |
| `printResponseBody` | Output to the logs the response body when calling a function. | `false` |
| `printRequestBody` | Output to the logs the request body when calling a function. | `false` |
| `fullnameOverride` | Override the name value used for the Connector Deployment object. | `""` |
| `rabbitmqPasswordSecret` | Name of the RabbitMQ password secret | `""` |
| `rabbitmqUsernameSecret` | Name of the RabbitMQ username secret | `""` |
| `caSecret` | Name secret for TLS CA - leave empty to disable | `""` |
| `certSecret` | Name secret for TLS client certificate cert - leave empty to disable | `""` |
| `keySecret` | Name secret for TLS client certificate private key - leave empty to disable | `""` |
| `contentType` | Set a HTTP Content Type during function invocation. | `text/plain` |
| `logs.debug` | Print debug logs | `false` |
| `logs.format` | The log encoding format. Supported values: `json` or `console` | `console` |

Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`. See `values.yaml` for the default configuration.

## Install a development version of the chart

When developing on the chart locally, just specify the path to the chart where you've cloned it:

```sh
$ helm upgrade rabbitmq-connector ./chart/rabbitmq-connector \
--install \
--namespace openfaas \
-f values.yaml
```

## Removing the rabbitmq-connector

All control plane components can be cleaned up with helm:

```sh
$ helm uninstall -n openfaas rabbitmq-connector
```
33 changes: 33 additions & 0 deletions chart/rabbitmq-connector/templates/_helpers.tpl
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
{{/* vim: set filetype=mustache: */}}
{{/*
Expand the name of the chart.
*/}}
{{- define "connector.name" -}}
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
{{- end -}}

{{/*
Create a default fully qualified app name.
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec).
If release name contains chart name it will be used as a full name.
*/}}
{{- define "connector.fullname" -}}
{{- if .Values.fullnameOverride -}}
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" -}}
{{- else -}}
{{- $name := default .Chart.Name .Values.nameOverride -}}
{{- if contains $name .Release.Name -}}
{{- .Release.Name | trunc 63 | trimSuffix "-" -}}
{{- else -}}
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" -}}
{{- end -}}
{{- end -}}
{{- end -}}

{{/*
Create chart name and version as used by the chart label.
*/}}
{{- define "connector.chart" -}}
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
{{- end -}}

Loading

0 comments on commit 88c1937

Please sign in to comment.