Envoy 访问日志记录了通过 Envoy 进行请求 / 响应交互的相关记录,可以方便地了解具体通信过程和调试定位问题。

环境准备

部署 httpbin 服务:

  1. kubectl apply -f samples/httpbin/httpbin.yaml

部署 sleep 服务:

  1. kubectl apply -f samples/sleep/sleep.yaml

httpbin 服务作为接收请求的服务端, sleep 服务作为发送请求的客户端。

还需要开启 Envoy 访问日志,执行以下命令修改 istio 配置:

  1. kubectl -n istio-system edit configmap istio

编辑yaml文件的对应配置:

  1. data:
  2. mesh: |-
  3. accessLogEncoding: JSON
  4. accessLogFile: /dev/stdout

其中,accessLogEncoding表示 accesslog 输出格式,Istio 预定义了 TEXTJSON 两种日志输出格式。默认使用 TEXT,通常改成 JSON 以提升可读性;accessLogFile:表示 accesslog 输出位置,通常指定到 /dev/stdout (标准输出),以便使用 kubectl logs 来查看日志。

保证yaml文件后,配置随即生效。

文章持续更新,微信搜索「万猫学社」第一时间阅读,关注后回复「电子书」,免费获取12本Java必读技术书籍。

测试访问日志

sleep 服务中向 httpbin 服务发出请求:

  1. export SLEEP_POD=$(kubectl get pods -l app=sleep -o 'jsonpath={.items[0].metadata.name}')
  2. kubectl exec "$SLEEP_POD" -c sleep -- curl -sS http://httpbin:8000/headers

返回结果如下:

  1. {
  2. "headers": {
  3. "Accept": "*/*",
  4. "Host": "httpbin:8000",
  5. "User-Agent": "curl/7.81.0-DEV",
  6. "X-B3-Parentspanid": "ed0178f3e1f48dd1",
  7. "X-B3-Sampled": "0",
  8. "X-B3-Spanid": "6c38b689ee5ab0c8",
  9. "X-B3-Traceid": "f17ce19c174cae85ed0178f3e1f48dd1",
  10. "X-Envoy-Attempt-Count": "1",
  11. "X-Forwarded-Client-Cert": "......"
  12. }
  13. }

执行以下命令,查看sleep 服务的Envoy日志:

  1. kubectl logs -l app=sleep -c istio-proxy

可以看到sleep服务对httpbin服务的调用的日志:

  1. {
  2. "authority": "httpbin:8000",
  3. "bytes_received": 0,
  4. "bytes_sent": 533,
  5. "connection_termination_details": null,
  6. "downstream_local_address": "172.24.146.239:8000",
  7. "downstream_remote_address": "172.24.158.25:49350",
  8. "duration": 3,
  9. "method": "GET",
  10. "path": "/headers",
  11. "protocol": "HTTP/1.1",
  12. "request_id": "ea40d320-348f-4f58-86d4-da157b0e0cca",
  13. "requested_server_name": null,
  14. "response_code": 200,
  15. "response_code_details": "via_upstream",
  16. "response_flags": "-",
  17. "route_name": "default",
  18. "start_time": "2022-07-04T10:00:09.401Z",
  19. "upstream_cluster": "outbound|8000||httpbin.istio-demo.svc.cluster.local",
  20. "upstream_host": "172.24.158.96:80",
  21. "upstream_local_address": "172.24.158.25:41812",
  22. "upstream_service_time": "2",
  23. "upstream_transport_failure_reason": null,
  24. "user_agent": "curl/7.81.0-DEV",
  25. "x_forwarded_for": null
  26. }

执行以下命令,查看httpbin 服务的Envoy日志:

  1. kubectl logs -l app=httpbin -c istio-proxy

可以看到httpbin服务被sleep服务调用的Envoy日志:

  1. {
  2. "authority": "httpbin:8000",
  3. "bytes_received": 0,
  4. "bytes_sent": 533,
  5. "connection_termination_details": null,
  6. "downstream_local_address": "172.24.158.96:80",
  7. "downstream_remote_address": "172.24.158.25:41812",
  8. "duration": 2,
  9. "method": "GET",
  10. "path": "/headers",
  11. "protocol": "HTTP/1.1",
  12. "request_id": "ea40d320-348f-4f58-86d4-da157b0e0cca",
  13. "requested_server_name": "outbound_.8000_._.httpbin.istio-demo.svc.cluster.local",
  14. "response_code": 200,
  15. "response_code_details": "via_upstream",
  16. "response_flags": "-",
  17. "route_name": "default",
  18. "start_time": "2022-07-04T10:00:09.401Z",
  19. "upstream_cluster": "inbound|80||",
  20. "upstream_host": "172.24.158.96:80",
  21. "upstream_local_address": "127.0.0.6:33665",
  22. "upstream_service_time": "1",
  23. "upstream_transport_failure_reason": null,
  24. "user_agent": "curl/7.81.0-DEV",
  25. "x_forwarded_for": null
  26. }

看到这么多参数,是不是有点懵逼?没关系接下来,我们详细看看!

文章持续更新,微信搜索「万猫学社」第一时间阅读,关注后回复「电子书」,免费获取12本Java必读技术书籍。

刨析Envoy日志

名称 HTTP TCP
authority 请求授权头 未实现(“-”)
bytes_received 接收到消息体字节数 在连接上从下游接收的字节数
bytes_sent 发送的包体字节数 在连接上发送给下游的字节数
connection_termination_details 连接中断详情 连接中断详情
downstream_local_address 下游连接的本地地址 下游连接的本地地址
downstream_remote_address 下游连接的远程地址 下游连接的远程地址
duration 请求从起始时间到最后一个字节发出的持续总时长(以毫秒为单位) 下游连接的持续总时长(以毫秒为单位)
method HTTP请求方法 未实现(“-”)
path HTTP请求路径 未实现(“-”)
protocol 协议,目前不是 HTTP/1.1 就是 HTTP/2 未实现(“-”)
request_id 由envoy创建的 X-REQUEST-ID 请求头的值 未实现(“-”)
requested_server_name 设置在 ssl 连接套接字上表示服务器名称指示 (SNI) 的字符值 未实现(“-”)
response_code HTTP 响应码 未实现(“-”)
response_code_details TTP 响应状态码详情提供关于响应状态码的附加信息。 未实现(“-”)
response_flags 响应或者连接的附加详情 响应或者连接的附加详情
route_name 路由名 路由名
start_time 请求开始时间(包括毫秒) 下游连接开始时间(包括毫秒)
upstream_cluster 上游主机所属的上游集群 上游主机所属的上游集群
upstream_host 上游主机 URL 上游主机 URL
upstream_local_address 上游连接的本地地址 上游连接的本地地址
upstream_transport_failure_reason 如果上游因传输套接字而连接失败,从传输套接字中提供失败原因。 未实现(“-”)
user_agent User-Agent请求头的值 未实现(“-”)
x_forwarded_for X-Forwarded-For请求头的值 未实现(“-”)

清理

删除 httpbinsleep 服务:

  1. kubectl delete -f samples/httpbin/httpbin.yaml
  2. kubectl delete -f samples/sleep/sleep.yaml

微信公众号:万猫学社

微信扫描二维码

关注后回复「电子书」

获取12本Java必读技术书籍

在Istio中,到底怎么获取 Envoy 访问日志?的更多相关文章

  1. SpringBoot应用中使用AOP记录接口访问日志

    SpringBoot应用中使用AOP记录接口访问日志 本文主要讲述AOP在mall项目中的应用,通过在controller层建一个切面来实现接口访问的统一日志记录. AOP AOP为Aspect Or ...

  2. CentOS中设置Apache服务器网站访问日志[每天的日志]

    在阿里云的linux 服务器下Apache的日志默认设置是七天更新一次, 并且所在的目录无法通过FTP浏览器查看, 这样让小白操作起来非常麻烦 可以使用rotatelogs来设置服务器的网站访问日志按 ...

  3. 利用html5中的localStorage获取网页被访问的次数

    利用html5中的localStorage获取网页被访问的次数 <!DOCTYPE html> <html> <head> <meta charset=&qu ...

  4. 如何在 Istio 中支持 Dubbo、Thrift、Redis 以及任何七层协议?

    赵化冰,腾讯云高级工程师,Istio Member,ServiceMesher管理委员,Istio 项目贡献者, Aerika 项目创建者 ,热衷于开源.网络和云计算.目前主要从事服务网格的开源和研发 ...

  5. Istio中的流量配置

    Istio中的流量配置 目录 Istio中的流量配置 Istio注入的容器 Istio-init istio-proxy Envoy架构 Pilot-agent生成的初始配置文件 Envoy管理接口获 ...

  6. 在 Istio 中实现 Redis 集群的数据分片、读写分离和流量镜像

    Redis 是一个高性能的 key-value 存储系统,被广泛用于微服务架构中.如果我们想要使用 Redis 集群模式提供的高级特性,则需要对客户端代码进行改动,这带来了应用升级和维护的一些困难.利 ...

  7. Istio 中实现客户端源 IP 的保持

    作者 尹烨,腾讯专家工程师, 腾讯云 TCM 产品负责人.在 K8s.Service Mesh 等方面有多年的实践经验. 导语 对于很多后端服务业务,我们都希望得到客户端源 IP.云上的负载均衡器,比 ...

  8. Abp项目中的领域模型实体类访问仓储的方法

    首先声明,不推荐使用这种方法.实体访问仓储是不被推荐的! 1.简单粗暴的方法 Abp.Dependency.IocManager.Instance.Resolve>(); 2.绕个弯子的方法 首 ...

  9. Linux分析日志获取最多访问的前10个IP

    原文地址:http://xuqq999.blog.51cto.com/3357083/774714 apache日志分析可以获得很多有用的信息,现在来试试最基本的,获取最多访问的前10个IP地址及访问 ...

  10. Spring拦截器中通过request获取到该请求对应Controller中的method对象

    背景:项目使用Spring 3.1.0.RELEASE,从dao到Controller层全部是基于注解配置.我的需求是想在自定义的Spring拦截器中通过request获取到该请求对应于Control ...

随机推荐

  1. dart基础---->dart语法入门

    Dart is an open source, structured programming language for creating complex, browser-based web appl ...

  2. EX6新增的字符串

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. Windows 11 Update Download Error Solution - 0x80248007

    I had the same issue on a Windows 2019 virtual server while performing routine windows updates. The ...

  4. NodeJS 实战系列:个人开发者应该如何选购云服务

    这文章至少值一千元,因为这是我保守估计花出去的冤枉钱(请自行脑补一个苦笑的 emoji) 文章中会穿插选择云服务的一些建议,当然也会提供一些"薅羊毛"的技巧.不过在此之前我们要想清 ...

  5. [ElasticSearch]常用URL路径

    https://127.0.0.1:9200/ http://127.0.0.1:9200/_all?pretty https://127.0.0.1:9200/_cluster/health?pre ...

  6. 部署:戴尔iDRAC+Ubuntu 18.04系统安装

    Ubuntu镜像下载链接:http://mirrors.aliyun.com/ubuntu-releases/18.04/ 1.登录戴尔管理口 2.点击虚拟控制台 3.选择镜像 4.挂载镜像 5.选择 ...

  7. sql lag函数

    lag https://spark.apache.org/docs/latest/api/sql/#lag lag(input[, offset[, default]]) OVER (PARTITIO ...

  8. C++11强制类型转换

    C++ 强制类型转换有四种关键字:static_cast.const_cast.reinterpret_cast和dynamic_cast.它们用于不同的情况和目的,比C语言的强制类型转换更清晰和安全 ...

  9. C++ 基于Capstone实现反汇编器

    Capstone是一个反汇编框架,提供了一个简单.轻量级的API接口,可透明地处理大多数流行的指令体系,包括x86/x86-64.ARM及MIPS等.Capstone支持C/C++和Python,并且 ...

  10. Kubernetes集群调度增强之超容量扩容

    作者:京东科技 徐宪章 1 什么是超容量扩容 超容量扩容功能,是指预先调度一定数量的工作节点,当业务高峰期或者集群整体负载较高时,可以使应用不必等待集群工作节点扩容,从而迅速完成应用横向扩容.通常情况 ...