helmchartconfig.yaml 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. apiVersion: helm.cattle.io/v1
  2. kind: HelmChartConfig
  3. metadata:
  4. name: traefik
  5. namespace: kube-system
  6. spec:
  7. valuesContent: |-
  8. additionalArguments:
  9. - "--entrypoints.websecure.proxyProtocol.trustedIPs=127.0.0.1/32,172.16.69.0/24"
  10. - "--entrypoints.web.http.redirections.entryPoint.to=:443"
  11. - "--entrypoints.web.http.redirections.entrypoint.scheme=https"
  12. # Auto cert renewal via cloudflare
  13. - "--certificatesresolvers.letsencrypt.acme.email=joshbicking@comcast.net"
  14. - "--certificatesresolvers.letsencrypt.acme.storage=/data/acme.json"
  15. - "--certificatesresolvers.letsencrypt.acme.dnschallenge.provider=cloudflare"
  16. - "--certificatesresolvers.letsencrypt.acme.dnschallenge.resolvers=1.1.1.1:53,8.8.8.8:53"
  17. - "--entrypoints.websecure.http.tls.certResolver=letsencrypt"
  18. # Main
  19. - "--entrypoints.websecure.http.tls.domains[0].main=jibby.org"
  20. - "--entrypoints.websecure.http.tls.domains[0].sans=*.jibby.org"
  21. # LAN-only
  22. - "--entrypoints.websecure.http.tls.domains[1].main=lan.jibby.org"
  23. - "--entrypoints.websecure.http.tls.domains[1].sans=*.lan.jibby.org"
  24. # Configuration for extra routers
  25. - "--providers.file.directory=/config"
  26. - "--log.level=INFO"
  27. # debug, uncomment for testing
  28. #- "--log.level=DEBUG"
  29. #- "--certificatesresolvers.letsencrypt.acme.caServer=https://acme-staging-v02.api.letsencrypt.org/directory"
  30. volumes:
  31. - name: traefik-config
  32. mountPath: "/config"
  33. type: configMap
  34. env:
  35. - name: CLOUDFLARE_EMAIL
  36. valueFrom:
  37. secretKeyRef:
  38. name: cloudflare-secrets
  39. key: email
  40. optional: false
  41. - name: CLOUDFLARE_API_KEY
  42. valueFrom:
  43. secretKeyRef:
  44. name: cloudflare-secrets
  45. key: api-key
  46. optional: false
  47. persistence:
  48. enabled: true
  49. storageClass: ceph-block-ssd
  50. metrics:
  51. prometheus:
  52. addServicesLabels: true
  53. # Fix for acme.json file being changed to 660 from 600
  54. # This can manifest as the incredibly unhelpful "the router <router name> uses a non-existent resolver: <resolver name>"
  55. # https://github.com/traefik/traefik/issues/10241
  56. podSecurityContext:
  57. fsGroup: 65532
  58. deployment:
  59. initContainers:
  60. # The "volume-permissions" init container is required if you run into permission issues.
  61. # Related issue: https://github.com/traefik/traefik-helm-chart/issues/396
  62. - name: volume-permissions
  63. image: busybox:latest
  64. command: ["sh", "-c", "touch /data/acme.json; chmod -v 600 /data/acme.json"]
  65. securityContext:
  66. runAsNonRoot: true
  67. runAsGroup: 65532
  68. runAsUser: 65532
  69. volumeMounts:
  70. - name: data
  71. mountPath: /data
  72. # ACME functionality is not supported when running Traefik as a DaemonSet
  73. #deployment:
  74. # kind: DaemonSet
  75. service:
  76. spec:
  77. # Required to show real IP to proxied services
  78. externalTrafficPolicy: Local
  79. providers:
  80. kubernetesCRD:
  81. # Allows IngressRoutes to use middleware from a different namespace
  82. allowCrossNamespace: true
  83. # pin pod to cluster-ingress node, so ServiceLB gives it the right external IP
  84. affinity:
  85. nodeAffinity:
  86. requiredDuringSchedulingIgnoredDuringExecution:
  87. nodeSelectorTerms:
  88. - matchExpressions:
  89. - key: cluster-ingress
  90. operator: In
  91. values:
  92. - "true"