added helm deployment files
This commit is contained in:
		
							parent
							
								
									f43e44e217
								
							
						
					
					
						commit
						226cb30961
					
				| 
						 | 
					@ -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/
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,6 @@
 | 
				
			||||||
 | 
					apiVersion: v2
 | 
				
			||||||
 | 
					name: hugo-mx-gateway
 | 
				
			||||||
 | 
					description: Helm chart for hugo-mx-gateway
 | 
				
			||||||
 | 
					type: application
 | 
				
			||||||
 | 
					version: 0.1.0
 | 
				
			||||||
 | 
					appVersion: 1.16.0
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,21 @@
 | 
				
			||||||
 | 
					1. Get the application URL by running these commands:
 | 
				
			||||||
 | 
					{{- if .Values.ingress.enabled }}
 | 
				
			||||||
 | 
					{{- range $host := .Values.ingress.hosts }}
 | 
				
			||||||
 | 
					  {{- range .paths }}
 | 
				
			||||||
 | 
					  http{{ if $.Values.ingress.tls }}s{{ end }}://{{ $host.host }}{{ . }}
 | 
				
			||||||
 | 
					  {{- end }}
 | 
				
			||||||
 | 
					{{- end }}
 | 
				
			||||||
 | 
					{{- else if contains "NodePort" .Values.service.type }}
 | 
				
			||||||
 | 
					  export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "helm.fullname" . }})
 | 
				
			||||||
 | 
					  export NODE_IP=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}")
 | 
				
			||||||
 | 
					  echo http://$NODE_IP:$NODE_PORT
 | 
				
			||||||
 | 
					{{- else if contains "LoadBalancer" .Values.service.type }}
 | 
				
			||||||
 | 
					     NOTE: It may take a few minutes for the LoadBalancer IP to be available.
 | 
				
			||||||
 | 
					           You can watch the status of by running 'kubectl get --namespace {{ .Release.Namespace }} svc -w {{ include "helm.fullname" . }}'
 | 
				
			||||||
 | 
					  export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "helm.fullname" . }} --template "{{"{{ range (index .status.loadBalancer.ingress 0) }}{{.}}{{ end }}"}}")
 | 
				
			||||||
 | 
					  echo http://$SERVICE_IP:{{ .Values.service.port }}
 | 
				
			||||||
 | 
					{{- else if contains "ClusterIP" .Values.service.type }}
 | 
				
			||||||
 | 
					  export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app.kubernetes.io/name={{ include "helm.name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
 | 
				
			||||||
 | 
					  echo "Visit http://127.0.0.1:8080 to use your application"
 | 
				
			||||||
 | 
					  kubectl --namespace {{ .Release.Namespace }} port-forward $POD_NAME 8080:80
 | 
				
			||||||
 | 
					{{- end }}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,63 @@
 | 
				
			||||||
 | 
					{{/* vim: set filetype=mustache: */}}
 | 
				
			||||||
 | 
					{{/*
 | 
				
			||||||
 | 
					Expand the name of the chart.
 | 
				
			||||||
 | 
					*/}}
 | 
				
			||||||
 | 
					{{- define "helm.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 "helm.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 "helm.chart" -}}
 | 
				
			||||||
 | 
					{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
 | 
				
			||||||
 | 
					{{- end -}}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					{{/*
 | 
				
			||||||
 | 
					Common labels
 | 
				
			||||||
 | 
					*/}}
 | 
				
			||||||
 | 
					{{- define "helm.labels" -}}
 | 
				
			||||||
 | 
					helm.sh/chart: {{ include "helm.chart" . }}
 | 
				
			||||||
 | 
					{{ include "helm.selectorLabels" . }}
 | 
				
			||||||
 | 
					{{- if .Chart.AppVersion }}
 | 
				
			||||||
 | 
					app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
 | 
				
			||||||
 | 
					{{- end }}
 | 
				
			||||||
 | 
					app.kubernetes.io/managed-by: {{ .Release.Service }}
 | 
				
			||||||
 | 
					{{- end -}}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					{{/*
 | 
				
			||||||
 | 
					Selector labels
 | 
				
			||||||
 | 
					*/}}
 | 
				
			||||||
 | 
					{{- define "helm.selectorLabels" -}}
 | 
				
			||||||
 | 
					app.kubernetes.io/name: {{ include "helm.name" . }}
 | 
				
			||||||
 | 
					app.kubernetes.io/instance: {{ .Release.Name }}
 | 
				
			||||||
 | 
					{{- end -}}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					{{/*
 | 
				
			||||||
 | 
					Create the name of the service account to use
 | 
				
			||||||
 | 
					*/}}
 | 
				
			||||||
 | 
					{{- define "helm.serviceAccountName" -}}
 | 
				
			||||||
 | 
					{{- if .Values.serviceAccount.create -}}
 | 
				
			||||||
 | 
					    {{ default (include "helm.fullname" .) .Values.serviceAccount.name }}
 | 
				
			||||||
 | 
					{{- else -}}
 | 
				
			||||||
 | 
					    {{ default "default" .Values.serviceAccount.name }}
 | 
				
			||||||
 | 
					{{- end -}}
 | 
				
			||||||
 | 
					{{- end -}}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,62 @@
 | 
				
			||||||
 | 
					apiVersion: apps/v1
 | 
				
			||||||
 | 
					kind: Deployment
 | 
				
			||||||
 | 
					metadata:
 | 
				
			||||||
 | 
					  name: {{ include "helm.fullname" . }}
 | 
				
			||||||
 | 
					  labels:
 | 
				
			||||||
 | 
					    {{- include "helm.labels" . | nindent 4 }}
 | 
				
			||||||
 | 
					spec:
 | 
				
			||||||
 | 
					  replicas: {{ .Values.replicaCount }}
 | 
				
			||||||
 | 
					  selector:
 | 
				
			||||||
 | 
					    matchLabels:
 | 
				
			||||||
 | 
					      {{- include "helm.selectorLabels" . | nindent 6 }}
 | 
				
			||||||
 | 
					  template:
 | 
				
			||||||
 | 
					    metadata:
 | 
				
			||||||
 | 
					      labels:
 | 
				
			||||||
 | 
					        {{- include "helm.selectorLabels" . | nindent 8 }}
 | 
				
			||||||
 | 
					    spec:
 | 
				
			||||||
 | 
					    {{- with .Values.imagePullSecrets }}
 | 
				
			||||||
 | 
					      imagePullSecrets:
 | 
				
			||||||
 | 
					        {{- toYaml . | nindent 8 }}
 | 
				
			||||||
 | 
					    {{- end }}
 | 
				
			||||||
 | 
					      serviceAccountName: {{ include "helm.serviceAccountName" . }}
 | 
				
			||||||
 | 
					      securityContext:
 | 
				
			||||||
 | 
					        {{- toYaml .Values.podSecurityContext | nindent 8 }}
 | 
				
			||||||
 | 
					      containers:
 | 
				
			||||||
 | 
					        - name: {{ .Chart.Name }}
 | 
				
			||||||
 | 
					          securityContext:
 | 
				
			||||||
 | 
					            {{- toYaml .Values.securityContext | nindent 12 }}
 | 
				
			||||||
 | 
					          image: "{{ .Values.image.repository }}:{{ .Chart.AppVersion }}"
 | 
				
			||||||
 | 
					          imagePullPolicy: {{ .Values.image.pullPolicy }}
 | 
				
			||||||
 | 
					          {{- if .Values.envs }}
 | 
				
			||||||
 | 
					          env:
 | 
				
			||||||
 | 
					          {{- range $key, $val := .Values.envs }}
 | 
				
			||||||
 | 
					            - name: {{ $key | quote }}
 | 
				
			||||||
 | 
					              value: {{ $val | quote }}
 | 
				
			||||||
 | 
					          {{- end }}
 | 
				
			||||||
 | 
					          {{- end }}          
 | 
				
			||||||
 | 
					          ports:
 | 
				
			||||||
 | 
					            - name: http
 | 
				
			||||||
 | 
					              containerPort: 80
 | 
				
			||||||
 | 
					              protocol: TCP
 | 
				
			||||||
 | 
					          livenessProbe:
 | 
				
			||||||
 | 
					            httpGet:
 | 
				
			||||||
 | 
					              path: /
 | 
				
			||||||
 | 
					              port: http
 | 
				
			||||||
 | 
					          readinessProbe:
 | 
				
			||||||
 | 
					            httpGet:
 | 
				
			||||||
 | 
					              path: /
 | 
				
			||||||
 | 
					              port: http
 | 
				
			||||||
 | 
					          resources:
 | 
				
			||||||
 | 
					            {{- toYaml .Values.resources | nindent 12 }}
 | 
				
			||||||
 | 
					      {{- with .Values.nodeSelector }}
 | 
				
			||||||
 | 
					      nodeSelector:
 | 
				
			||||||
 | 
					        {{- toYaml . | nindent 8 }}
 | 
				
			||||||
 | 
					      {{- end }}
 | 
				
			||||||
 | 
					    {{- with .Values.affinity }}
 | 
				
			||||||
 | 
					      affinity:
 | 
				
			||||||
 | 
					        {{- toYaml . | nindent 8 }}
 | 
				
			||||||
 | 
					    {{- end }}
 | 
				
			||||||
 | 
					    {{- with .Values.tolerations }}
 | 
				
			||||||
 | 
					      tolerations:
 | 
				
			||||||
 | 
					        {{- toYaml . | nindent 8 }}
 | 
				
			||||||
 | 
					    {{- end }}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,41 @@
 | 
				
			||||||
 | 
					{{- if .Values.ingress.enabled -}}
 | 
				
			||||||
 | 
					{{- $fullName := include "helm.fullname" . -}}
 | 
				
			||||||
 | 
					{{- $svcPort := .Values.service.port -}}
 | 
				
			||||||
 | 
					{{- if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}}
 | 
				
			||||||
 | 
					apiVersion: networking.k8s.io/v1beta1
 | 
				
			||||||
 | 
					{{- else -}}
 | 
				
			||||||
 | 
					apiVersion: extensions/v1beta1
 | 
				
			||||||
 | 
					{{- end }}
 | 
				
			||||||
 | 
					kind: Ingress
 | 
				
			||||||
 | 
					metadata:
 | 
				
			||||||
 | 
					  name: {{ $fullName }}
 | 
				
			||||||
 | 
					  labels:
 | 
				
			||||||
 | 
					    {{- include "helm.labels" . | nindent 4 }}
 | 
				
			||||||
 | 
					  {{- with .Values.ingress.annotations }}
 | 
				
			||||||
 | 
					  annotations:
 | 
				
			||||||
 | 
					    {{- toYaml . | nindent 4 }}
 | 
				
			||||||
 | 
					  {{- end }}
 | 
				
			||||||
 | 
					spec:
 | 
				
			||||||
 | 
					{{- if .Values.ingress.tls }}
 | 
				
			||||||
 | 
					  tls:
 | 
				
			||||||
 | 
					  {{- range .Values.ingress.tls }}
 | 
				
			||||||
 | 
					    - hosts:
 | 
				
			||||||
 | 
					      {{- range .hosts }}
 | 
				
			||||||
 | 
					        - {{ . | quote }}
 | 
				
			||||||
 | 
					      {{- end }}
 | 
				
			||||||
 | 
					      secretName: {{ .secretName }}
 | 
				
			||||||
 | 
					  {{- end }}
 | 
				
			||||||
 | 
					{{- end }}
 | 
				
			||||||
 | 
					  rules:
 | 
				
			||||||
 | 
					  {{- range .Values.ingress.hosts }}
 | 
				
			||||||
 | 
					    - host: {{ .host | quote }}
 | 
				
			||||||
 | 
					      http:
 | 
				
			||||||
 | 
					        paths:
 | 
				
			||||||
 | 
					        {{- range .paths }}
 | 
				
			||||||
 | 
					          - path: {{ . }}
 | 
				
			||||||
 | 
					            backend:
 | 
				
			||||||
 | 
					              serviceName: {{ $fullName }}
 | 
				
			||||||
 | 
					              servicePort: {{ $svcPort }}
 | 
				
			||||||
 | 
					        {{- end }}
 | 
				
			||||||
 | 
					  {{- end }}
 | 
				
			||||||
 | 
					{{- end }}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,15 @@
 | 
				
			||||||
 | 
					apiVersion: v1
 | 
				
			||||||
 | 
					kind: Service
 | 
				
			||||||
 | 
					metadata:
 | 
				
			||||||
 | 
					  name: {{ include "helm.fullname" . }}
 | 
				
			||||||
 | 
					  labels:
 | 
				
			||||||
 | 
					    {{- include "helm.labels" . | nindent 4 }}
 | 
				
			||||||
 | 
					spec:
 | 
				
			||||||
 | 
					  type: {{ .Values.service.type }}
 | 
				
			||||||
 | 
					  ports:
 | 
				
			||||||
 | 
					    - port: {{ .Values.service.port }}
 | 
				
			||||||
 | 
					      targetPort: http
 | 
				
			||||||
 | 
					      protocol: TCP
 | 
				
			||||||
 | 
					      name: http
 | 
				
			||||||
 | 
					  selector:
 | 
				
			||||||
 | 
					    {{- include "helm.selectorLabels" . | nindent 4 }}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,12 @@
 | 
				
			||||||
 | 
					{{- if .Values.serviceAccount.create -}}
 | 
				
			||||||
 | 
					apiVersion: v1
 | 
				
			||||||
 | 
					kind: ServiceAccount
 | 
				
			||||||
 | 
					metadata:
 | 
				
			||||||
 | 
					  name: {{ include "helm.serviceAccountName" . }}
 | 
				
			||||||
 | 
					  labels:
 | 
				
			||||||
 | 
					    {{- include "helm.labels" . | nindent 4 }}
 | 
				
			||||||
 | 
					  {{- with .Values.serviceAccount.annotations }}
 | 
				
			||||||
 | 
					  annotations:
 | 
				
			||||||
 | 
					    {{- toYaml . | nindent 4 }}
 | 
				
			||||||
 | 
					  {{- end }}
 | 
				
			||||||
 | 
					{{- end -}}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,15 @@
 | 
				
			||||||
 | 
					apiVersion: v1
 | 
				
			||||||
 | 
					kind: Pod
 | 
				
			||||||
 | 
					metadata:
 | 
				
			||||||
 | 
					  name: "{{ include "helm.fullname" . }}-test-connection"
 | 
				
			||||||
 | 
					  labels:
 | 
				
			||||||
 | 
					    {{- include "helm.labels" . | nindent 4 }}
 | 
				
			||||||
 | 
					  annotations:
 | 
				
			||||||
 | 
					    "helm.sh/hook": test-success
 | 
				
			||||||
 | 
					spec:
 | 
				
			||||||
 | 
					  containers:
 | 
				
			||||||
 | 
					    - name: wget
 | 
				
			||||||
 | 
					      image: busybox
 | 
				
			||||||
 | 
					      command: ['wget']
 | 
				
			||||||
 | 
					      args: ['{{ include "helm.fullname" . }}:{{ .Values.service.port }}']
 | 
				
			||||||
 | 
					  restartPolicy: Never
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,74 @@
 | 
				
			||||||
 | 
					replicaCount: 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					envs:
 | 
				
			||||||
 | 
					  SMTP_SERVER_ADDR: "smtp.mailgun.org:587"
 | 
				
			||||||
 | 
					  SMTP_VERITY_CERT: true
 | 
				
			||||||
 | 
					  SMTP_CLIENT_USERNAME: "postmaster@example.com"
 | 
				
			||||||
 | 
					  SMTP_CLIENT_PASSWORD: "postmasterSecretPassWord"
 | 
				
			||||||
 | 
					  ALLOWED_ORIGINS: "127.0.0.1,example.com"
 | 
				
			||||||
 | 
					  CONTACT_REPLY_EMAIL: "noreply@example.com"
 | 
				
			||||||
 | 
					  CONTACT_REPLY_CC_EMAIL: "contact@example.com"
 | 
				
			||||||
 | 
					  DEMO_URL: "https://demo.example.com/"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					image:
 | 
				
			||||||
 | 
					  repository: rchakode/hugo-mx-gateway
 | 
				
			||||||
 | 
					  pullPolicy: IfNotPresent
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					imagePullSecrets: []
 | 
				
			||||||
 | 
					nameOverride: ""
 | 
				
			||||||
 | 
					fullnameOverride: ""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					serviceAccount:
 | 
				
			||||||
 | 
					  # Specifies whether a service account should be created
 | 
				
			||||||
 | 
					  create: true
 | 
				
			||||||
 | 
					  # Annotations to add to the service account
 | 
				
			||||||
 | 
					  annotations: {}
 | 
				
			||||||
 | 
					  # The name of the service account to use.
 | 
				
			||||||
 | 
					  # If not set and create is true, a name is generated using the fullname template
 | 
				
			||||||
 | 
					  name:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					podSecurityContext: {}
 | 
				
			||||||
 | 
					  # fsGroup: 2000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					securityContext: {}
 | 
				
			||||||
 | 
					  # capabilities:
 | 
				
			||||||
 | 
					  #   drop:
 | 
				
			||||||
 | 
					  #   - ALL
 | 
				
			||||||
 | 
					  # readOnlyRootFilesystem: true
 | 
				
			||||||
 | 
					  # runAsNonRoot: true
 | 
				
			||||||
 | 
					  # runAsUser: 1000
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					service:
 | 
				
			||||||
 | 
					  type: ClusterIP
 | 
				
			||||||
 | 
					  port: 80
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ingress:
 | 
				
			||||||
 | 
					  enabled: false
 | 
				
			||||||
 | 
					  annotations: {}
 | 
				
			||||||
 | 
					    # kubernetes.io/ingress.class: nginx
 | 
				
			||||||
 | 
					    # kubernetes.io/tls-acme: "true"
 | 
				
			||||||
 | 
					  hosts:
 | 
				
			||||||
 | 
					    - host: chart-example.local
 | 
				
			||||||
 | 
					      paths: []
 | 
				
			||||||
 | 
					  tls: []
 | 
				
			||||||
 | 
					  #  - secretName: chart-example-tls
 | 
				
			||||||
 | 
					  #    hosts:
 | 
				
			||||||
 | 
					  #      - chart-example.local
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					resources: {}
 | 
				
			||||||
 | 
					  # We usually recommend not to specify default resources and to leave this as a conscious
 | 
				
			||||||
 | 
					  # choice for the user. This also increases chances charts run on environments with little
 | 
				
			||||||
 | 
					  # resources, such as Minikube. If you do want to specify resources, uncomment the following
 | 
				
			||||||
 | 
					  # lines, adjust them as necessary, and remove the curly braces after 'resources:'.
 | 
				
			||||||
 | 
					  # limits:
 | 
				
			||||||
 | 
					  #   cpu: 100m
 | 
				
			||||||
 | 
					  #   memory: 128Mi
 | 
				
			||||||
 | 
					  # requests:
 | 
				
			||||||
 | 
					  #   cpu: 100m
 | 
				
			||||||
 | 
					  #   memory: 128Mi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					nodeSelector: {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					tolerations: []
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					affinity: {}
 | 
				
			||||||
		Reference in New Issue