https 重定向到 http 然后重定向到 https

如何解决https 重定向到 http 然后重定向到 https

我在 EKS 中运行了一个应用程序。 Istio 用作 ServiceMesh。我在将 https 重定向到 http 然后再重定向到 https 时遇到了一些问题。看起来问题出在 istio 虚拟服务上,它会暂时切换到我想阻止的 http。

Curl output

我们就是这样安装 istio [安装的版本是 1.5.1]

istioctl -n infrastructure manifest apply \
 --set profile=default --set values.kiali.enabled=true \
 --set values.gateways.istio-ingressgateway.enabled=true \
 --set values.gateways.enabled=true \
 --set values.gateways.istio-ingressgateway.type=NodePort \
 --set values.global.k8sIngress.enabled=false \
 --set values.global.k8sIngress.gatewayName=ingressgateway \
 --set values.global.proxy.accessLogFile="/dev/stdout" 

这是我们的虚拟服务。集群包含两个部署:

  1. myapps-front
  2. myapps-api
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
Metadata:
  name: dev-sanojapps-virtual-service
  namespace: istio-system
spec:
  hosts:
    - "dev-mydomain.com"
  gateways:
    - ingressgateway
  http:
    - match:
        - uri:
            prefix: /myapp/
        - uri:
            prefix: /myapp
      rewrite:
        uri: /
      route:
        - destination:
              host: myapp-front.sanojapps-dev.svc.cluster.local
          headers:
            request:
              set:
                "X-Forwarded-Proto": "https"
                "X-Forwarded-Port": "443"
            response:
              set:
                Strict-Transport-Security: max-age=31536000; includeSubDomains
    - match:
        - uri:
            prefix: /v1/myapp-api/
        - uri:
            prefix: /v1/myapp-api
      rewrite:
        uri: /
      route:
        - destination:
            host: myapp-api.sanojapps-dev.svc.cluster.local
            port:
              number: 8080
    - match:
        - uri:
            prefix: /
      redirect:
        uri: /myapp/
        https_redirect: true
      headers:
            request:
              set:
                "X-Forwarded-Proto": "https"
                "X-Forwarded-Port": "443"
            response:
              set:
                Strict-Transport-Security: max-age=31536000; includeSubDomains

以下是前端应用 yaml 部署。

apiVersion: apps/v1
kind: Deployment
Metadata:
  name: myapp-front
  namespace: sanojapps-dev
  labels:
    app: myapp-front
spec:
  selector:
    matchLabels:
      app: myapp-front
  template:
    Metadata:
      labels:
        app: myapp-front
    spec:
      containers:
      - name: myapp-front
        image: <ECR_REPO:TAG>
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 80
          name: http
          protocol: TCP
        resources:
          limits:
            cpu: 500m
            memory: 1024Mi
          requests:
            cpu: 50m
            memory: 256Mi

我们的网关配置如下:

apiVersion: extensions/v1beta1
kind: Ingress
Metadata:
  namespace: istio-system
  name: sanojapps-ingress
  annotations:
    kubernetes.io/ingress.class: alb
    alb.ingress.kubernetes.io/scheme: internet-facing
    alb.ingress.kubernetes.io/subnets: ""
    alb.ingress.kubernetes.io/certificate-arn: arn:aws:acm:region:account:certificate/<ACM_ID>
    alb.ingress.kubernetes.io/listen-ports: '[{"HTTP": 80},{"HTTPS":443}]'
    alb.ingress.kubernetes.io/actions.ssl-redirect: '{"Type": "redirect","RedirectConfig": { "Protocol": "HTTPS","Port": "443","StatusCode": "HTTP_301"}}'
    alb.ingress.kubernetes.io/ssl-policy: ELBSecurityPolicy-FS-1-2-2019-08
    alb.ingress.kubernetes.io/wafv2-acl-arn: arn:aws:wafv2:region:account:regional/webacl/sanojapps-acl/<ACM_ID>
spec:
  rules:
    - http:
        paths:
         - path: /*
           backend:
             serviceName: ssl-redirect
             servicePort: use-annotation
         - path: /*
           backend:
             serviceName: istio-ingressgateway
             servicePort: 80
             

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?