备考ICA----Istio实验3---Istio DestinationRule 实验

备考ICA----Istio实验3---Istio DestinationRule 实验

1. hello服务说明

这部分服务沿用Istio实验2的deployment和svc

同时在上一个实验的deployment中分别加入了2个标签:

app: helloworld 两个deployment共有

version: v1 和 version: v2 两个deploymen 不同

详见:https://blog.csdn.net/qq_29974229/article/details/136914465 的 [1. 部署helloworld app] 部分yaml内容

2. DestinationRule流量转发

2.1 通过DestinationRule将所有流量都转发到v1版本

2.1.1 配置文件

通过DestinationRule 将version: v1和version: v2分别定义成2个subnet,名字为v1和v2,随后在vs的destination中通过subset选择,定义weight权重来实现不同流量权重的分发.金丝雀发布就是通过这种方式来实现的

helloworld-dr-all-v1.yaml

yaml 复制代码
---
apiVersion: networking.istio.io/v1beta1
kind: DestinationRule
metadata:
  name: helloworld-destination
spec:
  host: helloworld
  subsets:
  - name: v1
    labels:
      version: v1
  - name: v2
    labels:
      version: v2
---
apiVersion: networking.istio.io/v1beta1
kind: VirtualService
metadata:
  name: helloworld
spec:
  hosts:
  - "*"
  gateways:
  - helloworld-gateway
  http:
  - match:
    - uri:
        exact: /hello
    route:
    - destination:
        host: helloworld
        port:
          number: 5000
        subset: v1

应用配置

bash 复制代码
kubectl apply -f helloworld-dr-all-v1.yaml 

2.1.2 访问测试

即使在SVC上看到有v2的ep,但由于Envoy SideCar的存在,经由Istio Ingressgateway所有的流量直接被截获,并直接转发给了v1的vs由它响应请求

bash 复制代码
for i in {1..20};do curl http://192.168.126.220/hello ;sleep .5 ;done

2.2 通过 DestinationRule将流量2,8开给v1和v2

2.2.1 配置文件

之前已经在DestinationRule上定义了2个subnet,这里只需要定义vs的比例就可以了

helloworld-dr-20-v1.yaml

yaml 复制代码
---
apiVersion: networking.istio.io/v1beta1
kind: VirtualService
metadata:
  name: helloworld
spec:
  hosts:
  - "*"
  gateways:
  - helloworld-gateway
  http:
  - match:
    - uri:
        exact: /hello
    route:
    - destination:
        host: helloworld
        port:
          number: 5000
        subset: v1
      weight: 20
    - destination:
        host: helloworld
        port:
          number: 5000
        subset: v2
      weight: 80
bash 复制代码
kubectl apply -f helloworld-dr-20-v1.yaml

2.2.2 访问测试

20个请求4次,显然和我们预期是一样的

bash 复制代码
for i in {1..20};do curl http://192.168.126.220/hello ;sleep .5 ;done


相关推荐
Dobby_054 小时前
【Linux】安装 Rocky Linux 9 并配置 Kubernetes 集群基础环境 | VMware | Win11
linux·云原生·kubernetes
阿里云云原生6 小时前
阿里巴巴 AI Coding 分享会 Qoder Together 杭州站来啦!
云原生
阿里云云原生6 小时前
告别手动埋点!Android 无侵入式数据采集方案深度解析
android·云原生
老朋友此林7 小时前
一文速通k8s基础概念原理Kubernetes
云原生·容器·kubernetes
VermiliEiz9 小时前
k8s的calico出现ipset报错解决方法
云原生·容器·kubernetes
老实巴交的麻匪11 小时前
(八)学习、实践、理解 CI/CD 与 DevOps:持续集成 CI,从源代码到容器镜像
运维·云原生·自动化运维
做运维的阿瑞12 小时前
Kubernetes网络通信与Pod基础详解:从架构图看K8s核心组件
云原生·容器·kubernetes
掘根1 天前
【Docker】docker run
云原生·eureka
橙色云-智橙协同研发1 天前
PLM实施专家宝典:离散制造企业工程变更的“流程金融”方案
云原生·解决方案·plm·国产plm·产品服务·工程方案·工程变更
信仰_2739932431 天前
Eureka 多层缓存机制详解
缓存·云原生·eureka