-
应用准备:使用以前springbootapp镜像,xjk27400861/springbootapp:42与xjk27400861/springbootapp:43两个镜像,部署两个版本的应用
-
创建命名空间,springistiodemo,在k3s集群的任意一个节点执行
命令:
sudo kubectl create namespace springistiodemo
data:image/s3,"s3://crabby-images/93b04/93b0428573de8d8934eaf9aa4504fc01f042f618" alt="image"
-
自动注入(给命名空间打指定标签,启用自动注入)
sudo kubectl label namespace springistiodemo istio-injection=enabled
data:image/s3,"s3://crabby-images/79503/7950357d0a70d2725fff0231936bcfb05aba2bea" alt="image"
-
查看标签状态
sudo kubectl get ns springistiodemo --show-labels
data:image/s3,"s3://crabby-images/9bc3c/9bc3cce63cefb9a36c35747491438d770898d94e" alt="image"
-
禁用自动注入命令
sudo kubectl label namespace springistiodemo istio-injection=disabled –overwrite
data:image/s3,"s3://crabby-images/87f7f/87f7ff01408fc04e4c070ec62039e65ec6a03e2d" alt="image"
-
启用命名空间,自动注入后,rancher界面显示按钮为:禁用Istio自动注入
data:image/s3,"s3://crabby-images/8493e/8493eccb3432906c70ff7a50ec40d3e5dfccadcd" alt="image"
-
手动注入方式,(其他安装方式),rancher暂未找到执行istioctl命令的窗口
sudo istioctl kube-inject -f springbootapp-2nodes.yaml | sudo kubectl apply -f -
-
新建springbootapp-2nodes.yaml文件,执行命令部署应用
sudo kubectl create -f springbootapp-2nodes.yaml -n springistiodemo
-
springbootapp-2nodes.yaml文件内容,2个版本的服务,分别为v1和v2
data:image/s3,"s3://crabby-images/611fe/611fe5699febf534190257acff4aceec5d41a5b9" alt="image"
data:image/s3,"s3://crabby-images/f7f10/f7f10001bc927a3b4ac7312ae4c1a719355a38aa" alt="image"
-
稍等片刻,可以看到两个服务创建完成
data:image/s3,"s3://crabby-images/6b1d0/6b1d003aaca1dca24f1209610d15e4fe6b5afe17" alt="image"
-
创建及部署目标规则springbootapp-destination.yaml
sudo kubectl apply -f springbootapp-destination.yaml -n springistiodemo
data:image/s3,"s3://crabby-images/2085a/2085afacaa53c42a2ad98bda115d5566d9115d4f" alt="image"
-
GateWay创建,供外网访问
sudo kubectl apply -f springbootapp-vs-v1.yaml -n springistiodemo
data:image/s3,"s3://crabby-images/55ae7/55ae7f999fb42057620c693e1b821bfc17c6028f" alt="image"
-
创建及部署默认路由springbootapp-vs-v1.yaml,访问都访问v1版本服务
sudo kubectl apply -f springbootapp-vs-v1.yaml -n springistiodemo
data:image/s3,"s3://crabby-images/38bd5/38bd5d7b70cc8f1b189d859db06c8e84edef14ff" alt="image"
-
输入命令:sudo kubectl get svc istio-ingressgateway -n istio-system,查看端口映射,发现31380端口对应80端口
data:image/s3,"s3://crabby-images/28c41/28c4165e859d3ed70cdd315739294ccafdc622b1" alt="image"
-
data:image/s3,"s3://crabby-images/408fa/408fa8888d3a613544028c0f8b6d463d23b18b38" alt="image"
-
查看kiali界面,查看调用路径,namespace选择2个istio-system和springistiodemo,发现通过ingressgateway访问的服务都定位在了v1版本上
data:image/s3,"s3://crabby-images/b40bc/b40bcf22e7420494b66a46877f56307cd9ddd3e5" alt="image"
-
也可以通过在istio-ingressgateway的service中,添加端口映射,映射到应用上,可以不用80端口;例如:加端口映射8066-8080-31386,同时gateway的yaml文件,number属性改为8066,即可通过31386端口,访问服务(http://ip:31386)
data:image/s3,"s3://crabby-images/ab614/ab614574b2dd6e7e7dcb07f782defd2781ab6fd3" alt="image"