Installs pihole in kubernetes
Source code can be found here
Jeff Geerling on YouTube made a video about the installation of this chart:
helm repo add mojo2600 https://mojo2600.github.io/pihole-kubernetes/
helm repo update
The following items can be set via --set
flag during installation or configured by editing the values.yaml
directly.
- Ingress: The ingress controller must be installed in the Kubernetes cluster.
- ClusterIP: Exposes the service on a cluster-internal IP. Choosing this value makes the service only reachable from within the cluster.
- LoadBalancer: Exposes the service externally using a cloud provider’s load balancer.
dnsmasq:
customDnsEntries:
- address=/nas/192.168.178.10
persistentVolumeClaim:
enabled: true
serviceTCP:
loadBalancerIP: 192.168.178.252
annotations:
metallb.universe.tf/allow-shared-ip: pihole-svc
type: LoadBalancer
serviceUDP:
loadBalancerIP: 192.168.178.252
annotations:
metallb.universe.tf/allow-shared-ip: pihole-svc
type: LoadBalancer
To uninstall/delete the my-release
deployment:
helm delete --purge my-release
The following table lists the configurable parameters of the pihole chart and the default values.
Key | Type | Default | Description |
---|---|---|---|
DNS1 | string | "8.8.8.8" |
|
DNS2 | string | "8.8.4.4" |
|
adlists | object | {} |
|
admin.existingSecret | string | "" |
|
admin.passwordKey | string | "password" |
|
adminPassword | string | "admin" |
|
affinity | object | {} |
|
blacklist | object | {} |
|
dnsmasq.additionalHostsEntries | list | [] |
|
dnsmasq.customDnsEntries | list | [] |
|
doh.enabled | bool | false |
|
doh.name | string | "cloudflared" |
|
doh.pullPolicy | string | "IfNotPresent" |
|
doh.repository | string | "crazymax/cloudflared" |
|
doh.tag | string | "latest" |
|
doh.envVars | object | {} |
|
extraEnvVars | object | {} |
|
extraEnvVarsSecret | object | {} |
|
image.pullPolicy | string | "IfNotPresent" |
|
image.repository | string | "pihole/pihole" |
|
image.tag | string | "5.1.1" |
|
ingress.annotations | object | {} |
|
ingress.enabled | bool | false |
|
ingress.hosts[0] | string | "chart-example.local" |
|
ingress.path | string | "/" |
|
ingress.tls | list | [] |
|
nodeSelector | object | {} |
|
persistentVolumeClaim.accessModes[0] | string | "ReadWriteOnce" |
|
persistentVolumeClaim.annotations | object | {} |
|
persistentVolumeClaim.enabled | bool | false |
|
persistentVolumeClaim.existingClaim | bool | false |
|
persistentVolumeClaim.size | string | "500Mi" |
|
probes.liveness | object | {"enabled":true,"failureThreshold":10,"initialDelaySeconds":60,"timeoutSeconds":5} |
Configure the healthcheck for the ingress controller |
probes.readiness.enabled | bool | true |
|
probes.readiness.failureThreshold | int | 3 |
|
probes.readiness.initialDelaySeconds | int | 60 |
|
probes.readiness.timeoutSeconds | int | 5 |
|
regex | object | {} |
|
replicaCount | int | 1 |
|
resources | object | {} |
|
serviceTCP.annotations | object | {} |
|
serviceTCP.externalTrafficPolicy | string | "Local" |
|
serviceTCP.loadBalancerIP | string | "" |
|
serviceTCP.type | string | "NodePort" |
|
serviceUDP.annotations | object | {} |
|
serviceUDP.externalTrafficPolicy | string | "Local" |
|
serviceUDP.loadBalancerIP | string | "" |
|
serviceUDP.type | string | "NodePort" |
|
tolerations | list | [] |
|
whitelist | object | {} |
MetalLB 0.7.3 has a bug, where the service is not announced anymore, when the pod changes (e.g. update of a deployment). My workaround is to restart the metallb-speaker-*
pods.
pihole seems to work without issue in MetalLB 0.8.1+
Feel free to contribute by making a pull request.
Please read the official Contribution Guide from Helm for more information on how you can contribute to this Chart.