istio流量转移

  1. istio安装部署:
    https://blog.csdn.net/weixin_43606975/article/details/126582211?spm=1001.2014.3001.5502

2种方案可以行:

  1. 方案一创建2个svc不使用DestinationRule:
    2.1 创建yaml
#cat bookinfo-gateway.yaml
apiVersion: networking.istio.io/v1alpha3
kind: Gateway
metadata:
  name: bookinfo-gateway
spec:
  selector:
    istio: ingressgateway # use istio default controller
  servers:
  - port:
      number: 80
      name: http
      protocol: HTTP
    hosts:
    - "*"
---
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
  name: bookinfo
spec:
  hosts:
  - "*"
  gateways:
  - bookinfo-gateway
  http:
  - match:
    - uri:
        exact: /
    route:
    - destination:
        host: productpage-v1
        port:
          number: 8080
      #  subset: v1
  - match:
    - uri:
        exact: /123
    route:
    - destination:
        host: productpage-v2
        port:
          number: 8080
     #   subset: v2

#cat v1-deployment.yaml
apiVersion: v1
kind: Service
metadata:
  name: productpage-v1
  labels:
    app: productpage
    service: productpagev1
spec:
  ports:
  - port: 8080
    name: http
  selector:
    app: productpagev1
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: productpage-v1
  labels:
    app: productpagev1
    version: v1
spec:
  replicas: 1
  selector:
    matchLabels:
      app: productpagev1
      version: v1
  template:
    metadata:
      labels:
        app: productpagev1
        version: v1
    spec:
      containers:
      - name: productpage
        image: argoproj/rollouts-demo:blue
        ports:
        - name: http
          containerPort: 8080
          protocol: TCP
        resources:
          requests:
            memory: 32Mi
            cpu: 5m

---

kind: Service
metadata:
  name: productpage-v2
  labels:
    app: productpagev2
    service: productpagev2
spec:
  ports:
  - port: 8080
    name: http
  selector:
    app: productpagev2
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: productpage-v2
  labels:
    app: productpagev2
    version: v2
spec:
  replicas: 1
  selector:
    matchLabels:
      app: productpagev2
      version: v2
  template:
    metadata:
      labels:
        app: productpagev2
        version: v2
    spec:
      containers:
      - name: productpage
        image: tomcat
        ports:
        - name: http
          containerPort: 8080
          protocol: TCP
        resources:
          requests:
            memory: 32Mi
            cpu: 5m

---

启动:

kubectl apply -f ./

访问:lb地址/123 到tomcat
在这里插入图片描述
访问:lb地址/ 到argo
在这里插入图片描述

  1. 方式二一个svc,2个deployment使用DestinationRule:
    3.1 yaml文件:
#cat bookinfo-gateway.yaml
apiVersion: networking.istio.io/v1alpha3
kind: Gateway
metadata:
  name: bookinfo-gateway
spec:
  selector:
    istio: ingressgateway # use istio default controller
  servers:
  - port:
      number: 80
      name: http
      protocol: HTTP
    hosts:
    - "*"
---
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
  name: bookinfo
spec:
  hosts:
  - "*"
  gateways:
  - bookinfo-gateway
  http:
  - match:
    - uri:
        exact: /
    route:
    - destination:
        host: productpage-v1
     #   host: rollout-destrule
       # port:
        #  number: 8080
        subset: v1
  - match:
    - uri:
        exact: /123
    route:
    - destination:
        host: productpage-v1
       # port:
       #   number: 8080
        subset: v2

#cat v1-deployment.yaml
apiVersion: v1
kind: Service
metadata:
  name: productpage-v1
  labels:
    app: productpage
    service: productpage
spec:
  ports:
  - port: 8080
    name: http
  selector:
    app: productpage
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: productpage-v1
  labels:
    app: productpage
    version: v1
spec:
  replicas: 1
  selector:
    matchLabels:
      app: productpage
      version: v1
  template:
    metadata:
      labels:
        app: productpage
        version: v1
    spec:
      containers:
      - name: productpage
        image: argoproj/rollouts-demo:blue
        ports:
        - name: http
          containerPort: 8080
          protocol: TCP
        resources:
          requests:
            memory: 32Mi
            cpu: 5m

---

#cat v2-deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: productpage-v2
  labels:
    app: productpage
    version: v2
spec:
  replicas: 1
  selector:
    matchLabels:
      app: productpage
      version: v2
  template:
    metadata:
      labels:
        app: productpage
        version: v2
    spec:
      containers:
      - name: productpage
        image: tomcat
        ports:
        - name: http
          containerPort: 8080
          protocol: TCP
        resources:
          requests:
            memory: 32Mi
            cpu: 5m

---

#cat dr.yaml
apiVersion: networking.istio.io/v1alpha3
kind: DestinationRule
metadata:
  name: rollout-destrule
spec:
  host: productpage-v1
  subsets:
  - name: v1   # referenced in canary.trafficRouting.istio.destinationRule.canarySubsetName
    labels:        # labels will be injected with canary rollouts-pod-template-hash value
      version: v1
  - name: v2   # referenced in canary.trafficRouting.istio.destinationRule.stableSubsetName
    labels:        # labels will be injected with stable rollouts-pod-template-hash value
      version: v2


启动:

kubectl apply -f ./

访问:lb地址/123 到tomcat
在这里插入图片描述
访问:lb地址/ 到argo
在这里插入图片描述
当然可以在VirtualService中加上权重实现流量比例:

apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
  name: helloworld
spec:
  hosts:
    - helloworld
  http:
  - route:
    - destination:
        host: helloworld
        subset: v1
        weight: 90
    - destination:
        host: helloworld
        subset: v2
        weight: 10
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值