kubernetes istio

目录

一、部署

二、部署示例应用

三、部署遥测组件

四、流量管理

五、熔断


官网:https://istio.io/latest/zh/about/service-mesh/

一、部署

提前准备好文件

复制代码
tar zxf 15t10-1.19.3-linux-amd64.tar.gz
cd 15t10-1.19.3/
export PATH=$PWD/bin:$PATH

istioctl install --set profile=demo -y
kubectl get pod -A


给命名空间添加标签,指示 Istio 在部署应用的时候,自动注入 Envoy 边车代理

二、部署示例应用

复制代码
kubectl apply -f samples/bookinfo/platform/kube/bookinfo.yaml
kubectl apply -f samples/bookinfo/networking/bookinfo-gateway.yaml

三、部署遥测组件

复制代码
kubectl apply -f samples/addons

待插件部署完毕后,修改kiali服务的访问方式为Loadbalancer


访问kiali:http://192.168.67.125:20001/

四、流量管理

将所有流量路由到每个微服务的 v1 版本

复制代码
kubectl apply -f samples/bookinfo/networking/destination-rule-all.yaml
kubectl apply -f samples/bookinfo/networking/virtual-service-all-v1.yaml

来自名为 Jason 的用户的所有流量将被路由到服务 reviews:v2

复制代码
kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml


创建故障注入规则以延迟来自测试用户 jason 的流量

复制代码
kubectl apply -f samples/bookinfo/networking/virtual-service-ratings-test-delay.yaml

用户 jason 登陆到 /productpage 页面,出现了一个问题:Reviews 部分显示了错误消息

设置流量转移,将所有流量转移到 reviews:v3

复制代码
vim  samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml
kubectl apply -f   samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml


修改延迟规则为任何低于 2.5 秒的数值,例如 2 秒

复制代码
vim  samples/bookinfo/networking/virtual-service-ratings-test-delay.yaml
kubectl apply -f   samples/bookinfo/networking/virtual-service-ratings-test-delay.yaml


把 50% 的流量从 reviews:v1 转移到 reviews:v3 一半v1 一半v3

复制代码
kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-50-v3.yaml


当reviews:v3 微服务已经稳定,可以通过应用 Virtual Service 规则将 100% 的流量路由 reviews:v3:

复制代码
kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-v3.yaml


清理:

复制代码
samples/bookinfo/platform/kube/cleanup.sh

五、熔断

部署 httpbin 服务

复制代码
kubectl apply -f samples/httpbin/httpbin.yaml

配置熔断规则

复制代码
kubectl apply -f - <<EOF
apiVersion: networking.istio.io/v1alpha3
kind: DestinationRule
metadata:
  name: httpbin
spec:
  host: httpbin
  trafficPolicy:
    connectionPool:
      tcp:
        maxConnections: 1
      http:
        http1MaxPendingRequests: 1
        maxRequestsPerConnection: 1
    outlierDetection:
      consecutive5xxErrors: 1
      interval: 1s
      baseEjectionTime: 3m
      maxEjectionPercent: 100
EOF

增加一个客户端

复制代码
kubectl apply -f samples/httpbin/sample-client/fortio-deploy.yaml


登入客户端 Pod 并使用 Fortio 工具调用 httpbin 服务

复制代码
export fortio-deploy-6cf68cc4c-qfcb=$(kubectl get pods -l app=fortio -o 'jsonpath={.items[0].metadata.name}')

kubectl exec "fortio-deploy-6cf68cc4c-qfcb" -c fortio -- /usr/bin/fortio curl -quiet http://httpbin:8000/get


触发熔断器

发送并发数为 2 的连接(-c 2),请求 20 次(-n 20)

复制代码
kubectl exec "fortio-deplov-6cf68cc4c-abfcb" -c fortio -- /usr/bin/fortio load -c 2 -qps 0 -n 20 -loglevel Warning http://httpbin:8000/get

istio-proxy 确实允许存在一些误差


将并发连接数提高到 3 个

复制代码
kubectl exec "fortio-deploy-6cf68cc4c-qbfcb" -c fortio -- /usr/bin/fortio load -c 3 -qps 0 -n 30 -loglevel Warning http://httpbin:8000/get


将并发连接数提高到 5 个 均被熔断器拦截

复制代码
kubectl exec "fortio-deploy-6cf68cc4c-qbfcb" -c fortio -- /usr/bin/fortio load -c 5 -qps 0 -n 30 -loglevel Warning http://httpbin:8000/get

清理

复制代码
kubectl delete destinationrule httpbin

kubectl delete -f samples/httpbin/sample-client/fortio-deploy.yaml
kubectl delete -f samples/httpbin/httpbin.yaml

回收istio

复制代码
istioctl uninstall -y --purge
kubectl label namespace default istio-injection-

相关推荐
dyj0953 小时前
Dify - (一)、本地部署Dify+聊天助手/Agent
人工智能·docker·容器
Nice_Fold6 小时前
Kubernetes DaemonSet、StatefulSet与Service(自用笔记)
笔记·容器·kubernetes
Java后端的Ai之路10 小时前
Kubernetes是什么?(小白入门版)
云原生·容器·kubernetes·教程
木雷坞11 小时前
视觉算法环境 Docker 镜像拉取失败排查
运维·人工智能·docker·容器
瀚高PG实验室11 小时前
安全版V4.5版本docker容器license过期问题处理步骤
安全·docker·容器·瀚高数据库
筱_智13 小时前
Docker学习-超详细-通俗易懂(从入门到精通)
学习·docker·容器
EAIReport14 小时前
Docker与K8s核心解析:共同性、差异性及实战适配指南
docker·容器·kubernetes
长安链开源社区14 小时前
动手开发 | 如何通过k8s部署长安链
云原生·容器·kubernetes·区块链
江湖有缘14 小时前
容器化部署|Docker搭建Blinko轻量笔记系统
笔记·docker·容器
亚空间仓鼠14 小时前
Kubernetes技术入门与实践(五):DaemonSet与StatefulSet
容器·贪心算法·kubernetes