🐇明明跟你说过:个人主页

🏅个人专栏:《未来已来:云原生之旅》🏅

🔖行路有良友,便是天堂🔖

目录

一、引言

1、什么是云原生

2、云原生监控的重要性

二、云原生监控的基本概念

1、监控与观测性的区别

2、日志、追踪与度量:监控数据的三大支柱

三、云原生应用监控的关键领域

1、容器监控:Docker与Kubernetes集群

2、微服务监控:服务发现与调用链追踪

3、数据库与存储监控


一、引言

1、什么是云原生

云原生(Cloud Native)是一种设计和运行应用程序的方法,充分利用云计算的优势来提高敏捷性、弹性和可扩展性。通俗地说,云原生就是在云的环境中开发、部署和运行应用程序。

1. 微服务架构

  • 传统方式:一个大块头应用程序,所有功能都捆绑在一起,就像一个大蛋糕。
  • 云原生方式:把应用程序拆分成多个小服务,每个服务只负责一种功能,就像把蛋糕切成很多小块,每块都有不同的味道。


2. 容器化

  • 传统方式:在一台大机器上运行应用程序,很像把各种家电(微波炉、冰箱、洗衣机)都放在一个房间里。
  • 云原生方式:把每个服务放在一个独立的“盒子”(容器)里,这些盒子可以在任何地方运行,就像每个家电都有自己的独立小房间,可以随时移动。


3. 动态编排

  • 传统方式:手动配置和管理服务器资源,就像自己动手安排家具位置。
  • 云原生方式:使用自动化工具(如 Kubernetes)来管理和调整资源,就像有个智能机器人帮你安排和调整家具位置,确保最优配置。


4. 持续交付和集成(CI/CD)

  • 传统方式:开发完所有功能后才进行测试和发布,就像先做完整个蛋糕才开始品尝。
  • 云原生方式:不断开发、测试和发布小部分功能,就像每做好一小块蛋糕就立即品尝,确保每一块都是完美的。

2、云原生监控的重要性

1. 确保系统的可见性

  • 传统方式:只有一个大应用,出问题时可以直接查看日志。
  • 云原生方式:系统由很多小服务组成,每个服务都可能在不同的地方运行。监控可以让你看到每个服务的运行状态,就像拥有一双透视眼,能看到所有的内部运作。


2. 快速检测和响应问题

  • 传统方式:问题通常是被用户报告后才发现。
  • 云原生方式:监控系统能实时检测到问题,立即通知你,让你在用户之前就知道问题并解决它,就像车上的警报系统提醒你有故障。


3. 优化资源使用

  • 传统方式:资源分配是固定的,常常造成浪费或资源不足。
  • 云原生方式:监控帮助你了解每个服务的资源使用情况,自动调整资源分配,确保不浪费也不短缺,就像智能家居系统根据需要调整灯光和温度。


4. 保障系统的性能和可靠性

  • 传统方式:性能问题和瓶颈很难定位。
  • 云原生方式:监控工具提供详细的性能数据和趋势分析,帮助你快速找到并解决性能瓶颈,确保系统平稳运行,就像车上的仪表盘实时显示速度和油量,确保你安全驾驶。

二、云原生监控的基本概念

1、监控与观测性的区别

在云原生环境中,“监控”(Monitoring)“观测性”(Observability)是两个紧密相关但有所不同的概念。理解它们之间的区别对于有效管理和维护现代分布式系统至关重要。

监控(Monitoring)
监控是指通过预定义的指标和警报系统来跟踪和记录系统的运行状态。它关注的是系统的已知状态和预期行为,并在这些状态出现异常时发出警报。


例子:

  • 服务器的 CPU 使用率超过 80% 时发出警报。
  • Web 服务的响应时间超过 2 秒时触发通知。

观测性(Observability)
观测性是指通过系统生成的数据来理解和解释系统内部的状态和行为。它关注的是系统的未知状态和意外行为,并帮助发现和解决复杂的问题。


例子:

  • 使用分布式追踪来分析请求在微服务架构中的流转路径。
  • 通过日志分析来查找引起特定错误的根本原因。

监控与观测性的区别
目标

  • 监控:主要关注已知问题的检测和警报,通过预定义的指标来监控系统健康状态。
  • 观测性:旨在理解和解释系统的内部状态,帮助解决未知问题,通过多种数据源提供全面视图。


数据类型

  • 监控:主要依赖预定义的指标(如 CPU 使用率、内存使用量等)。
  • 观测性:收集和分析日志、指标和追踪数据,提供更全面和详细的信息。

方法

  • 监控:基于阈值的警报系统,当超出设定范围时触发警报。
  • 观测性:利用多种工具和方法(如日志分析、分布式追踪)来动态分析系统状态。


时间维度

  • 监控:通常用于历史数据分析和趋势预测。
  • 观测性:更强调实时分析和即时响应。


例子说明:
监控
假设你有一个电子商务网站,监控系统会:

  1. 跟踪网站的响应时间。
  2. 监控服务器的 CPU 和内存使用情况。
  3. 当响应时间超过某个阈值(比如 2 秒)时,发出警报。

观测性
观测性系统会:

  1. 收集详细的日志数据,记录每个用户请求的详细信息。
  2. 使用分布式追踪来跟踪请求在各个微服务之间的流转路径。
  3. 分析日志和追踪数据,以确定某个请求为什么会变慢,找到可能的瓶颈和错误点。

2、日志、追踪与度量:监控数据的三大支柱

在云原生监控和观测性中,日志(Logs)追踪(Traces)度量(Metrics)被称为监控数据的三大支柱(the three pillars of observability)。这三者各自提供不同类型的数据和视角,共同帮助我们全面了解和分析系统的运行状况。

1. 日志(Logs)
日志是应用程序、服务和系统生成的时间序列文本记录,用于记录系统的操作和事件。

例子:

  • 应用程序在处理用户请求时记录的每个步骤。
  • 系统在启动、关闭或遇到错误时的日志条目。


2. 追踪(Traces)
追踪是对分布式系统中单个请求或事务的生命周期进行记录和分析。追踪数据展示了请求在多个服务和组件之间流转的过程。

例子:

  • 一个用户请求在经过多个微服务时的详细路径和时间花费。
  • 分析一个请求在数据库查询、服务调用和数据处理等各个阶段的耗时。


3. 度量(Metrics)
度量是定量测量的时间序列数据,用于描述系统性能和健康状态。度量数据通常是以数值形式呈现的。

例子:

  • CPU 使用率、内存使用量、磁盘 I/O 速率等系统级指标。
  • 每秒请求数、错误率、响应时间等应用程序级指标。

三、云原生应用监控的关键领域

1、容器监控:Docker与Kubernetes集群

在云原生环境中,容器化技术(如 Docker)容器编排工具(如 Kubernetes)被广泛使用。为了确保容器和集群的健康运行,容器监控变得至关重要。容器监控涵盖了对单个容器、整个容器集群的性能和状态的监控。

Docker 监控
Docker 监控主要关注单个容器的性能和状态。

关键指标:

  • CPU 使用率:监控容器使用的 CPU 资源。
  • 内存使用率:监控容器使用的内存资源。
  • 网络流量:监控容器的网络流量,包括进出流量。
  • 磁盘 I/O:监控容器的磁盘读写操作。
  • 容器状态:监控容器的运行状态(运行中、停止、崩溃等)。


监控工具:

  1. Docker Stats:Docker 提供的内置命令,可显示容器的实时资源使用情况。
  2. cAdvisor:一个开源项目,专门用于容器的资源使用和性能分析。可以收集容器的 CPU、内存、文件系统和网络使用情况。
  3. Prometheus 和 Grafana:Prometheus 可以从 cAdvisor 收集指标数据,并将这些数据可视化到 Grafana 中。

Kubernetes 集群监控
Kubernetes 监控不仅关注单个容器,还关注整个集群的状态和性能,包括节点、Pod、服务和网络等。

关键指标:

  • 节点性能:CPU、内存使用率,磁盘 I/O,网络流量等。
  • Pod 和容器性能:CPU、内存使用率,Pod 重启次数等。
  • 集群状态:节点状态(就绪、不可用等)、Pod 状态(运行中、挂起等)。
  • 服务和网络性能:服务响应时间,网络延迟,错误率等。


监控工具:

  1. Kubelet Metrics:Kubelet 提供的指标,可以通过 /metrics 端点获取节点和容器的性能数据。
  2. cAdvisor:内置于每个 Kubelet 中,提供节点和容器级别的监控数据。
  3. Prometheus Operator:用于在 Kubernetes 集群中部署和管理 Prometheus 监控系统。
  4. ELK Stack:Elasticsearch、Logstash 和 Kibana 组合,用于日志收集、分析和可视化。

   

2、微服务监控:服务发现与调用链追踪

服务发现(Service Discovery)
服务发现是指在动态变化的环境中自动检测和定位服务的过程。微服务架构中,每个服务通常在多个实例上运行,且这些实例可能频繁地启动和停止,因此需要一种机制来自动发现和连接到这些服务。


调用链追踪(Distributed Tracing)
调用链追踪是指在分布式系统中跟踪和记录一个请求在多个服务之间的流转过程。调用链追踪帮助开发者理解请求的路径、识别性能瓶颈和定位错误源。

实际案例:
电子商务平台的服务发现与调用链追踪
在一个复杂的电子商务平台中,服务发现和调用链追踪可以协同工作,确保系统高效稳定运行。

  • 服务发现:使用 Consul 注册和发现各个服务,如用户服务、订单服务和支付服务。每个服务实例启动时,自动注册到 Consul,客户端通过查询 Consul 获取服务实例信息,实现负载均衡和调用。
  • 调用链追踪:使用 Jaeger 跟踪用户从浏览商品到下订单再到支付的整个过程。每个服务处理请求时,生成追踪数据并发送到 Jaeger。通过 Jaeger 的可视化界面,可以清晰地看到请求的流转路径,识别性能瓶颈,如订单服务的响应时间过长,并定位具体的服务和操作进行优化。

3、数据库与存储监控

数据库与存储监控在云原生环境中至关重要,因为它们直接影响应用程序的性能和可靠性。有效的监控可以帮助我们识别和解决性能瓶颈、优化资源使用以及防止数据丢失。

数据库监控
数据库监控的目标是确保数据库的高性能和高可用性,监控其健康状态和性能指标。

关键指标:

  • 查询性能:
    •  查询响应时间:每个查询的执行时间。
    •  查询吞吐量:每秒执行的查询数量。
    •  慢查询:执行时间超过预设阈值的查询。
  • 资源使用:
    •  CPU 使用率:数据库进程消耗的 CPU 资源。
    •  内存使用率:数据库进程消耗的内存资源。
    •  磁盘 I/O:数据库的读写操作速率。
  • 连接管理:
    •  活动连接数:当前活跃的数据库连接数量。
    •  连接失败率:连接失败的次数和频率。
  • 错误和警报:
    •  错误日志:数据库系统日志中记录的错误信息。
    •  告警事件:如磁盘空间不足、内存溢出等。

监控工具: 

  1. Prometheus + Grafana:
  2. Percona Monitoring and Management (PMM):一个开源的数据库监控和管理工具,支持 MySQL、MongoDB、PostgreSQL 等数据库。
  3. DataDog:一款商业监控服务,提供全面的数据库监控功能。

存储监控
存储监控的目标是确保存储系统的高性能和可靠性,监控其健康状态和性能指标。

关键指标:

  • 容量和使用率:
    •  总容量:存储系统的总容量。
    •  已用容量:已使用的存储容量。
    •  剩余容量:可用的存储容量。
    •  使用率:已使用容量占总容量的百分比。
  • I/O 性能:
    •  读写延迟:读写操作的平均延迟时间。
    •  读写吞吐量:每秒读写操作的数量。
    •  I/O 操作数:每秒进行的 I/O 操作次数。
  • 错误和警报:
    •  硬盘故障率:硬盘故障次数和频率。
    •  数据完整性错误:如 CRC 错误、数据校验错误等。

监控工具:

  1. Prometheus + Grafana:Prometheus用于收集和存储存储系统性能指标,Grafana用于可视化这些指标。
  2. ELK Stack (Elasticsearch, Logstash, Kibana):用于日志收集和分析,可以监控存储系统的日志。

   

💕💕💕每一次的分享都是一次成长的旅程,感谢您的陪伴和关注。希望这些关于云原生的文章能陪伴您走过技术的一段旅程,共同见证成长和进步!😺😺😺

🧨🧨🧨让我们一起在技术的海洋中探索前行,共同书写美好的未来!!! 

Logo

助力广东及东莞地区开发者,代码托管、在线学习与竞赛、技术交流与分享、资源共享、职业发展,成为松山湖开发者首选的工作与学习平台

更多推荐