备考ICA----Istio实验2---Istio Gateway 和 VirtualService 实验

备考ICA----Istio实验2---Istio Gateway 和 VirtualService 实验

1. 部署helloworld app

hellowworld app主要是由一个svc加2个deployment组成

2个deployment都拥有一个app=helloworld的标签,还各自拥有自己版本的version,分别是v1和v2

service通过app=helloworl将流量分发给v1和v2

当两个deployment中pod个数一样时,那么大概会各自获取到50%的流量.当放大或缩小某个deployment中pod数量,可以大致的实现不同比例的流量分发到2个版本上,这也是早期金丝雀的一种用法.

yaml内容如下

yaml 复制代码
apiVersion: v1
kind: Service
metadata:
  name: helloworld
  labels:
    app: helloworld
    service: helloworld
spec:
  ports:
  - port: 5000
    name: http
  selector:
    app: helloworld
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: helloworld-v1
  labels:
    app: helloworld
    version: v1
spec:
  replicas: 1
  selector:
    matchLabels:
      app: helloworld
      version: v1
  template:
    metadata:
      labels:
        app: helloworld
        version: v1
    spec:
      containers:
      - name: helloworld
        image: docker.io/istio/examples-helloworld-v1
        resources:
          requests:
            cpu: "100m"
        imagePullPolicy: IfNotPresent #Always
        ports:
        - containerPort: 5000
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: helloworld-v2
  labels:
    app: helloworld
    version: v2
spec:
  replicas: 1
  selector:
    matchLabels:
      app: helloworld
      version: v2
  template:
    metadata:
      labels:
        app: helloworld
        version: v2
    spec:
      containers:
      - name: helloworld
        image: docker.io/istio/examples-helloworld-v2
        resources:
          requests:
            cpu: "100m"
        imagePullPolicy: IfNotPresent #Always
        ports:
        - containerPort: 5000
bash 复制代码
kubectl apply -f istio/samples/helloworld/helloworld.yaml
bash 复制代码
kubectl get pods --show-labels |grep helloworld

测试通过访问svc的地址可以看到和我们预期的结果差不多

bash 复制代码
kubectl get svc
for i in {1..20};do curl $(kubectl get svc helloworld|grep helloworld|awk '{print $3}'):5000/hello;sleep 0.5 ;done

2. 发布 Gateway 和 VirtualService

istio/samples/helloworld/helloworld-gateway.yaml

在ingressgateway的80端口监听,当所有hosts的流量匹配uri: /hello如果匹配上那么将所有流量转发给helloworld:5000的endpoint进行响应

yaml 复制代码
apiVersion: networking.istio.io/v1alpha3
kind: Gateway
metadata:
  name: helloworld-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: helloworld
spec:
  hosts:
  - "*"
  gateways:
  - helloworld-gateway
  http:
  - match:
    - uri:
        exact: /hello
    route:
    - destination:
        host: helloworld
        port:
          number: 5000
bash 复制代码
kubectl apply -f istio/samples/helloworld/helloworld-gateway.yaml

Gateway和Virtualservice被创建

3. 访问测试

此时可以通过ingressgateway访问到hello的内容,通过刷新可以分别读取到v1和v2

v1

v2

当多次curl时可以看到流量被随机分配到2个版本上

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

当访问量足够大时,流量分配趋近于1:1

相关推荐
哪里不会点哪里.3 分钟前
什么是微服务?
微服务·云原生·架构
橙露1 小时前
云原生运维实战:阿里云 ECS 服务器安全加固与性能调优指南
运维·阿里云·云原生
yumenai_2 小时前
【K8s 避坑指南】2026 最新 Kubernetes v1.28 + Containerd 安装全流程(内网/离线通用版)
ubuntu·云原生·容器·kubernetes·k8s
刘叨叨趣味运维2 小时前
快速掌握K8s概念:云原生时代的操作系统
云原生·容器·kubernetes
The star"'2 小时前
kubernetes的概述,部署方式,基础命令,核心部件
云原生·容器·kubernetes·云计算
viviwong122 小时前
云原生学习笔记
云原生
ProgrammerPulse2 小时前
从 VM 到容器:一场云原生语境下的 “平滑进化”
云原生
小二·3 小时前
Go 语言系统编程与云原生开发实战(第2篇):并发编程深度实战 —— Goroutine、Channel 与 Context 构建高并发 API 网关
开发语言·云原生·golang
牛奶咖啡133 小时前
Prometheus+Grafana构建云原生分布式监控系统(十)_prometheus的服务发现机制(一)
云原生·prometheus·prometheus服务发现·静态服务发现·动态服务发现·基于文件的服务发现配置实践·prometheus标签重写
火山引擎开发者社区3 小时前
高密、海量、智能化:解密火山引擎 veDB 的云原生底座
云原生·火山引擎