Skip to content

Commit

Permalink
feat(influxdb): Use stable/influxdb chart
Browse files Browse the repository at this point in the history
closes #180
* This moves to using the influxdb chart in the stable repository
* Sets the version to 0.4.0
* Adds two pre-upgrade hooks to the base monitor chart. These hooks
allow the chart to migrate data from the old volume mount location to
the new one provided by the influxdb chart.
* If `influxdb_location` is set to `off-cluster` it will delete the deployment resource using a post-install or post-upgrade hook.
  • Loading branch information
Jonathan Chauncey committed Apr 11, 2017
1 parent 977d0f3 commit c8eb29a
Show file tree
Hide file tree
Showing 18 changed files with 252 additions and 168 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,3 +8,4 @@ influxdb/manifests/*.tmp.yaml
chronograf/manifests/*.tmp.yaml
grafana/manifests/*.tmp.yaml
rootfs/usr/bin/telegraf
charts/monitor/charts/*.tgz
Original file line number Diff line number Diff line change
Expand Up @@ -59,8 +59,10 @@ spec:
name: influxdb-creds
key: password
{{- else }}
- name: "INFLUXDB_URLS"
value: http://$(DEIS_MONITOR_INFLUXAPI_SERVICE_HOST):$(DEIS_MONITOR_INFLUXAPI_SERVICE_PORT_TRANSPORT)
# - name: "INFLUXDB_URLS"
# value: http://{{.Release.Name}}.influxdb.{{.Release.Namespace}}.svc.cluster.local:8086
- name: DEIS_MONITOR_INFLUXAPI_SERVICE_HOST
value: {{.Release.Name}}-influxdb.{{.Release.Namespace}}.svc.cluster.local
{{- end }}
- name: "BIND_PORT"
value: "3500"
Expand Down
7 changes: 0 additions & 7 deletions charts/monitor/charts/influxdb/Chart.yaml

This file was deleted.

This file was deleted.

This file was deleted.

This file was deleted.

20 changes: 0 additions & 20 deletions charts/monitor/charts/influxdb/templates/monitor-influxdb-pvc.yaml

This file was deleted.

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -55,9 +55,9 @@ spec:
key: password
{{- else }}
- name: "INFLUXDB_URLS"
value: "\"http://$(DEIS_MONITOR_INFLUXAPI_SERVICE_HOST):$(DEIS_MONITOR_INFLUXAPI_SERVICE_PORT_TRANSPORT)\""
value: "\"http://{{.Release.Name}}-influxdb.{{.Release.Namespace}}.svc.cluster.local:8086\""
- name: "INFLUXDB_INPUT_URLS"
value: "\"http://$(DEIS_MONITOR_INFLUXAPI_SERVICE_HOST):$(DEIS_MONITOR_INFLUXAPI_SERVICE_PORT_TRANSPORT)/debug/vars\""
value: "\"http://{{.Release.Name}}-influxdb.{{.Release.Namespace}}.svc.cluster.local:8086/debug/vars\""
- name: "ENABLE_INFLUXDB_INPUT"
value: "true"
{{- end }}
Expand Down
40 changes: 40 additions & 0 deletions charts/monitor/migrate.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
apiVersion: batch/v1
kind: Job
metadata:
name: deis-monitor-migrate-data
annotations:
"helm.sh/hook": "pre-upgrade"
"helm.sh/hook-weight": "0"
spec:
template:
spec:
restartPolicy: Never
containers:
- name: deis-monitor-migrate-data
image: "lachlanevenson/k8s-kubectl"
command: ["/bin/sh", "-c"]
args: ["(if [ -d /var/lib/influxdb/data/_internal ]; then \
echo 'Nothing to migrate!'; \
else \
echo Creating directories; \
mkdir /var/lib/influxdb/data; \
(if [ -d /var/lib/influxdb/db/wal ]; then \
echo 'Moving data from /db/wal'; \
mv /var/lib/influxdb/db/wal /var/lib/influxdb; \
else \
echo 'Directory /var/lib/influxdb/db/wal does not exist!'; \
fi); \
(if [ -d /var/lib/influxdb/db/_internal ]; then \
echo 'Moving data from /db/*'; \
mv /var/lib/influxdb/db/* /var/lib/influxdb/data; \
else \
echo 'Directory /var/lib/influxdb/db does not exist!'; \
fi);
fi)"]
volumeMounts:
- name: data
mountPath: /var/lib/influxdb
volumes:
- name: data
persistentVolumeClaim:
claimName: deis-monitor-influxdb
10 changes: 10 additions & 0 deletions charts/monitor/requirements.lock
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
dependencies:
- condition: ""
enabled: false
import-values: null
name: influxdb
repository: https://kubernetes-charts.storage.googleapis.com
tags: null
version: 0.4.0
digest: sha256:c645931b63ed441ffd84ffca9d539c00651a2abaa97c4d0fdbc231cd9096f5e8
generated: 2017-04-11T16:47:15.396173511-04:00
4 changes: 4 additions & 0 deletions charts/monitor/requirements.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
dependencies:
- name: influxdb
version: "0.4.0"
repository: https://kubernetes-charts.storage.googleapis.com
36 changes: 36 additions & 0 deletions charts/monitor/templates/hook-delete-influxdb.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
{{- if eq .Values.global.influxdb_location "off-cluster" }}
apiVersion: batch/v1
kind: Job
metadata:
name: deis-monitor-delete-influxdb-deployment-{{ randAlphaNum 5 | lower }}
labels:
heritage: {{.Release.Service | quote }}
release: {{.Release.Name | quote }}
chart: {{.Chart.Name}}
annotations:
"helm.sh/hook": post-install,post-upgrade
"helm.sh/hook-weight": "-10"
spec:
template:
metadata:
name: "{{.Release.Name}}"
labels:
heritage: {{.Release.Service | quote }}
release: {{.Release.Name | quote }}
chart: "{{.Chart.Name}}"
spec:
restartPolicy: Never
containers:
- name: deis-monitor-delete-influxdb-deployment
image: "lachlanevenson/k8s-kubectl"
command: ["/bin/sh", "-c"]
args: ["(kubectl delete deploy {{.Release.Name}}-influxdb) \
|| \
true"]
- name: deis-monitor-delete-telegraf-pods
image: "lachlanevenson/k8s-kubectl"
command: ["/bin/sh", "-c"]
args: ["kubectl get pods | grep deis-monitor-telegraf | awk '{print $1}' | xargs kubectl delete pod \
|| \
true"]
{{- end }}
35 changes: 35 additions & 0 deletions charts/monitor/templates/hook-kill-pods.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
{{ $tillerVersion := semver .Capabilities.TillerVersion.SemVer }}
{{ $comparingVersion := semver "2.3.0" }}

{{- if gt ($tillerVersion | $comparingVersion.Compare) -1 }}
{{- if .Values.influxdb.persistence.enabled }}
apiVersion: batch/v1
kind: Job
metadata:
name: deis-monitor-kill-pods-{{ randAlphaNum 5 | lower }}
labels:
heritage: {{.Release.Service | quote }}
release: {{.Release.Name | quote }}
chart: {{.Chart.Name}}
annotations:
"helm.sh/hook": pre-upgrade
"helm.sh/hook-weight": "-10"
spec:
template:
metadata:
name: "{{.Release.Name}}"
labels:
heritage: {{.Release.Service | quote }}
release: {{.Release.Name | quote }}
chart: "{{.Chart.Name}}"
spec:
restartPolicy: Never
containers:
- name: deis-monitor-kill-pods
image: "lachlanevenson/k8s-kubectl"
command: ["/bin/sh", "-c"]
args: ["(kubectl delete daemonset deis-monitor-telegraf &&
kubectl delete deploy deis-monitor-influxdb &&
sleep 30) || true"]
{{- end }}
{{- end }}
57 changes: 57 additions & 0 deletions charts/monitor/templates/hook-migrate-data.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
{{ $tillerVersion := semver .Capabilities.TillerVersion.SemVer }}
{{ $comparingVersion := semver "2.3.0" }}

{{- if gt ($tillerVersion | $comparingVersion.Compare) -1 }}
{{- if .Values.influxdb.persistence.enabled }}
apiVersion: batch/v1
kind: Job
metadata:
name: deis-monitor-migrate-data-{{ randAlphaNum 5 | lower }}
labels:
heritage: {{.Release.Service | quote }}
release: {{.Release.Name | quote }}
chart: {{.Chart.Name}}
annotations:
"helm.sh/hook": "pre-upgrade"
"helm.sh/hook-weight": "0"
spec:
template:
metadata:
name: "{{.Release.Name}}"
labels:
heritage: {{.Release.Service | quote }}
release: {{.Release.Name | quote }}
chart: "{{.Chart.Name}}"
spec:
restartPolicy: Never
containers:
- name: deis-monitor-migrate-data
image: "lachlanevenson/k8s-kubectl"
command: ["/bin/sh", "-c"]
args: ["(if [ -d {{ .Values.influxdb.config.storage_directory }}/data/_internal ]; then \
echo 'Nothing to migrate!'; \
else \
echo Creating directories; \
mkdir {{ .Values.influxdb.config.storage_directory }}/data; \
(if [ -d {{ .Values.influxdb.config.storage_directory }}/db/wal ]; then \
echo 'Moving data from /db/wal'; \
mv {{ .Values.influxdb.config.storage_directory }}/db/wal {{ .Values.influxdb.config.storage_directory }}; \
else \
echo 'Directory {{ .Values.influxdb.config.storage_directory }}/db/wal does not exist!'; \
fi); \
(if [ -d {{ .Values.influxdb.config.storage_directory }}/db/_internal ]; then \
echo 'Moving data from /db/*'; \
mv {{ .Values.influxdb.config.storage_directory }}/db/* {{ .Values.influxdb.config.storage_directory }}/data; \
else \
echo 'Directory {{ .Values.influxdb.config.storage_directory }}/db does not exist!'; \
fi);
fi)"]
volumeMounts:
- name: data
mountPath: {{ .Values.influxdb.config.storage_directory }}
volumes:
- name: data
persistentVolumeClaim:
claimName: deis-monitor-influxdb
{{- end }}
{{- end }}
Loading

0 comments on commit c8eb29a

Please sign in to comment.