single traefik entrypoint
This commit is contained in:
42
README.md
42
README.md
@@ -55,6 +55,48 @@ spec:
|
|||||||
- name: httpsredirect
|
- name: httpsredirect
|
||||||
```
|
```
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: {{ .Release.Name }}-external-tls
|
||||||
|
annotations:
|
||||||
|
kubernetes.io/ingress.class: traefik-external
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
tls:
|
||||||
|
certResolver: myresolver
|
||||||
|
routes:
|
||||||
|
- match: Host(`jellyfin.ducoterra.net`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: {{ .Release.Name }}
|
||||||
|
port: 8096
|
||||||
|
middlewares:
|
||||||
|
- name: {{ .Release.Name }}
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: {{ .Release.Name }}-external-web
|
||||||
|
annotations:
|
||||||
|
kubernetes.io/ingress.class: traefik-external
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- web
|
||||||
|
routes:
|
||||||
|
- match: Host(`jellyfin.ducoterra.net`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: {{ .Release.Name }}
|
||||||
|
port: 8096
|
||||||
|
middlewares:
|
||||||
|
- name: httpsredirect
|
||||||
|
```
|
||||||
|
|
||||||
## Create a name.com secret for traefik to use:
|
## Create a name.com secret for traefik to use:
|
||||||
|
|
||||||
export USERNAME=
|
export USERNAME=
|
||||||
|
|||||||
53
example.yaml
Normal file
53
example.yaml
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: {{ .Release.Name }}-tls
|
||||||
|
annotations:
|
||||||
|
kubernetes.io/ingress.class: traefik
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
tls:
|
||||||
|
certResolver: duconet
|
||||||
|
routes:
|
||||||
|
- match: Host(`{{ .Release.Name }}.ducoterra.net`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: {{ .Release.Name }}
|
||||||
|
port: {{ .Values.service.port }}
|
||||||
|
---
|
||||||
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: {{ .Release.Name }}
|
||||||
|
annotations:
|
||||||
|
kubernetes.io/ingress.class: traefik
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- web
|
||||||
|
routes:
|
||||||
|
- match: Host(`{{ .Release.Name }}.ducoterra.net`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: {{ .Release.Name }}
|
||||||
|
port: {{ .Values.service.port }}
|
||||||
|
middlewares:
|
||||||
|
- name: httpsredirect-{{ .Release.Name }}
|
||||||
|
---
|
||||||
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
|
kind: Middleware
|
||||||
|
metadata:
|
||||||
|
name: httpsredirect-{{ .Release.Name }}
|
||||||
|
spec:
|
||||||
|
redirectScheme:
|
||||||
|
scheme: https
|
||||||
|
permanent: true
|
||||||
|
---
|
||||||
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
|
kind: Middleware
|
||||||
|
metadata:
|
||||||
|
name: basic-auth-{{ .Release.Name }}
|
||||||
|
spec:
|
||||||
|
basicAuth:
|
||||||
|
secret: authsecret
|
||||||
|
removeHeader: true
|
||||||
@@ -20,6 +20,7 @@ spec:
|
|||||||
- name: traefik
|
- name: traefik
|
||||||
image: {{ .Values.image }}
|
image: {{ .Values.image }}
|
||||||
args:
|
args:
|
||||||
|
- --providers.kubernetescrd
|
||||||
- --providers.kubernetescrd.ingressclass={{ .Values.config.ingressclass }}
|
- --providers.kubernetescrd.ingressclass={{ .Values.config.ingressclass }}
|
||||||
- --log.level=ERROR
|
- --log.level=ERROR
|
||||||
- --accesslog=true
|
- --accesslog=true
|
||||||
@@ -28,7 +29,6 @@ spec:
|
|||||||
- --entrypoints.web.address=:{{ .Values.config.http_port }}
|
- --entrypoints.web.address=:{{ .Values.config.http_port }}
|
||||||
- --entrypoints.websecure.address=:{{ .Values.config.https_port }}
|
- --entrypoints.websecure.address=:{{ .Values.config.https_port }}
|
||||||
- --entrypoints.websecure.http.tls=true
|
- --entrypoints.websecure.http.tls=true
|
||||||
- --providers.kubernetescrd
|
|
||||||
{{ if .Values.enable.statsd }}
|
{{ if .Values.enable.statsd }}
|
||||||
- --metrics.statsd=true
|
- --metrics.statsd=true
|
||||||
- --metrics.statsd.address={{ .Values.config.statsd_endpoint }}
|
- --metrics.statsd.address={{ .Values.config.statsd_endpoint }}
|
||||||
@@ -37,16 +37,16 @@ spec:
|
|||||||
- --metrics.statsd.prefix={{ .Release.Name }}
|
- --metrics.statsd.prefix={{ .Release.Name }}
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .Values.enable.dnschallenge }}
|
{{ if .Values.enable.dnschallenge }}
|
||||||
- --certificatesresolvers.myresolver.acme.dnschallenge=true
|
- --certificatesresolvers.duconet.acme.dnschallenge=true
|
||||||
- --certificatesresolvers.myresolver.acme.dnschallenge.provider={{ .Values.config.dnschallenge_provider }}
|
- --certificatesresolvers.duconet.acme.dnschallenge.provider={{ .Values.config.dnschallenge_provider }}
|
||||||
- --certificatesresolvers.myresolver.acme.email={{ .Values.config.acme_email }}
|
- --certificatesresolvers.duconet.acme.email={{ .Values.config.acme_email }}
|
||||||
- --certificatesresolvers.myresolver.acme.storage=/acme/acme.json
|
- --certificatesresolvers.duconet.acme.storage=/acme/acme.json
|
||||||
- --certificatesresolvers.myresolver.acme.dnschallenge.resolvers=1.1.1.1
|
- --certificatesresolvers.duconet.acme.dnschallenge.resolvers=1.1.1.1
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .Values.enable.tlschallenge }}
|
{{ if .Values.enable.tlschallenge }}
|
||||||
- --certificatesresolvers.myresolver.acme.tlschallenge
|
- --certificatesresolvers.duconet.acme.tlschallenge
|
||||||
- --certificatesresolvers.myresolver.acme.email={{ .Values.config.acme_email }}
|
- --certificatesresolvers.duconet.acme.email={{ .Values.config.acme_email }}
|
||||||
- --certificatesresolvers.myresolver.acme.storage=/acme/acme.json
|
- --certificatesresolvers.duconet.acme.storage=/acme/acme.json
|
||||||
{{ end }}
|
{{ end }}
|
||||||
{{ if .Values.enable.tracing }}
|
{{ if .Values.enable.tracing }}
|
||||||
- --tracing=true
|
- --tracing=true
|
||||||
|
|||||||
@@ -4,40 +4,18 @@ metadata:
|
|||||||
name: {{ .Release.Name }}-tls
|
name: {{ .Release.Name }}-tls
|
||||||
namespace: kube-system
|
namespace: kube-system
|
||||||
annotations:
|
annotations:
|
||||||
kubernetes.io/ingress.class: traefik-internal
|
kubernetes.io/ingress.class: traefik
|
||||||
spec:
|
spec:
|
||||||
entryPoints:
|
entryPoints:
|
||||||
- websecure
|
- websecure
|
||||||
tls:
|
tls:
|
||||||
certResolver: myresolver
|
certResolver: duconet
|
||||||
domains:
|
|
||||||
- main: "*.ducoterra.net"
|
|
||||||
routes:
|
routes:
|
||||||
- match: Host(`{{ .Release.Name }}.ducoterra.net`)
|
- match: Host(`{{ .Release.Name }}.ducoterra.net`)
|
||||||
kind: Rule
|
kind: Rule
|
||||||
services:
|
services:
|
||||||
- name: {{ .Release.Name }}-admin
|
- name: {{ .Release.Name }}-admin
|
||||||
port: 8080
|
port: {{ .Values.config.admin_port }}
|
||||||
middlewares:
|
middlewares:
|
||||||
- name: basic-auth
|
- name: basic-auth
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
apiVersion: traefik.containo.us/v1alpha1
|
|
||||||
kind: IngressRoute
|
|
||||||
metadata:
|
|
||||||
name: {{ .Release.Name }}-web
|
|
||||||
namespace: kube-system
|
|
||||||
annotations:
|
|
||||||
kubernetes.io/ingress.class: traefik-internal
|
|
||||||
spec:
|
|
||||||
entryPoints:
|
|
||||||
- web
|
|
||||||
routes:
|
|
||||||
- match: Host(`{{ .Release.Name }}.ducoterra.net`)
|
|
||||||
kind: Rule
|
|
||||||
services:
|
|
||||||
- name: {{ .Release.Name }}-admin
|
|
||||||
port: 8080
|
|
||||||
middlewares:
|
|
||||||
- name: httpsredirect
|
- name: httpsredirect
|
||||||
@@ -34,6 +34,14 @@ rules:
|
|||||||
- ingresses/status
|
- ingresses/status
|
||||||
verbs:
|
verbs:
|
||||||
- update
|
- update
|
||||||
|
- apiGroups:
|
||||||
|
- networking.k8s.io
|
||||||
|
resources:
|
||||||
|
- ingressclasses
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
- apiGroups:
|
- apiGroups:
|
||||||
- traefik.containo.us
|
- traefik.containo.us
|
||||||
resources:
|
resources:
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
{{ if .Values.install.resourcedefinition }}
|
|
||||||
# All resources definition must be declared
|
# All resources definition must be declared
|
||||||
apiVersion: apiextensions.k8s.io/v1beta1
|
apiVersion: apiextensions.k8s.io/v1beta1
|
||||||
kind: CustomResourceDefinition
|
kind: CustomResourceDefinition
|
||||||
@@ -102,5 +101,4 @@ spec:
|
|||||||
kind: TraefikService
|
kind: TraefikService
|
||||||
plural: traefikservices
|
plural: traefikservices
|
||||||
singular: traefikservice
|
singular: traefikservice
|
||||||
scope: Namespaced
|
scope: Namespaced
|
||||||
{{ end }}
|
|
||||||
2
upgrade.sh
Executable file
2
upgrade.sh
Executable file
@@ -0,0 +1,2 @@
|
|||||||
|
helm --kube-context mainframe-admin upgrade --install traefik ./helm --values values.yaml
|
||||||
|
kubectl --context mainframe-admin get pod -w
|
||||||
23
values.yaml
Normal file
23
values.yaml
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
image: traefik:v2.3.2
|
||||||
|
|
||||||
|
enable:
|
||||||
|
dnschallenge: false
|
||||||
|
tlschallenge: true
|
||||||
|
tracing: false
|
||||||
|
statsd: false
|
||||||
|
|
||||||
|
middleware:
|
||||||
|
basicauth: true
|
||||||
|
redirectscheme: true
|
||||||
|
stricttransport: true
|
||||||
|
|
||||||
|
config:
|
||||||
|
ingressclass: traefik
|
||||||
|
http_port: 9080
|
||||||
|
https_port: 9443
|
||||||
|
admin_port: 8080
|
||||||
|
# statsd reporting
|
||||||
|
statsd_endpoint: graphite.ducoterra.net:8125
|
||||||
|
acme_email: ducoterra@icloud.com
|
||||||
|
# zipkin tracing
|
||||||
|
tracing_endpoint: http://zipkin:9411/api/v2/spans
|
||||||
Reference in New Issue
Block a user