infrastructure/external-dns.yaml

152 lines
4 KiB
YAML
Raw Normal View History

# External DNS service account
apiVersion: kubernetes.crossplane.io/v1alpha2
kind: Object
metadata:
name: external-dns-sa
namespace: crossplane-system
spec:
providerConfigRef:
name: kubernetes-provider
forProvider:
manifest:
apiVersion: v1
kind: ServiceAccount
metadata:
name: external-dns
namespace: external-dns
---
# External DNS cluster role
apiVersion: kubernetes.crossplane.io/v1alpha2
kind: Object
metadata:
name: external-dns-clusterrole
namespace: crossplane-system
spec:
providerConfigRef:
name: kubernetes-provider
forProvider:
manifest:
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: external-dns
rules:
- apiGroups: [""]
resources: ["services", "endpoints", "pods"]
verbs: ["get", "watch", "list"]
- apiGroups: ["extensions", "networking.k8s.io"]
resources: ["ingresses"]
verbs: ["get", "watch", "list"]
- apiGroups: ["getambassador.io"]
resources: ["hosts", "mappings"]
verbs: ["get", "watch", "list"]
- apiGroups: [""]
resources: ["nodes"]
verbs: ["list", "watch"]
---
# External DNS cluster role binding
apiVersion: kubernetes.crossplane.io/v1alpha2
kind: Object
metadata:
name: external-dns-clusterrolebinding
namespace: crossplane-system
spec:
providerConfigRef:
name: kubernetes-provider
forProvider:
manifest:
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: external-dns
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: external-dns
subjects:
- kind: ServiceAccount
name: external-dns
namespace: external-dns
---
# External DNS Gandi API key secret
apiVersion: kubernetes.crossplane.io/v1alpha2
kind: Object
metadata:
name: external-dns-gandi-secret
namespace: crossplane-system
spec:
providerConfigRef:
name: kubernetes-provider
forProvider:
manifest:
apiVersion: v1
kind: Secret
metadata:
name: gandi-api-key
namespace: external-dns
type: Opaque
stringData:
api-key: "5ea1e058de81926ad37af59374756eb69f7e24af"
---
# External DNS deployment
apiVersion: kubernetes.crossplane.io/v1alpha2
kind: Object
metadata:
name: external-dns-deployment
namespace: crossplane-system
spec:
providerConfigRef:
name: kubernetes-provider
forProvider:
manifest:
apiVersion: apps/v1
kind: Deployment
metadata:
name: external-dns
namespace: external-dns
spec:
strategy:
type: Recreate
selector:
matchLabels:
app: external-dns
template:
metadata:
labels:
app: external-dns
spec:
serviceAccountName: external-dns
containers:
- name: external-dns
image: registry.k8s.io/external-dns/external-dns:v0.15.0
args:
- --source=service
- --source=ingress
- --source=ambassador-host
- --domain-filter=nge6.com
- --provider=gandi
- --registry=txt
- --txt-owner-id=external-dns
- --txt-prefix=external-dns-
- --log-level=debug
- --log-format=text
env:
- name: GANDI_PAT
valueFrom:
secretKeyRef:
name: gandi-api-key
key: api-key
resources:
limits:
cpu: 100m
memory: 128Mi
requests:
cpu: 50m
memory: 64Mi
securityContext:
runAsNonRoot: true
runAsUser: 65534
readOnlyRootFilesystem: true
allowPrivilegeEscalation: false
capabilities:
drop: ["ALL"]