《OpenShift 4.x HOL教程汇总》
说明:本文已经在OpenShift 4.8环境中验证
创建ServiceMesh环境
参照《OpenShift 4 - 创建Service Mesh运行环境》在OpenShift上准备好Service Mesh的运行环境。
部署Istio的微服务
本部分会部署3个微服务,它们的关系如下图:Frontend_v1接收用户请求后会转发给后台Backend_v1和Backend_v2。
- 下载资源
$ git clone https://gitlab.com/workshop6/service-mesh.git
$ cd service-mesh
- 创建my-istio-app项目,然后参考《OpenShift 4 - 创建Service Mesh运行环境》将此项目加入到OpenShift ServiceMesh Member Roll的项目列表中。
$ oc new-project my-istio-app
- 执行命令部署3个微服务和相关对象。在完成后可以看到3个运行的Pod,前两个Pod中有2个Container(其中1个Container是自动注入的sidecar),而frontend-v1只有1个Container,这是由于在frontend-v1-deployment.yaml中缺少注释“sidecar.istio.io/inject: “true””。
$ oc apply -f ocp/backend-v1-deployment.yaml -n my-istio-app
$ oc apply -f ocp/backend-v2-deployment.yaml -n my-istio-app
$ oc apply -f ocp/backend-service.yaml -n my-istio-app
$ oc apply -f ocp/frontend-v1-deployment.yaml -n my-istio-app
$ oc apply -f ocp/frontend-service.yaml -n my-istio-app
$ oc apply -f ocp/frontend-route.yaml -n my-istio-app
$ oc get pod -n my-istio-app
NAME READY STATUS RESTARTS AGE
backend-v1-6ddf9c7dcf-zmn4b 2/2 Running 0 12h
backend-v2-7655885b8c-qg4d7 2/2 Running 0 12h
frontend-v1-655f4478c-9dwnv 1/1 Running 0 12h
- 可以执行以下命令为“deployment/frontend-v1”对象添加一个注释。
$ oc patch deployment/frontend-v1 -p '{"spec":{"template":{"metadata":{"annotations":{"sidecar.istio.io/inject":"true"}}}}}' -n my-istio-app
$ oc get pod -n my-istio-app
NAME READY STATUS RESTARTS AGE
backend-v1-6ddf9c7dcf-zmn4b 2/2 Running 0 12h
backend-v2-7655885b8c-qg4d7 2/2 Running 0 12h
frontend-v1-677b9c7d9c-fn2nm 2/2 Running 0 8m42s
- 访问frontend微服务。backend-v1和backend-v2是被随机调用的,其中backend-v1用时较短,而backend-v2用时较长
$ FRONTEND_URL=$(oc get route frontend -n my-istio-app -o jsonpath='{.status.ingress[0].host}')
$ curl $FRONTEND_URL -s -w "\nElapsed Time:%{time_total}\n" | grep Elapsed
Elapsed Time:1.236257
$ curl $FRONTEND_URL -s -w "\nElapsed Time:%{time_total}\n" | grep Elapsed
Elapsed Time:6.092146
参考
https://gitlab.com/workshop6/service-mesh