ie调试模式下文本框能够正常启用_开箱即用!使用Rancher 2.3 启用Istio初体验

Rancher的理念是Run Kubernetes Everywhere,Rancher 2.3中许多重大更新,让这一理念的实现又向前一步。

70eeb79bb28bcd22f1dd1dff6f7aa77e.png

其中,最重要的两个特性是集成了Istio以及对Windows的支持。本文我们将主要讨论如何使用通过Rancher UI提供的Istio支持,并通过Kiali dashboard进行可视化。

前期准备:

  • 正在运行的Kubernetes集群
  • 安装Rancher并导入该集群

在本例中,我们将使用CIVO Cloud上的大型k3s托管集群,并且已经完成Rancher App的安装(在Civo Marketplace的Rancher应用程序将会在集群上安装Rancher,并将集群导入其中)。集群的设置可以参考以下步骤:

https://medium.com/@SaiyamPathak/managed-k3s-is-it-a-thing-9397799c38a

a2ab2efc2c7909df8569587940501163.png

启动集群之后,在集群创建过程中从marketplace选择Rancher进行安装。Civo将会启动Rancher server并导入集群。

4ecce7072dae9adf1249776b0beba8d4.png

集群准备就绪后,你将能看到Rancher 2.3的dashboard,它能够支持Istio和Kiali。让我们来探索一下这个dashboard吧!

集群创建之后,你可以下载kubeconfig,并连接集群。然后查看Rancher server以及cattle-agents是否起来并且运行。

>> kubectl apply -f rancher-ingress.yamlingress.extensions/cattle-ingress createdkubectl get ingress -n cattle-systemNAME             HOSTS   ADDRESS        PORTS   AGEcattle-ingress   *       172.31.0.189   80      32s

为了访问Rancher UI,创建一个ingress,rancher-ingress.yaml如下:

>> kubectl apply -f rancher-ingress.yamlingress.extensions/cattle-ingress createdkubectl get ingress -n cattle-systemNAME             HOSTS   ADDRESS        PORTS   AGEcattle-ingress   *       172.31.0.189   80      32s

现在如果你访问任何节点ip,你都将看到Rancher server正在运行。

c9ba6a09285149dd6ffec27c92a193b0.png


创建一个密码,保存URL。随后你应该能够看到导入的集群。

9bba987e60eeda7459c73fff1036a401.png

通过Rancher UI启用Istio

文档中是这样描述Istio的:

使用云平台的企业或组织可以从其中体会到很多益处。但是不可否认的是,采用云技术会对DevOps团队造成压力。开发人员必须使用微服务来构建可移植性,同时,运维人员管理超大型混合云和多云部署。而服务网格使得微服务更加易用,其中Istio可以帮助你连接、保护、控制和观察服务。

在很大程度上,Istio有助于降低部署的复杂性,并减轻开发团队的负担。它是一个完全开源的服务网格,可以在现有的分布式应用程序上透明地注入一层。同时,它也是一个平台,包括可将其集成到任何日志记录平台、遥测或策略系统中的各种API。Istio的多样功能可以让你能够成功、高效地运行分布式微服务架构,并提供统一地方式来保护、连接和监控微服务。

那么,现在我们开始通过Rancher UI中启用Istio,并部署吧。

要启用Istio,你需要访问UI上方的菜单栏,其路径是:工具> Istio。你可以更改许多配置选项。而现在,我想让所有配置都保持默认状态并将ingress网关设置为True。启用这一功能还将启用监控功能,这是Istio正常运行的先决条件。

56c7cf4bc308f32e1bdd95796692ed1b.png

启用之后,你将可以看到监控和Istio pod在命名空间cattle-prometheus(用于监控)和istio-system(用于istio)下出现。

5089be3d2aea66a71701cfa9f7b2ff8e.png
>> kubectl get pods -n istio-systemNAME                                      READY   STATUS    RESTARTS   AGEistio-citadel-6bb9c9f6fb-md9f8            1/1     Running   0          6m16sistio-tracing-64d646945-xm4sm             2/2     Running   0          6m15sistio-policy-68959c7999-5kmdb             2/2     Running   1          6m16sistio-galley-67848cd58-g5tbt              1/1     Running   0          6m16skiali-5f8f876bd5-6djxf                    2/2     Running   0          6m16sistio-telemetry-778bfdcf74-ps9vl          2/2     Running   1          6m16sistio-pilot-7546b9fdcc-rbxj8              2/2     Running   0          6m16sistio-ingressgateway-6f877dd689-rskn4     1/1     Running   0          6m16sistio-sidecar-injector-69c97ddbb5-x7jcv   1/1     Running   0          6m16s>> kubectl get pods -n cattle-prometheusNAME                                                       READY   STATUS    RESTARTS   AGEprometheus-operator-monitoring-operator-79484b9c6f-zshlq   1/1     Running   0          7m42sexporter-node-cluster-monitoring-wnxtc                     1/1     Running   0          7m39sexporter-node-cluster-monitoring-k68fb                     1/1     Running   0          7m39sgrafana-cluster-monitoring-5d676d89c5-vkbzm                2/2     Running   0          7m39sprometheus-cluster-monitoring-0                            5/5     Running   1          7m15sexporter-kube-state-cluster-monitoring-5dfd658dc-pn8mt     1/1     Running   0          7m39s

现在,我们来进行Istio部署示例,生成流量并在Kiali dashboard中查看它。

我们将为示例应用程序创建deployment、Gateway以及虚拟服务,如下所示:

kubectl  label namespace default istio-injection=enablednamespace/default labeledkubectl  apply -fservice/details createdserviceaccount/bookinfo-details createddeployment.apps/details-v1 createdservice/ratings createdserviceaccount/bookinfo-ratings createddeployment.apps/ratings-v1 createdservice/reviews createdserviceaccount/bookinfo-reviews createddeployment.apps/reviews-v1 createddeployment.apps/reviews-v2 createddeployment.apps/reviews-v3 createdservice/productpage createdserviceaccount/bookinfo-productpage createddeployment.apps/productpage-v1 createdkubectl  apply -f gateway.networking.istio.io/bookinfo-gateway createdkubectl  apply -f virtualservice.networking.istio.io/bookinfo created

生成流量:

现在,应用程序已经部署,你可以通过Istio gateway查看它。

>> kubectl  get podsNAME                              READY   STATUS    RESTARTS   AGEdetails-v1-74f858558f-m5tsx       2/2     Running   0          10mratings-v1-7855f5bcb9-lkhgg       2/2     Running   0          10mproductpage-v1-8554d58bff-llnqh   2/2     Running   0          10m|reviews-v2-d6cfdb7d6-rl4zk        2/2     Running   0          10mreviews-v3-75699b5cfb-crdrd       2/2     Running   0          10mreviews-v1-59fd8b965b-rmct2       2/2     Running   0          10m>> kubectl get svcNAME          TYPE        CLUSTER-IP        EXTERNAL-IP   PORT(S)    AGEkubernetes    ClusterIP   192.168.128.1             443/TCP    140mdetails       ClusterIP   192.168.154.118           9080/TCP   10mratings       ClusterIP   192.168.207.69            9080/TCP   10mreviews       ClusterIP   192.168.141.42            9080/TCP   10mproductpage   ClusterIP   192.168.128.87            9080/TCP   10m
0b4b4ed8ddaf0d87ed13249b63e50ebd.png

点击Test用户和普通用户,来生成一些流量。

从UI上方的菜单栏中【资源】项,选择Istio。你可以看到以下图表:

7ae2eae3a251a8cea9a9719b4993b957.png

点击屏幕上的Kiali图标。

Kiali

Kiali是Istio的可视化控制台,它具有服务网格配置功能。它通过推断拓扑来帮助理解你的服务网格架构并提供你的网格的健康状态。此外,Kiali还提供了详细的指标,并且其集成了基本的Grafana,因此可用于高级查询。还集成了Jaeger,可提供分布式追踪。

您可以查看已部署应用程序的完整拓扑以及流程。

cdddb51e8d4b776e0b0afb679f5ba87d.png

下面是已经部署的应用程序的图表:

28393ef6e794b10cbd2f0e4d3001bdf3.png

以下是其他图表:

b18e119e1e2867b6cbf352b594960e35.png

服务图表

8119ac35a6cca484c238f3994de76586.png

版本化应用程序图

510b6f94902fd45761bf84defcb702d7.png

工作负载图

Jaeger

受Dapper和OpenZipkin的启发,Jaeger被设计为一个开源分布式跟踪系统,由Uber Technologies发布。它用于监控、诊断基于微服务的分布式系统,包括:

  • 分布式上下文传播(Distributed Context Propagation)
  • 分布式事务监控
  • 根源分析(Root cause analysis)
  • 服务依赖分析
  • 性能/延迟优化
cc3aa87c9dbafd95c655ec6bca1ac2da.png

Jaeger UI

5f66c1e1b552f4b32b3087c7efaabf83.png

Jaeger 查询

总 结

在本文中,我们讨论了在Rancher 2.3.x中如何安装Istio并使用Kiali可视化服务网格。我们还部署了一个示例应用程序并生成了一些流量,还使用Kiali和Jaeger查看它们。

如果你还想了解更多关于Istio、Kiali以及Jaeger的内容,欢迎访问以下网站观看视频:

https://space.bilibili.com/430496045

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值