参考

1. 使用 Jaeger

  • jaegertracing/jaeger 是一个用于分布式跟踪的开源软件,提供原生 OpenTracing 支持,向下兼容 ZipKin
  • istio 中采用 Jaeger 作为分布式跟踪组件;
  • istio sidecar 为网格中的应用提供的跟踪功能只能提供调用环节的数据,如果需要支持整条链路,需要根据 OpenTracing 规范对应用进行改写。

1.1 启用 Jaeger

1.1.1 定制 Jaeger values.yaml

  • Jaeger 默认不启用,需要定制安装清单,可以通过 helm template--set 参数定制安装清单文件。
# 同时启用 "ingress" ,开放服务
vim install/kubernetes/helm/istio/charts/tracing/values.yaml ingress:
# 启用 "ingress",默认值 "false"
enabled: true
# Used to create an Ingress record.
hosts:
# 修改 "domain"
- tracing.istio
annotations:
# kubernetes.io/ingress.class: nginx
# kubernetes.io/tls-acme: "true"
tls:
# Secrets must be manually created in the namespace.
# - secretName: tracing-tls
# hosts:
# - tracing.local

1.1.2 渲染并启用 Jaeger

# 直接修改 Jaeger 的 `values.yaml` 文件的 "enabled: false" 为 "enabled: true" 并不生效;
# 但修改 `values.yaml` 文件的其余部分是有效的
helm template install/kubernetes/helm/istio \
--set tracing.enabled=true \
--name istio \
--namespace istio-system > default-tracing.yaml # 查看资源对象
kubectl get pod -n istio-system -w # `values.yaml` 文件的 "contextPath" 参数不体现,默认值即 "/jaeger"
URL: http://tracing.istio/jaeger/ # 构建流量观察 jaeger 服务
kubectl exec -it -c sleep $(kubectl get pod -l app=sleep,version=v1 -o jsonpath={.items[0].metadata.name}) /bin/bash
bash-4.4# for i in `seq 100` ; do http --body http://flaskapp/env/version ; done

1.2 跟踪参数传递

1.2.1 孤立的跟踪信息

# 样例服务在 istio 源代码的 samples 目录下
cd istio-1.1.7/samples/httpbin
kubectl apply -f httpbin.yaml # 在 "sleep" 服务的 Pod 内发起请求,要求 "flaskapp" 调用 "httpbin" 服务的 "/get" 路径,并返回 "httpbin" 给出的响应,同时要显示 "sleep" 发出的请求 Header 的内容;
# 完整路径:"sleep" --> "flaskapp" --> "httpbin",但 "OpenTracing" 所依赖的 `header` 没有被传递,导致 Jaeger 无法确定调用之间的关系
kubectl exec -it -c sleep $(kubectl get pod -l app=sleep,version=v1 -o jsonpath={.items[0].metadata.name}) /bin/bash
bash-4.4# http --debug http://flaskapp/fetch_with_header?url=http://httpbin:8000/get
  • 返回信息中,requests.request 是 httpie 客户端发出请求的 header 的原始内容;
  • flaskapp 收到的 header 内容中有一系列 "X-*" 的请求 header ,是 Evory 代理对请求进行的修改,其中包含分布式跟踪所需要的 Request-Id 等请求 header 。

1.2.2 跟踪参数传递

1.2.2.1 fetch_with_trace
  • flaskapp 服务的代码中定义了一个 fetch_with_trace 方法:
# 路径:"/app/main.py"
@app.route('/fetch_with_trace')
def fetch_with_trace():
url = request.args.get('url', '')
request_headers = dict(request.headers)
new_header = {}
for key in request_headers.keys():
if key.lower() in TRACE_HEADERS:
new_header[key] = request_headers[key] req = Request(url, headers = new_header)
return urlopen(req).read()
  • 通过 fetch_with_trace 方法:将中间服务收到的请求在进行下一级请求时,将其中用于跟踪的 header 传递下去,即可将孤立的跟踪信息融合在一起。
kubectl exec -it -c sleep $(kubectl get pod -l app=sleep,version=v1 -o jsonpath={.items[0].metadata.name}) /bin/bash
bash-4.4# for i in `seq 100` ; do http http://flaskapp/fetch_with_trace?url=http://httpbin:8000/ip ; done
1.2.2.1 fetch_with_header
  • 通过 /fetch_with_header 方法,可以观察 header 传递过程中的变化:
bash-4.4# do http http://flaskapp/fetch_with_header?url=http://httpbin:8000/get
  • 返回两组 http header :

    • 第一组来自 flaskapp ,表示 sleep --> flaskapp 的请求内容;
    • 第二组来自 httpbin ,表示 flaskapp --> httpbin 的请求内容。

2. 使用 Kiali

  • kiali 也是一个用于 istio 可视化的软件:
  • 与 Grafana & Prometheus 不同的是,Kiali 目前专用于 istio 系统;
  • 除提供监控,可视化,跟踪等通用功能外,还专门提供了 istio 的配置验证,健康评估等高级功能。

2.1 启用 Kiali

2.1.1 定制 Kiali values.yaml

  • Kiali 默认未启用,需要定制安装清单,可以通过 helm template--set 参数渲染定制安装清单文件。
# 同时启用 "ingress" ,开放服务
vim install/kubernetes/helm/istio/charts/kiali/values.yaml # 使用当前最新(2019年6月前后)稳定镜像
tag: v0.20
# "ingress" 资源的 "spec.rules.host.http.paths.path" 字段,即 "subpath"
contextPath: /kiali ingress:
# 启用 "ingress",默认值 "false"
enabled: true
# Used to create an Ingress record.
hosts:
# 修改 "domain"
- kiali.istio
annotations:
# kubernetes.io/ingress.class: nginx
# kubernetes.io/tls-acme: "true"
tls:
# Secrets must be manually created in the namespace.
# - secretName: kiali-tls
# hosts:
# - kiali.local dashboard:
# 以名为 "kiali" 的 "Secret" 对象传递登陆账号与密码
secretName: kiali # You must create a secret with this name - one is not provided out-of-box.
# 重定向,以 "ConfigMap" 对象的形式挂载到工作负载
# 注意:可以被访问的外部地址
grafanaURL: http://grafana:3000 # If you have Grafana installed and it is accessible to client browsers, then set this to its external URL. Kiali will redirect users to this URL when Grafana metrics are to be shown.
jaegerURL: http://tracing:80 # If you have Jaeger installed and it is accessible to client browsers, then set this property to its external URL. Kiali will redirect users to this URL when Jaeger tracing is to be shown.

2.1.2 渲染并启用 Kiali

# 直接修改 Jaeger 的 `values.yaml` 文件的 "enabled: false" 为 "enabled: true" 并不生效;
# 但修改 `values.yaml` 文件的其余部分是有效的
helm template install/kubernetes/helm/istio \
--set kiali.enabled=true \
--name istio \
--namespace istio-system > default-tracing.yaml # 创建 "Secret" 对象 "kiali"
kubectl create secret generic kiali -n istio-system --from-literal "username=admin" --from-literal "passphrase=admin" # 查看资源对象
kubectl get pod -n istio-system -w # 访问地址
URL: http://kiali.istio/kiali/

istio部署-istio jaeger & kiali的更多相关文章

  1. istio部署-istio prometheus

    参考 fleeto/sleep fleeto/flaskapp 1. 使用 Prometheus 1.1 访问 Prometheus 1.1.1 端口转发 Prometheus 服务默认启用. # o ...

  2. istio部署-helm

    参考 istio/istio istio/Kubernetes Customizable Install with Helm Istio安装参数介绍 1. Istio Chart 目录结构 PATH: ...

  3. 第五章 用Helm部署Istio

    5.1 Istio Chart概述 Helm是目前Istio官方推荐的安装方式.还可以对输入值进行一些调整,完成对Istio的部分配置工作.Istio Chart是一个总分结构,其分级结构和设计结构是 ...

  4. K8s下部署Istio

    一.环境准备 1.1环境信息 主机名 IP地址 用途 zhengzw-k8s-master 10.10.100.7 K8s Master zhengzw-k8s-node-1 10.10.100.15 ...

  5. istio部署-快速入门

    参考 istio/istio Quick Start Evaluation Install fleeto/sleep fleeto/flaskapp 本文为 istio 快速入门部署,一般用于演示环境 ...

  6. istio部署

    Istio的部署介绍 目录 Istio的部署介绍 部署模型 集群模式 单集群 多集群 网络模型 单网络 多网络 控制面模型 身份和信任模型 网格中的信任 网格之间的信任 网格模型 单网格 多网格 租户 ...

  7. [Istioc]Istio部署sock-shop时rabbitmq出现CrashLoopBackOff

    因Istio官网自带的bookinfo服务依赖关系较少,因此想部署sock-shop进行进一步的实验. kubectl apply -f <(istioctl kube-inject -f so ...

  8. [Istio]Kubernetes集群部署Istio 1.0

    大部分内容都是可以根据https://istio.io/docs/setup/kubernetes/quick-start/来处理的,这里主要谈部署时一些细节的问题 首先,当我们按照 istio 官方 ...

  9. 让istio中的jaeger跑起来

    现在的水平,仅止于让它跑起来.:) 同样的环境,microk8s+istio. 步骤如下: 一,使用kubectl get pod -n istio-system查看所有istio的POD运行正常. ...

随机推荐

  1. JAVA 递归线程池测试 ExecutorService / ForkJoinPool

    测试工具使用递归的方式获取子进程的Msg消息,目前有2种常用的ExecutorService / ForkJoinPool 为了测试哪种效果较好,我们来写个测试Demo,循环5555555次+1(加锁 ...

  2. tensorflow数据集加载

    本篇涉及的内容主要有小型常用的经典数据集的加载步骤,tensorflow提供了如下接口:keras.datasets.tf.data.Dataset.from_tensor_slices(shuffl ...

  3. 安装Logstash到linux(源码)

    运行环境 系统版本:CentOS Linux release 7.3.1611 (Core) 软件版本:logstash-7.1.0 硬件要求:最低2核4GB 安装过程 1.源码安装JDK 1.1.从 ...

  4. 问题 E: Problem B

    #include <cstdio> #include <cstring> #include <algorithm> #include <vector> ...

  5. Acer4315笔记本CPU升级

    终于有时间升级一下不怎么用的旧笔记本Acer4315了.在计划升级前了解了一下,芯片组是GL960,支持可升级的CPU有: CM560 CM570 T1600 T1700 T2310 T2330 T2 ...

  6. java读取解析application.yml

    java读取解析application.yml 不用依赖spring容器,可单独使用. bug已修改... 第一步.首先要2个jar <!-- properties和yaml格式化 --> ...

  7. css动画延迟好像有点怪

    项目中需要使用到动画animate.css,在自定义的时候发现设置animation-delay 和 animation-duration 的总时间不对会导致 动画缺失. 比如 bounceInLef ...

  8. VS的使用技巧记录:

    调试: F5:调试运行 会在编译前进行debug F10:单步步过   遇到函数不会进入函数内部执行 F11:单步步入   遇到函数会进入函数一步一步执行 ctrl+F5:直接运行不调试

  9. ubuntu set up 4 - 设置和软件

    1. Top Bar显示日期 https://askubuntu.com/questions/966576/customizing-tray-taskbar-date-display-in-ubunt ...

  10. Alice and Hairdresser

    Alice's hair is growing by leaps and bounds. Maybe the cause of it is the excess of vitamins, or may ...