完善istio的安装过程

顺利安装完成并跑通bookinfo sample示例,可以在各个监控页面中看到结果。
pull/20/head
Jimmy Song 2017-06-02 14:18:47 +08:00
parent 7785fdb268
commit 77df44ecfc
7 changed files with 57 additions and 22 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 152 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 243 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 489 KiB

After

Width:  |  Height:  |  Size: 521 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 446 KiB

After

Width:  |  Height:  |  Size: 669 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 119 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 196 KiB

After

Width:  |  Height:  |  Size: 465 KiB

View File

@ -6,11 +6,9 @@
## 安装环境 ## 安装环境
CentOS 7.3.1611 - CentOS 7.3.1611
- Docker 1.12.6
Docker 1.12.6 - Kubernetes 1.6.0
Kubernetes 1.6.0
## 安装 ## 安装
@ -164,7 +162,7 @@ kubectl apply -f install/kubernetes/addons/servicegraph.yaml
kubectl apply -f install/kubernetes/addons/zipkin.yaml kubectl apply -f install/kubernetes/addons/zipkin.yaml
``` ```
在traefik ingress中增加增加以上几个服务的配置。 在traefik ingress中增加增加以上几个服务的配置同时增加istio-ingress配置
```Yaml ```Yaml
- host: grafana.istio.io - host: grafana.istio.io
@ -195,22 +193,15 @@ kubectl apply -f install/kubernetes/addons/zipkin.yaml
backend: backend:
serviceName: zipkin serviceName: zipkin
servicePort: 9411 servicePort: 9411
- host: ingress.istio.io
http:
paths:
- path: /
backend:
serviceName: istio-ingress
servicePort: 80
``` ```
Grafana页面
![Istio Grafana界面](../images/istio-grafana.jpg)
Prometheus页面
![Prometheus页面](../images/istio-prometheus.jpg)
Zipkin页面
![Zipkin页面](../images/istio-zipkin.jpg)
## 测试 ## 测试
我们使用Istio提供的测试应用[bookinfo](https://istio.io/docs/samples/bookinfo.html)微服务来进行测试。 我们使用Istio提供的测试应用[bookinfo](https://istio.io/docs/samples/bookinfo.html)微服务来进行测试。
@ -226,6 +217,10 @@ istio/examples-bookinfo-reviews-v3
istio/examples-bookinfo-productpage-v1 istio/examples-bookinfo-productpage-v1
``` ```
该应用架构图如下:
![BookInfo Sample应用架构图](../images/bookinfo-sample-arch.png)
**部署应用** **部署应用**
``` ```
@ -234,9 +229,49 @@ kubectl create -f <(istioctl kube-inject -f samples/apps/bookinfo/bookinfo.yaml)
`Istio kube-inject`命令会在`bookinfo.yaml`文件中增加Envoy sidecar信息。参考https://istio.io/docs/reference/commands/istioctl.html#istioctl-kube-inject `Istio kube-inject`命令会在`bookinfo.yaml`文件中增加Envoy sidecar信息。参考https://istio.io/docs/reference/commands/istioctl.html#istioctl-kube-inject
## 问题 在本机的`/etc/hosts`下增加VIP节点和`ingress.istio.io`的对应信息。具体步骤参考:[边缘节点配置](../practice/edge-node-configuration.md)
在bookinfo部署后没有在Grafana、Prometheus、ServiceGraph和Zipkin中看到结果。 在浏览器中访问http://ingress.istio.io/productpage
![BookInfo Sample页面](../images/bookinfo-sample.jpg)
## 监控
不断刷新productpage页面将可以在以下几个监控中看到如下界面。
**Grafana页面**
http://grafana.istio.io
![Istio Grafana界面](../images/istio-grafana.jpg)
**Prometheus页面**
http://prometheus.istio.io
![Prometheus页面](../images/istio-prometheus.jpg)
**Zipkin页面**
http://zipkin.istio.io
![Zipkin页面](../images/istio-zipkin.jpg)
**ServiceGraph页面**
http://servicegraph.istio.io/dotviz
可以用来查看服务间的依赖关系。
访问http://servicegraph.istio.io/graph可以获得json格式的返回结果。
![ServiceGraph页面](../images/istio-servicegraph.jpg)
## 更进一步
BookInfo示例中有三个版本的`reviews`可以使用istio来配置路由请求将流量分摊到不同版本的应用上。参考[Configuring Request Routing](https://istio.io/docs/tasks/request-routing.html)。
还有一些更高级的功能,我们后续将进一步探索。
## 参考 ## 参考