Skip to content

Network notes

Currently just some notes about network installation.

bash
export NETWORK_NAMESPACE=network-system

Install Metallb

Update IP-Pool in metallb-pool.yaml

yaml
apiVersion: metallb.io/v1beta1
kind: IPAddressPool
metadata:
  name: pool
  namespace: network-system
spec:
  addresses:
  - 10.25.10.101-10.25.10.119
yaml
apiVersion: metallb.io/v1beta1
kind: L2Advertisement
metadata:
  name: l2-ip
  namespace: network-system
spec:
  ipAddressPools:
  - pool
bash
helm repo add bitnami https://charts.bitnami.com/bitnami && helm repo update
helm upgrade --install -n ${NETWORK_NAMESPACE} metallb bitnami/metallb --set fullnameOverride=metallb
kubectl apply -f metallb-pool.yaml -n ${NETWORK_NAMESPACE}
kubectl apply -f metallb-l2advertisements.yaml -n ${NETWORK_NAMESPACE}

Install Ingress-Nginx

ingress-values.yaml

yaml
nameOverride: ingress-nginx
fullnameOverride: ingress-nginx

controller:
  kind: DaemonSet

  service:
     externalTrafficPolicy: "Local"

  config:
    allow-snippet-annotations: "true"
    hsts: "true"
    hsts-include-subdomains: "true"
    hsts-max-age: "31536000"

  resources:
    requests:
      cpu: 10m
      memory: 100Mi

  ingressClassResource:
    name: nginx
    enabled: true
    default: true
    controllerValue: "k8s.io/ingress-nginx"
bash
helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx && helm repo update
helm upgrade --install -n ${NETWORK_NAMESPACE} ingress ingress-nginx/ingress-nginx -f ingress-values.yaml

Install External DNS, Cert-Manager, Cloudflare DDNS

Stuff needed from Cloudflare:

  • Cloudflare Token with edit rights for the zone
  • ZoneId
  • Email Address

Update:

  • cloudflare-ddns.yaml
  • cluster-issuer.yaml
  • external-dns-values.yaml
bash
kubectl create secret generic cloudflare-secret --from-literal=cloudflare_api_token=<your-cloudflare-api-key> -n ${NETWORK_NAMESPACE}

external-dns-values.yaml

yaml
fullnameOverride: external-dns
crd:
  create: true
sources:
- crd
- service
- ingress
logLevel: debug
policy: sync
registry: txt
# annotationFilter: "external-dns.alpha.kubernetes.io/target"
txtOwnerId: default
provider: cloudflare
cloudflare:
  secretName: cloudflare-secret
  proxied: false
domainFilters:
- amazing.host
resources:
  requests:
    cpu: 50m
    memory: 64Mi
bash
helm upgrade --install -n ${NETWORK_NAMESPACE} external-dns bitnami/external-dns -f external-dns-values.yaml
json
{
    "cloudflare": [
      {
        "authentication": {
          "api_token": "<INSERT CLOUDFLARE TOKEN>"
        },
        "zone_id": "<INSERT CLOUDFLARE ZONE ID>",
        "subdomains": [
          {
            "name": "dynamic",
            "proxied": false
          }
        ]
      }
    ],
    "a": true,
    "aaaa": true,
    "purgeUnknownRecords": false,
    "ttl": 300
}
bash
kubectl create secret generic config-cloudflare-ddns --from-file=config.json=cloudflare-ddns-config.json -n ${NETWORK_NAMESPACE}
kubectl apply -f cloudflare-ddns.yaml -n ${NETWORK_NAMESPACE}

cluster-issuer.yaml

yaml
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
  name: letsencrypt-prod
spec:
  acme:
    email: <INSERT EMAIL>
    server: https://acme-v02.api.letsencrypt.org/directory
    privateKeySecretRef:
      name: letsencrypt-prod
    solvers:
    - dns01:
        cloudflare:
          email: <INSERT EMAIL>
          apiTokenSecretRef:
            name: cloudflare-secret
            key: cloudflare_api_token
---
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
  name: selfsigned
spec:
  selfSigned: {}

cert-manager-values.yaml

yaml
fullnameOverride: cert-manager
installCRDs: true
ingressShim:
  defaultIssuerKind: ClusterIssuer
  defaultIssuerName: letsencrypt-prod
bash
helm repo add jetstack https://charts.jetstack.io --force-update && helm repo update
helm upgrade --install -n ${NETWORK_NAMESPACE} cert-manager jetstack/cert-manager -f cert-manager-values.yaml
kubectl apply -f cluster-issuer.yaml

Resources:

cert-manager-values.yaml

yaml
fullnameOverride: cert-manager
installCRDs: true
ingressShim:
  defaultIssuerKind: ClusterIssuer
  defaultIssuerName: letsencrypt-prod

cloudflare-ddns-config.json

json
{
    "cloudflare": [
      {
        "authentication": {
          "api_token": "<INSERT CLOUDFLARE TOKEN>"
        },
        "zone_id": "<INSERT CLOUDFLARE ZONE ID>",
        "subdomains": [
          {
            "name": "dynamic",
            "proxied": false
          }
        ]
      }
    ],
    "a": true,
    "aaaa": true,
    "purgeUnknownRecords": false,
    "ttl": 300
  }

cloudflare-ddns.yaml

yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: cloudflare-ddns
spec:
  selector:
    matchLabels:
      app: cloudflare-ddns
  template:
    metadata:
      labels:
        app: cloudflare-ddns
    spec:
      containers:
        - name: cloudflare-ddns
          image: timothyjmiller/cloudflare-ddns:latest
          resources:
            limits:
              memory: '32Mi'
              cpu: '50m'
          env:
            - name: CONFIG_PATH
              value: '/etc/cloudflare-ddns/'
          volumeMounts:
            - mountPath: '/etc/cloudflare-ddns'
              name: config-cloudflare-ddns
              readOnly: true
      volumes:
        - name: config-cloudflare-ddns
          secret:
            secretName: config-cloudflare-ddns

cluster-issuer.yaml

yaml
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
  name: letsencrypt-prod
spec:
  acme:
    email: <INSERT EMAIL>
    server: https://acme-v02.api.letsencrypt.org/directory
    privateKeySecretRef:
      name: letsencrypt-prod
    solvers:
    - dns01:
        cloudflare:
          email: <INSERT EMAIL>
          apiTokenSecretRef:
            name: cloudflare-secret
            key: cloudflare_api_token
---
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
  name: selfsigned
spec:
  selfSigned: {}

external-dns-values.yaml

yaml
fullnameOverride: external-dns
crd:
  create: true
sources:
- crd
- service
- ingress
logLevel: debug
policy: sync
registry: txt
# annotationFilter: "external-dns.alpha.kubernetes.io/target"
txtOwnerId: default
provider: cloudflare
cloudflare:
  secretName: cloudflare-secret
  proxied: false
domainFilters:
- emporium.host
resources:
  requests:
    cpu: 50m
    memory: 64Mi

ingress-values.yaml

yaml
nameOverride: ingress-nginx
fullnameOverride: ingress-nginx
controller:
  replicaCount: 3
  resources:
    requests:
      cpu: 10m
      memory: 100Mi
  ingressClassResource:
    name: nginx
    enabled: true
    default: true
    controllerValue: "k8s.io/ingress-nginx"

metallb-pool.yaml

yaml
apiVersion: metallb.io/v1beta1
kind: IPAddressPool
metadata:
  name: default-pool
spec:
  addresses:
  - 10.25.10.101-10.25.10.119

metallb-l2advertisements.yaml

yaml
apiVersion: metallb.io/v1beta1
kind: L2Advertisement
metadata:
  name: l2-ip
  namespace: network-system
spec:
  ipAddressPools:
  - default-pool