官网:https://istio.io/latest/zh/about/service-mesh/
部署
[root@k8s2 ~]# tar zxf istio-1.19.3-linux-amd64.tar.gz
[root@k8s2 ~]# cd istio-1.19.3/
[root@k8s2 istio-1.19.3]# export PATH=$PWD/bin:$PATH
demo专为测试准备的功能集合
[root@k8s2 istio-1.19.3]# istioctl install --set profile=demo -y
data:image/s3,"s3://crabby-images/95071/95071342a25f5636324a637371c9fd97ead4708c" alt=""
[root@k8s2 istio-1.19.3]# kubectl get pod -A
data:image/s3,"s3://crabby-images/afecf/afecfadf875ab8c9133ead9ac248b5262d01f5ee" alt=""
给命名空间添加标签,指示 Istio 在部署应用的时候,自动注入 Envoy 边车代理
[root@k8s2 istio-1.19.3]# kubectl label namespace default istio-injection=enabled
部署示例应用
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/platform/kube/bookinfo.yaml
data:image/s3,"s3://crabby-images/4d1c9/4d1c975a49a0bb9a090cb7f6f6ac1a1ab0d70a4a" alt=""
[root@k8s2 istio-1.19.3]# kubectl get pod
data:image/s3,"s3://crabby-images/fabf6/fabf6919cd86166cb732d068ac8297f61704d887" alt=""
data:image/s3,"s3://crabby-images/1f876/1f8766b6f905209b5d588c8179e68372b9ba7578" alt=""
创建 Istio 入站网关
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/bookinfo-gateway.yaml
data:image/s3,"s3://crabby-images/a5a34/a5a34f69dae7d8ed2c985d0abe652e398b3e1637" alt=""
[root@k8s2 istio-1.19.3]# kubectl -n istio-system get svc
data:image/s3,"s3://crabby-images/41cbf/41cbf70550e836cd7c0d5f7af01c3f95968ff578" alt=""
访问应用:http://192.168.92.102/productpage
data:image/s3,"s3://crabby-images/d7ba9/d7ba916b22b685a0cde083cbf056c02758c91fb7" alt=""
部署遥测组件
[root@k8s2 istio-1.17.1]# kubectl apply -f samples/addons
data:image/s3,"s3://crabby-images/ca8fc/ca8fc3a67f344d4cf16648118c914cf3ef85fbdb" alt=""
待插件部署完毕后,修改kiali服务的访问方式为Loadbalancer
data:image/s3,"s3://crabby-images/31171/311717140fce6cf21ce342cea44ee9c110100f91" alt=""
访问kiali:http://192.168.56.100:20001/
data:image/s3,"s3://crabby-images/b2b4a/b2b4ac51da1cc25093d9e0e2c9fd868d5362db1f" alt=""
流量管理
将所有流量路由到每个微服务的 v1 版本
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/destination-rule-all.yaml
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/virtual-service-all-v1.yaml
data:image/s3,"s3://crabby-images/87d9c/87d9c690228b250e77adf583bae15bf8e688cee6" alt=""
data:image/s3,"s3://crabby-images/6089e/6089e7f842cd894a3ebc888b5bd009d5be0fb516" alt=""
来自名为 Jason 的用户的所有流量将被路由到服务 reviews:v2
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml
data:image/s3,"s3://crabby-images/a5fc3/a5fc37a92e33ee13c67b0b64dfa43dd41ca20d17" alt=""
创建故障注入规则以延迟来自测试用户 jason 的流量
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/virtual-service-ratings-test-delay.yaml
用户 jason 登陆到 /productpage 页面,出现了一个问题:Reviews 部分显示了错误消息
data:image/s3,"s3://crabby-images/e5851/e58510f38212523de18c655b1ef76ce674b4e173" alt=""
设置流量转移,将所有流量转移到 reviews:v3
[root@k8s2 istio-1.19.3]# vim samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
name: reviews
spec:
hosts:
- reviews
http:
- match:
- headers:
end-user:
exact: jason
route:
- destination:
host: reviews
subset: v3
- route:
- destination:
host: reviews
subset: v1
data:image/s3,"s3://crabby-images/4eff6/4eff677401caf0df471da6f093731a4ba1b8b381" alt=""
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-test-v2.yaml
data:image/s3,"s3://crabby-images/1db4d/1db4d1185e34d44facfdc124b25e0570e34577b9" alt=""
修改延迟规则为任何低于 2.5 秒的数值,例如 2 秒
[root@k8s2 istio-1.19.3]# vim samples/bookinfo/networking/virtual-service-ratings-test-delay.yaml
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:
name: ratings
spec:
hosts:
- ratings
http:
- match:
- headers:
end-user:
exact: jason
fault:
delay:
percentage:
value: 100.0
fixedDelay: 2s
route:
- destination:
host: ratings
subset: v1
- route:
- destination:
host: ratings
subset: v1
data:image/s3,"s3://crabby-images/1819d/1819d66d59fa993f09b1d760d8488d78e59926fd" alt=""
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/virtual-service-ratings-test-delay.yaml
data:image/s3,"s3://crabby-images/b56e6/b56e6e95ff6746171bb6ed902e5a3aca2af7a44c" alt=""
把 50% 的流量从 reviews:v1 转移到 reviews:v3
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-50-v3.yaml
data:image/s3,"s3://crabby-images/6c70b/6c70baf3fa5b31552632aadf0d94d0f6ef93ded4" alt=""
data:image/s3,"s3://crabby-images/ffc81/ffc818461dc37073b620146626e9daba7e061a4b" alt=""
当reviews:v3 微服务已经稳定,可以通过应用 Virtual Service 规则将 100% 的流量路由 reviews:v3:
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-v3.yaml
data:image/s3,"s3://crabby-images/0768d/0768dc290570b32943b5bdbd9bff4a126a50e793" alt=""
清理
[root@k8s2 istio-1.19.3]# samples/bookinfo/platform/kube/cleanup.sh
data:image/s3,"s3://crabby-images/ef18a/ef18a4faa08d39104ae18c4bd816efa211e922fa" alt=""
熔断
部署 httpbin 服务
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/httpbin/httpbin.yaml
data:image/s3,"s3://crabby-images/06c11/06c114edb0e0ed0197ef9c5c8e6727b6e862b918" alt=""
配置熔断规则
[root@k8s2 istio-1.19.3]# 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
data:image/s3,"s3://crabby-images/16062/160624d29cb59e54e7d6a81dd20eb95e690068cd" alt=""
增加一个客户端
[root@k8s2 istio-1.19.3]# kubectl apply -f samples/httpbin/sample-client/fortio-deploy.yaml
data:image/s3,"s3://crabby-images/c90c3/c90c3408bb7b12713cbc015179939007e62d5d05" alt=""
[root@k8s2 istio-1.19.3]# kubectl get pod
[root@k8s2 istio-1.19.3]# kubectl get svc
data:image/s3,"s3://crabby-images/79f28/79f2830237fd3d6af6083571a0216f51b8c32980" alt=""
登入客户端 Pod 并使用 Fortio 工具调用 httpbin 服务
[root@k8s2 istio-1.19.3]# export FORTIO_POD=$(kubectl get pods -l app=fortio -o 'jsonpath={.items[0].metadata.name}')
[root@k8s2 istio-1.19.3]# kubectl exec "$FORTIO_POD" -c fortio -- /usr/bin/fortio curl -quiet http://httpbin:8000/get
data:image/s3,"s3://crabby-images/6a81b/6a81b3cfd8708a1872466dfca63ea5309ec4d093" alt=""
触发熔断器
发送并发数为 2 的连接(-c 2),请求 20 次(-n 20)
[root@k8s2 istio-1.19.3]# kubectl exec "$FORTIO_POD" -c fortio -- /usr/bin/fortio load -c 2 -qps 0 -n 20 -loglevel Warning http://httpbin:8000/get
data:image/s3,"s3://crabby-images/0ecca/0ecca46385513b5ef9667e8283351870410990e3" alt=""
istio-proxy 确实允许存在一些误差
将并发连接数提高到 3 个
[root@k8s2 istio-1.19.3]# kubectl exec "$FORTIO_POD" -c fortio -- /usr/bin/fortio load -c 3 -qps 0 -n 30 -loglevel Warning http://httpbin:8000/get
data:image/s3,"s3://crabby-images/ee953/ee9535d61eb398aa8668bf99a7d48bfbd26a8b1d" alt=""
将并发连接数提高到 5 个
[root@k8s2 istio-1.19.3]# kubectl exec "$FORTIO_POD" -c fortio -- /usr/bin/fortio load -c 5 -qps 0 -n 30 -loglevel Warning http://httpbin:8000/get
data:image/s3,"s3://crabby-images/aeb86/aeb867cbdd6a66c3d6de887b723be31a9f1dcff7" alt=""
均被熔断器拦截
清理
[root@k8s2 istio-1.19.3]# kubectl delete destinationrule httpbin
[root@k8s2 istio-1.19.3]# kubectl delete -f samples/httpbin/sample-client/fortio-deploy.yaml
[root@k8s2 istio-1.19.3]# kubectl delete -f samples/httpbin/httpbin.yaml
data:image/s3,"s3://crabby-images/9fb0f/9fb0f7c683060f097ec4e98ea3ce3f49fed5389f" alt=""
卸载istio
[root@k8s2 istio-1.19.3]# istioctl uninstall -y --purge
data:image/s3,"s3://crabby-images/cd929/cd929bb67e8545040331902130cefdb5d70f611e" alt=""
[root@k8s2 istio-1.19.3]# kubectl label namespace default istio-injection-