title | menu_order |
---|---|
Requirements for Helm Integration with Flux (alpha stage) |
20 |
- Kubernetes >=v1.9 is recommended. Kubernetes v1.8 (the first to support Custom Resources) appears to have problems with repeated application of custom resources (see kubernetes/kubernetes#53379). This means fluxd can fail to apply changes to FluxHelmRelease resources.
- tiller should be running in the cluster, though helm-operator will wait until it can find one.
- One repo containing both desired release state information and Charts themselves
- Release state information in the form of Custom Resources manifests is located under a particular path ("releaseconfig" by default; can be overriden)
- Charts are colocated under another path ("charts" by default; can be overriden). Charts are subdirectories under the charts path.
- Custom Resource namespace reflects where the release should be done. Both the Helm application and its corresponding Custom Resource will live in this namespace.
- example of a test repo: https://github.com/tamarakaufler/flux-helm-test
---
apiVersion: helm.integrations.flux.weave.works/v1alpha2
kind: FluxHelmRelease
metadata:
name: mongodb
namespace: myNamespace
labels:
chart: mongodb
spec:
chartGitPath: mongodb
releaseName: mongo-database
values:
image: bitnami/mongodb:3.7.1-r1
- name
- namespace
- label.chart ... the same as chartgitpath, with slash replaced with an underscore
- chartGitPath ... path (from repo root) to a Chart subdirectory
-
releaseName:
-
if a release already exists and Flux should start managing it, then releasename must be provided
-
if releasename is not provided, Flux will construct a release name based on the namespace and the Custom Resource name (ie $namespace-$CR_name)
- values:
foo: value1
bar:
baz: value2
oof:
- item1
- item2
a dictionary of key value pairs (which can be nested) for overriding Chart parameters. Examples of parameter names:
- image
- resources -> requests -> memory (nested)