Traefik-默认证书、Middleware、Ingressroute

该文详细介绍了如何在Traefik中配置默认证书、实现HTTP到HTTPS的自动重定向、处理带路径的域名以及设置TLS选项。通过创建TLSStore、Middleware和IngressRoute资源,可以管理证书、设定路径处理规则并强制执行TLS版本策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.默认证书

apiVersion: traefik.containo.us/v1alpha1
kind: TLSStore
metadata:
  name: default
  namespace: default

spec:
  defaultCertificate:
    secretName: default-certificate

---
apiVersion: v1
kind: Secret
metadata:
  name: default-certificate
  namespace: default

type: Opaque
data:
  tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
  tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=

2.Middleware

2.1 http转https

apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
  name: redirect-https
  namespace: test
spec:
  redirectScheme:
    scheme: https

2.2 指定带路径的域名

apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
  name: common-api-gateway
  namespace: test
spec:
  stripPrefix:
    prefixes:
      - "/api/"

2.3 TLSoption

apiVersion: traefik.containo.us/v1alpha1
kind: TLSOption
metadata:
  name: mintls12
  namespace: nginx-test
spec:
  minVersion: VersionTLS12

2.4 不同域名跳转

apiVersion: traefik.containo.us/v1alpha1
kind: Middleware
metadata:
  name: rewriteurl
  namespace: test
spec:
  redirectRegex:
    regex: ^https://test.com/(.*)
    replacement: https://www.test.com/${1}

3.IngressRoute

3.1 http

apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
  name: ingress-common-http
  namespace: test
spec:
  entryPoints:
  - web
  routes:
    - kind: Rule
      match: Host(`nginx.test.com`) && PathPrefix(`/`)
      services:
        - name: nginx-test1-service
          port: 80
    - kind: Rule
      match: Host(`nginx.test.com`) && PathPrefix(`/api/`)
      services:
        - name: nginx-test2-service
          port: 8080
      middlewares:
        - name: "common-api-gateway"
        - name: redirect-https

3.2 https

apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
  name: ingress-common-https
  namespace: test
spec:
  entryPoints:
  - websecure
  routes:
    - kind: Rule
      match: Host(`nginx.test.com`) && PathPrefix(`/`)
      services:
        - name: nginx-test1-service
          port: 80

    - kind: Rule
      match: Host(`nginx.test.com`) && PathPrefix(`/api/`)
      services:
        - name: nginx-test2-service
          port: 8080
      middlewares:
        - name: "common-api-gateway"
  tls:
    secretName: nginx-test
    options:
      name: mintls12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值