add helm stuff

This commit is contained in:
ducoterra
2020-05-16 09:54:45 -04:00
parent c9330366d1
commit d79697bc56
7 changed files with 64 additions and 18 deletions

View File

@@ -1,4 +1,5 @@
variables: variables:
CI_PROJECT_NAME: "homer"
CI_PROJECT_DIR: "." CI_PROJECT_DIR: "."
CI_REGISTRY_IMAGE: hub.ducoterra.net/ducoterra/homer CI_REGISTRY_IMAGE: hub.ducoterra.net/ducoterra/homer
@@ -30,10 +31,8 @@ deploy_to_prod:
name: debian:10 name: debian:10
entrypoint: [""] entrypoint: [""]
script: script:
- apt -qq update >> /dev/null && apt -qq install -y curl gettext >> /dev/null - apt -qq update >> /dev/null && apt -qq install -y curl >> /dev/null
- curl -LO https://storage.googleapis.com/kubernetes-release/release/`curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt`/bin/linux/amd64/kubectl - curl -LO https://storage.googleapis.com/kubernetes-release/release/`curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt`/bin/linux/amd64/kubectl
- curl https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3 | bash
- chmod +x ./kubectl - chmod +x ./kubectl
- mkdir /deploy - helm install --set tag=$CI_COMMIT_TAG $CI_PROJECT_NAME ./helm
- for f in $(find k8s -regex '.*\.ya*ml'); do envsubst < $f > "/deploy/$(basename $f)"; done
- for f in $(find k8s/prod -regex '.*\.ya*ml'); do envsubst < $f > "/deploy/$(basename $f)"; done
- ./kubectl apply -f /deploy

23
helm/.helmignore Normal file
View File

@@ -0,0 +1,23 @@
# 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/

23
helm/Chart.yaml Normal file
View File

@@ -0,0 +1,23 @@
apiVersion: v2
name: helm
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.
appVersion: 1.16.0

View File

@@ -1,19 +1,19 @@
apiVersion: apps/v1 apiVersion: apps/v1
kind: Deployment kind: Deployment
metadata: metadata:
name: dashboard name: {{ .Release.Name }}
spec: spec:
selector: selector:
matchLabels: matchLabels:
app: dashboard app: {{ .Release.Name }}
template: template:
metadata: metadata:
labels: labels:
app: dashboard app: {{ .Release.Name }}
spec: spec:
containers: containers:
- name: dashboard - name: {{ .Release.Name }}
image: $CI_REGISTRY_IMAGE:$CI_COMMIT_TAG image: {{ .Values.image }}:{{ .Values.tag }}
resources: resources:
limits: limits:
memory: "128Mi" memory: "128Mi"

View File

@@ -1,7 +1,7 @@
apiVersion: traefik.containo.us/v1alpha1 apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute kind: IngressRoute
metadata: metadata:
name: dashboard-internal-tls name: {{ .Release.Name }}-internal-tls
annotations: annotations:
kubernetes.io/ingress.class: traefik-internal kubernetes.io/ingress.class: traefik-internal
spec: spec:
@@ -12,10 +12,10 @@ spec:
domains: domains:
- main: "*.ducoterra.net" - main: "*.ducoterra.net"
routes: routes:
- match: Host(`dashboard.ducoterra.net`) - match: Host(`{{ .Release.Name }}.ducoterra.net`)
kind: Rule kind: Rule
services: services:
- name: dashboard - name: {{ .Release.Name }}
port: 8080 port: 8080
--- ---
@@ -23,17 +23,17 @@ spec:
apiVersion: traefik.containo.us/v1alpha1 apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute kind: IngressRoute
metadata: metadata:
name: dashboard-internal-web name: {{ .Release.Name }}-internal-web
annotations: annotations:
kubernetes.io/ingress.class: traefik-internal kubernetes.io/ingress.class: traefik-internal
spec: spec:
entryPoints: entryPoints:
- web - web
routes: routes:
- match: Host(`dashboard.ducoterra.net`) - match: Host(`{{ .Release.Name }}.ducoterra.net`)
kind: Rule kind: Rule
services: services:
- name: dashboard - name: {{ .Release.Name }}
port: 8080 port: 8080
middlewares: middlewares:
- name: httpsredirect - name: httpsredirect

View File

@@ -1,10 +1,10 @@
apiVersion: v1 apiVersion: v1
kind: Service kind: Service
metadata: metadata:
name: dashboard name: {{ .Release.Name }}
spec: spec:
selector: selector:
app: dashboard app: {{ .Release.Name }}
ports: ports:
- port: 8080 - port: 8080
targetPort: 8080 targetPort: 8080

1
helm/values.yaml Normal file
View File

@@ -0,0 +1 @@
image: hub.ducoterra.net/ducoterra/homer