mirror of
https://github.com/k8s-at-home/charts.git
synced 2025-01-23 15:39:02 +00:00
[powerdns] Introduce Powerdns chart (#308)
* initial commit for powerdns Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add auto-create zone, bump chart version Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add selector for db type Signed-off-by: Ryan Holt <ryan@ryanholt.net> * fix indent Signed-off-by: Ryan Holt <ryan@ryanholt.net> * fix path mount for conf.d Signed-off-by: Ryan Holt <ryan@ryanholt.net> * fix indent Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add liveness & readiness probes. Bump chart Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add more sleep Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add startupProbe Signed-off-by: Ryan Holt <ryan@ryanholt.net> * replace homepage with home Signed-off-by: Ryan Holt <ryan@ryanholt.net> * remove trailing space Signed-off-by: Ryan Holt <ryan@ryanholt.net> * fix maintainer to be github username Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add newline to end of file for linting Signed-off-by: Ryan Holt <ryan@ryanholt.net> * opinionate the chart -- generate an api_key Signed-off-by: Ryan Holt <ryan@ryanholt.net> * disable dependent charts by default Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add default values for dependent charts (disabled) Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add newline (lint) Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add check for lifecycle Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add default values for automated tests Signed-off-by: Ryan Holt <ryan@ryanholt.net> * update default mysql/postgres host to match dependent chart Signed-off-by: Ryan Holt <ryan@ryanholt.net> * update pdnspass to be the same for mysql and pdns chart Signed-off-by: Ryan Holt <ryan@ryanholt.net> * fixed a broken conditional Signed-off-by: Ryan Holt <ryan@ryanholt.net> * disable persistence on mariadb by default Signed-off-by: Ryan Holt <ryan@ryanholt.net> * found the missing toggle Signed-off-by: Ryan Holt <ryan@ryanholt.net> * mysql=mariadb Signed-off-by: Ryan Holt <ryan@ryanholt.net> * try using a templated mysql host name Signed-off-by: Ryan Holt <ryan@ryanholt.net> * fix linting problem Signed-off-by: Ryan Holt <ryan@ryanholt.net> * maybe this will work? Signed-off-by: Ryan Holt <ryan@ryanholt.net> * another attempt Signed-off-by: Ryan Holt <ryan@ryanholt.net> * how about this? Signed-off-by: Ryan Holt <ryan@ryanholt.net> * trying this Signed-off-by: Ryan Holt <ryan@ryanholt.net> * try this one out Signed-off-by: Ryan Holt <ryan@ryanholt.net> * this might work Signed-off-by: Ryan Holt <ryan@ryanholt.net> * remove special characters from domain name, attempt to fix configmap Signed-off-by: Ryan Holt <ryan@ryanholt.net> * try it with quotes Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add 'quote' Signed-off-by: Ryan Holt <ryan@ryanholt.net> * needs to be = not : Signed-off-by: Ryan Holt <ryan@ryanholt.net> * remove the quote option Signed-off-by: Ryan Holt <ryan@ryanholt.net> * remove bbenc64 Signed-off-by: Ryan Holt <ryan@ryanholt.net> * add probes and optional exclude Signed-off-by: Ryan Holt <ryan@ryanholt.net> * flip to ClusterIP as default Signed-off-by: Ryan Holt <ryan@ryanholt.net> * remove ci exclusions, bump chart to v1 Signed-off-by: Ryan Holt <ryan@ryanholt.net> Co-authored-by: Jeff Billimek <jeff@billimek.com>
This commit is contained in:
parent
db26e398d2
commit
ddd4788598
22
charts/powerdns/.helmignore
Executable file
22
charts/powerdns/.helmignore
Executable file
@ -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/
|
21
charts/powerdns/Chart.yaml
Executable file
21
charts/powerdns/Chart.yaml
Executable file
@ -0,0 +1,21 @@
|
||||
apiVersion: v2
|
||||
appVersion: "latest"
|
||||
description: PowerDNS is a DNS server, written in C++ and licensed under the GPL. It runs on most Unix derivatives. PowerDNS features a large number of different backends ranging from simple BIND style zonefiles to relational databases and load balancing/failover algorithms. A DNS recursor is provided as a separate program.
|
||||
name: powerdns
|
||||
version: 1.0.0
|
||||
home: https://www.powerdns.com/
|
||||
sources:
|
||||
- http://www.github.com/PowerDNS/
|
||||
icon: https://www.powerdns.com/img/pDNS_logo_positive_claim_down_screen_xsmall.png
|
||||
maintainers:
|
||||
- name: carpenike
|
||||
email: ryan@ryanholt.net
|
||||
dependencies:
|
||||
- name: postgresql
|
||||
version: 9.1.2
|
||||
repository: https://charts.bitnami.com/bitnami
|
||||
condition: postgres.enabled
|
||||
- name: mariadb
|
||||
version: 7.7.1
|
||||
repository: https://charts.bitnami.com/bitnami
|
||||
condition: mariadb.enabled
|
15
charts/powerdns/templates/NOTES.txt
Executable file
15
charts/powerdns/templates/NOTES.txt
Executable file
@ -0,0 +1,15 @@
|
||||
1. Get the application URL by running these commands:
|
||||
{{- if contains "NodePort" .Values.service.type }}
|
||||
export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "powerdns.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 "powerdns.fullname" . }}'
|
||||
export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "powerdns.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 "powerdns.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 port-forward $POD_NAME 8080:80
|
||||
{{- end }}
|
56
charts/powerdns/templates/_helpers.tpl
Executable file
56
charts/powerdns/templates/_helpers.tpl
Executable file
@ -0,0 +1,56 @@
|
||||
{{/* vim: set filetype=mustache: */}}
|
||||
{{/*
|
||||
Expand the name of the chart.
|
||||
*/}}
|
||||
{{- define "powerdns.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 "powerdns.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 "powerdns.chart" -}}
|
||||
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}}
|
||||
{{- end -}}
|
||||
|
||||
{{/*
|
||||
Common labels
|
||||
*/}}
|
||||
{{- define "powerdns.labels" -}}
|
||||
app.kubernetes.io/name: {{ include "powerdns.name" . }}
|
||||
helm.sh/chart: {{ include "powerdns.chart" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
{{- if .Chart.AppVersion }}
|
||||
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
|
||||
{{- end }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
{{- end -}}
|
||||
|
||||
{{/*
|
||||
Create the name of the service account to use
|
||||
*/}}
|
||||
{{- define "powerdns.serviceAccountName" -}}
|
||||
{{- if .Values.serviceAccount.create -}}
|
||||
{{ default (include "powerdns.fullname" .) .Values.serviceAccount.name }}
|
||||
{{- else -}}
|
||||
{{ default "default" .Values.serviceAccount.name }}
|
||||
{{- end -}}
|
||||
{{- end -}}
|
30
charts/powerdns/templates/configmap.yaml
Executable file
30
charts/powerdns/templates/configmap.yaml
Executable file
@ -0,0 +1,30 @@
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: {{ template "powerdns.fullname" . }}
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "powerdns.name" . }}
|
||||
helm.sh/chart: {{ include "powerdns.chart" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
app.kubernetes.io/managed-by: {{ .Release.Service }}
|
||||
data:
|
||||
01-general-config.conf: |
|
||||
{{ range $key, $value := .Values.powerdns.config -}}
|
||||
{{ $key }}={{ $value }}
|
||||
{{ end }}
|
||||
|
||||
|
||||
00-api-key.conf: |
|
||||
api=yes
|
||||
{{ if .Values.powerdns.api_key }}
|
||||
api-key={{ .Values.powerdns.api_key }}
|
||||
{{ else }}
|
||||
api-key={{ randAlphaNum 24 }}
|
||||
{{ end }}
|
||||
webserver=yes
|
||||
# IP Address of web server to listen on
|
||||
webserver-address=0.0.0.0
|
||||
# Port of web server to listen on
|
||||
webserver-port=8081
|
||||
# Web server access is only allowed from these subnets
|
||||
webserver-allow-from=0.0.0.0/0,::/0
|
154
charts/powerdns/templates/deployment.yaml
Executable file
154
charts/powerdns/templates/deployment.yaml
Executable file
@ -0,0 +1,154 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
labels:
|
||||
{{ include "powerdns.labels" . | indent 4 }}
|
||||
spec:
|
||||
replicas: {{ .Values.replicaCount }}
|
||||
selector:
|
||||
matchLabels:
|
||||
app.kubernetes.io/name: {{ include "powerdns.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app.kubernetes.io/name: {{ include "powerdns.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
spec:
|
||||
{{- with .Values.imagePullSecrets }}
|
||||
imagePullSecrets:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
serviceAccountName: {{ template "powerdns.serviceAccountName" . }}
|
||||
securityContext:
|
||||
{{- toYaml .Values.podSecurityContext | nindent 8 }}
|
||||
containers:
|
||||
- name: {{ .Chart.Name }}
|
||||
securityContext:
|
||||
{{- toYaml .Values.securityContext | nindent 12 }}
|
||||
image: "{{ .Values.image.repository }}:{{ tpl .Values.image.tag . }}"
|
||||
imagePullPolicy: {{ .Values.image.pullPolicy }}
|
||||
volumeMounts:
|
||||
- name: config
|
||||
mountPath: /etc/pdns/conf.d
|
||||
env:
|
||||
{{- if .Values.postgres.enabled }}
|
||||
- name: PGSQL_HOST
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: postgres_host
|
||||
- name: PGSQL_PORT
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: postgres_port
|
||||
- name: PGSQL_USERNAME
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: postgres_username
|
||||
- name: PGSQL_PASSWORD
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: postgres_password
|
||||
- name: PGSQL_DATABASE
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: postgres_database
|
||||
- name: PGSQL_DNSSEC
|
||||
value: {{if (.Values.powerdns.dnssec)}}"yes"{{else}}"no"{{ end }}
|
||||
{{ end }}
|
||||
{{- if .Values.mariadb.enabled }}
|
||||
- name: MYSQL_HOST
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: mysql_host
|
||||
- name: MYSQL_USER
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: mysql_username
|
||||
- name: MYSQL_PASS
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: mysql_password
|
||||
- name: MYSQL_DB
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
key: mysql_database
|
||||
- name: MYSQL_DNSSEC
|
||||
value: {{if (.Values.powerdns.dnssec)}}"yes"{{else}}"no"{{ end }}
|
||||
{{ end }}
|
||||
ports:
|
||||
- name: dns-tcp
|
||||
containerPort: 53
|
||||
protocol: TCP
|
||||
- name: dns-udp
|
||||
containerPort: 53
|
||||
protocol: UDP
|
||||
- name: dns-webserver
|
||||
containerPort: 8081
|
||||
protocol: TCP
|
||||
{{- if .Values.probes.liveness.enabled }}
|
||||
livenessProbe:
|
||||
httpGet:
|
||||
path: /
|
||||
port: dns-webserver
|
||||
initialDelaySeconds: {{ .Values.probes.liveness.initialDelaySeconds }}
|
||||
failureThreshold: {{ .Values.probes.liveness.failureThreshold }}
|
||||
timeoutSeconds: {{ .Values.probes.liveness.timeoutSeconds }}
|
||||
{{ end }}
|
||||
{{- if .Values.probes.readiness.enabled }}
|
||||
readinessProbe:
|
||||
httpGet:
|
||||
path: /
|
||||
port: dns-webserver
|
||||
initialDelaySeconds: {{ .Values.probes.readiness.initialDelaySeconds }}
|
||||
failureThreshold: {{ .Values.probes.readiness.failureThreshold }}
|
||||
timeoutSeconds: {{ .Values.probes.readiness.timeoutSeconds }}
|
||||
{{ end }}
|
||||
{{- if .Values.probes.startup.enabled }}
|
||||
startupProbe:
|
||||
httpGet:
|
||||
path: /
|
||||
port: dns-webserver
|
||||
failureThreshold: {{ .Values.probes.startup.failureThreshold }}
|
||||
periodSeconds: {{ .Values.probes.startup.periodSeconds }}
|
||||
{{ end }}
|
||||
{{- if .Values.mariadb.enabled }}
|
||||
lifecycle:
|
||||
postStart:
|
||||
exec:
|
||||
command: ["/bin/sh", "-c", "a=0;while [ $a -lt 200 ];do sleep 5;a=$[a+1];echo 'stage: '$a;if nc -vz {{ .Values.powerdns.mysql.host }} 3306;then (! pdnsutil list-zone {{ .Values.powerdns.domain }} 2>/dev/null) && pdnsutil create-zone {{ .Values.powerdns.domain }};echo 'End Stage';a=200;fi;done"]
|
||||
{{ end }}
|
||||
{{- if .Values.postgres.enabled }}
|
||||
lifecycle:
|
||||
postStart:
|
||||
exec:
|
||||
command: ["/bin/sh", "-c", "a=0;while [ $a -lt 200 ];do sleep 5;a=$[a+1];echo 'stage: '$a;if nc -vz {{ .Values.powerdns.postgres.host }} 5432;then (! pdnsutil list-zone {{ .Values.powerdns.domain }} 2>/dev/null) && pdnsutil create-zone {{ .Values.powerdns.domain }};echo 'End Stage';a=200;fi;done"]
|
||||
{{ end }}
|
||||
resources:
|
||||
{{- toYaml .Values.resources | nindent 12 }}
|
||||
volumes:
|
||||
- name: config
|
||||
configMap:
|
||||
name: {{ template "powerdns.fullname" . }}
|
||||
{{- with .Values.nodeSelector }}
|
||||
nodeSelector:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
{{- with .Values.affinity }}
|
||||
affinity:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
||||
{{- with .Values.tolerations }}
|
||||
tolerations:
|
||||
{{- toYaml . | nindent 8 }}
|
||||
{{- end }}
|
22
charts/powerdns/templates/secret.yaml
Executable file
22
charts/powerdns/templates/secret.yaml
Executable file
@ -0,0 +1,22 @@
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
name: {{ include "powerdns.fullname" . }}
|
||||
labels:
|
||||
{{ include "powerdns.labels" . | indent 4 }}
|
||||
type: Opaque
|
||||
data:
|
||||
{{- if .Values.postgres.enabled }}
|
||||
postgres_host: "{{ printf (include "powerdns.fullname" "-postgres" ) | b64enc }}"
|
||||
postgres_port: "{{ .Values.powerdns.postgres.port | toString | b64enc }}"
|
||||
postgres_username: "{{ .Values.powerdns.postgres.username | b64enc }}"
|
||||
postgres_password: "{{ .Values.powerdns.postgres.password | toString | b64enc }}"
|
||||
postgres_database: "{{ .Values.powerdns.postgres.database | b64enc }}"
|
||||
{{ end }}
|
||||
{{- if .Values.mariadb.enabled }}
|
||||
{{- $mysqltmp := printf "%s-%s" .Release.Name "mariadb"}}
|
||||
mysql_host: "{{ $mysqltmp | b64enc }}"
|
||||
mysql_username: "{{ .Values.powerdns.mysql.username | b64enc }}"
|
||||
mysql_password: "{{ .Values.powerdns.mysql.password | toString | b64enc }}"
|
||||
mysql_database: "{{ .Values.powerdns.mysql.database | b64enc }}"
|
||||
{{ end }}
|
81
charts/powerdns/templates/service.yaml
Executable file
81
charts/powerdns/templates/service.yaml
Executable file
@ -0,0 +1,81 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ include "powerdns.fullname" . }}-udp
|
||||
{{- if .Values.service.annotations }}
|
||||
annotations:
|
||||
{{ toYaml .Values.service.annotations | indent 4 }}
|
||||
{{- end }}
|
||||
labels:
|
||||
{{ include "powerdns.labels" . | indent 4 }}
|
||||
spec:
|
||||
type: {{ .Values.service.type }}
|
||||
{{ if .Values.service.loadBalancerIP }}
|
||||
loadBalancerIP: {{ .Values.service.loadBalancerIP }}
|
||||
{{ end }}
|
||||
{{- if .Values.service.externalIPs }}
|
||||
externalIPs:
|
||||
{{ toYaml .Values.service.externalIPs | indent 4 }}
|
||||
{{- end }}
|
||||
{{- if (.Values.service.externalTrafficPolicy) }}
|
||||
externalTrafficPolicy: "{{ .Values.service.externalTrafficPolicy }}"
|
||||
{{- end }}
|
||||
ports:
|
||||
- name: dns-udp
|
||||
port: 53
|
||||
protocol: UDP
|
||||
selector:
|
||||
app.kubernetes.io/name: {{ include "powerdns.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ include "powerdns.fullname" . }}-tcp
|
||||
{{- if .Values.service.annotations }}
|
||||
annotations:
|
||||
{{ toYaml .Values.service.annotations | indent 4 }}
|
||||
{{- end }}
|
||||
labels:
|
||||
{{ include "powerdns.labels" . | indent 4 }}
|
||||
spec:
|
||||
type: {{ .Values.service.type }}
|
||||
{{ if .Values.service.loadBalancerIP }}
|
||||
loadBalancerIP: {{ .Values.service.loadBalancerIP }}
|
||||
{{ end }}
|
||||
{{- if .Values.service.externalIPs }}
|
||||
externalIPs:
|
||||
{{ toYaml .Values.service.externalIPs | indent 4 }}
|
||||
{{- end }}
|
||||
{{- if (.Values.service.externalTrafficPolicy) }}
|
||||
externalTrafficPolicy: "{{ .Values.service.externalTrafficPolicy }}"
|
||||
{{- end }}
|
||||
ports:
|
||||
- name: dns-tcp
|
||||
port: 53
|
||||
protocol: TCP
|
||||
selector:
|
||||
app.kubernetes.io/name: {{ include "powerdns.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
{{ if (.Values.powerdns.api_key) }}
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: {{ include "powerdns.fullname" . }}-webserver
|
||||
{{- if .Values.service.annotations }}
|
||||
annotations:
|
||||
{{ toYaml .Values.service.annotations | indent 4 }}
|
||||
{{- end }}
|
||||
labels:
|
||||
{{ include "powerdns.labels" . | indent 4 }}
|
||||
spec:
|
||||
type: ClusterIP
|
||||
ports:
|
||||
- port: 8081
|
||||
targetPort: dns-webserver
|
||||
protocol: TCP
|
||||
selector:
|
||||
app.kubernetes.io/name: {{ include "powerdns.name" . }}
|
||||
app.kubernetes.io/instance: {{ .Release.Name }}
|
||||
{{- end }}
|
8
charts/powerdns/templates/serviceaccount.yaml
Executable file
8
charts/powerdns/templates/serviceaccount.yaml
Executable file
@ -0,0 +1,8 @@
|
||||
{{- if .Values.serviceAccount.create -}}
|
||||
apiVersion: v1
|
||||
kind: ServiceAccount
|
||||
metadata:
|
||||
name: {{ template "powerdns.serviceAccountName" . }}
|
||||
labels:
|
||||
{{ include "powerdns.labels" . | indent 4 }}
|
||||
{{- end -}}
|
108
charts/powerdns/values.yaml
Executable file
108
charts/powerdns/values.yaml
Executable file
@ -0,0 +1,108 @@
|
||||
# Default values for powerdns.
|
||||
# This is a YAML-formatted file.
|
||||
# Declare variables to be passed into your templates.
|
||||
|
||||
replicaCount: 1
|
||||
|
||||
image:
|
||||
repository: psitrax/powerdns
|
||||
tag: v4.3.0
|
||||
pullPolicy: Always
|
||||
|
||||
imagePullSecrets: []
|
||||
nameOverride: ""
|
||||
fullnameOverride: ""
|
||||
|
||||
serviceAccount:
|
||||
# Specifies whether a service account should be created
|
||||
create: true
|
||||
# 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:
|
||||
## Set external traffic policy to: "Local" to preserve source IP on
|
||||
## providers supporting it
|
||||
## Ref: https://kubernetes.io/docs/tutorials/services/source-ip/#source-ip-for-services-with-typeloadbalancer
|
||||
externalTrafficPolicy: ""
|
||||
type: ClusterIP
|
||||
port: 53
|
||||
|
||||
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: {}
|
||||
|
||||
powerdns:
|
||||
domain: mydomain.local
|
||||
postgres:
|
||||
host: powerdns-postgres
|
||||
port: 5432
|
||||
username: pdns
|
||||
password: pdnspass
|
||||
database: pdns
|
||||
mysql:
|
||||
host: powerdns-mariadb
|
||||
port: 3306
|
||||
username: pdns
|
||||
password: pdnspass
|
||||
database: pdns
|
||||
dnssec: true
|
||||
config: {}
|
||||
|
||||
mariadb:
|
||||
enabled: true
|
||||
db:
|
||||
name: pdns
|
||||
user: pdns
|
||||
password: pdnspass
|
||||
replication:
|
||||
enabled: false
|
||||
rootUser:
|
||||
password: pdnsrootpass
|
||||
master:
|
||||
persistence:
|
||||
enabled: false
|
||||
postgres:
|
||||
enabled: false
|
||||
|
||||
# Probes configuration
|
||||
probes:
|
||||
liveness:
|
||||
enabled: true
|
||||
initialDelaySeconds: 30
|
||||
failureThreshold: 5
|
||||
timeoutSeconds: 10
|
||||
readiness:
|
||||
enabled: true
|
||||
initialDelaySeconds: 30
|
||||
failureThreshold: 5
|
||||
timeoutSeconds: 10
|
||||
startup:
|
||||
enabled: false
|
||||
failureThreshold: 30
|
||||
periodSeconds: 10
|
Loading…
Reference in New Issue
Block a user