混合云环境实现K8S可观测的6大策略

2023年,原生云应用及平台发展迅猛。大量企业都在努力发挥其应用程序的最大潜力,以确保极致的用户体验并推动业务增长。

混合云环境的兴起和容器化技术(如Kubernetes)的采用彻底改变了现代应用程序的开发、部署和扩展方式。

在这个数字舞台上,K8S是大多数云原生应用程序和工作负载的首选平台,这个流行的开源工具有助于容器编排和发现、负载平衡和其他功能。根据一份报告,96%的公司目前已在其云系统中使用或正在评估K8S的实施。

图片

然而,随之而来的是一系列新的挑战。随着应用程序复杂性的增加,对有效的可观测性解决方案的需求也在增加,这些解决方案使企业能够深入了解其容器化的工作负载,也是混合云环境中管理和优化容器化应用程序的一个重要前提。

本文将深入K8S的可观测性,探索六种有效的策略,这些策略可以让企业在混合云环境中释放其容器化应用程序的全部潜力。

1、使用集群日志记录与日志聚合

为了深入了解分布式系统,集群日志记录是一个基本策略。在K8S环境中,应用程序会跨越多个容器和节点,因此收集和分析各种来源的日志就变得至关重要。

集群日志记录包括将不同组件的日志整合到一个易于访问的位置。集群日志记录的重要性在于它能够提供系统行为和性能的整体视图。

利用K8S集群日志,您可以关联事件并识别K8S集群中的模式,从而实现高效的故障排除和故障原因分析。

想要在K8S中实现集群日志记录,您可以利用强大的日志聚合工具或云原生解决方案,如亚马逊观测日志或者谷歌云日志。这些工具提供了可扩展且高效的方法来收集、存储和分析来自 K8S 集群的日志。

2、利用分布式追踪实现端到端可见性

在微服务分布在多个容器和节点上的复杂 K8S 环境中,了解不同组件之间的请求和交互流很具有挑战性。这就是分布式追踪发挥作用的地方——在请求遍历各种服务时提供对请求执行路径的端到端可见性。

分布式追踪允许您追踪请求从入口到接触的所有微服务的流程,从而捕获有关每个步骤的宝贵信息。通过使用追踪库或代理检测应用程序,可以生成追踪数据,以显示每个服务的持续时间、延迟和潜在瓶颈。

在 Kubernetes 中利用分布式追踪的好处是非常显著的。

首先,它可以帮助您了解服务之间的依赖关系,从而实现更好的故障排除和性能优化。当请求出现延迟或错误时,您可以快速确定出现问题的服务或组件并采取纠正措施。

其次,分布式追踪允许您测量和监视各个服务及其交互的性能。

通过分析追踪数据,您可以识别性能瓶颈,检测低效的资源使用情况,并优化系统的整体响应能力。这些信息对于容器规划和确保 Kubernetes 环境中的可扩展性非常重要。

对企业而言,可以选择一些流行的分布式追踪解决方案。这些工具为有效收集和可视化追踪数据提供了必要的工具和基础设施。通过将这些解决方案集成到您的K8S部署中,可以全面了解您的微服务行为,并推动持续改进。

3、将K8S与APM解决方案集成

为了在K8S中实现全面的可观测性,有必要将您的环境与应用性能监控(APM)解决方案进行集成。APM解决方案提供了超越传统指标和日志的高级监控功能,能够洞察各个应用程序组件的性能和行为。

APM集成的主要好处之一是能够检测和诊断K8S应用程序中的性能瓶颈。

借助APM解决方案,您可以在请求通过各种服务时对其进行跟踪,并确定高延迟或资源冲突的区间。有了这些信息,就可以采取有针对性的措施来优化关键路径并提高应用程序的整体性能。

许多APM解决方案提供专门的K8S集成,简化了对容器化应用程序的监控和管理。这些集成提供了预配置的仪表板、警报和工具库,简化了K8S环境中APM数据的捕获和分析。

4、使用基于指标的监控

基于指标的监控构成了K8S中可观测性的基础。它包括收集和分析关键指标,这些指标提供了对您的K8S集群和应用程序的健康、性能和资源利用率的洞察。

谈到Kubernetes中基于指标的监控,有几个基本组件需要考虑:

节点级指标:监控Kubernetes集群中单个节点的资源利用率对于容量规划和基础设施优化至关重要。CPU使用率、内存使用率、磁盘I/O和网络带宽等指标有助于您识别潜在的资源瓶颈,并确保最佳分配。        

Pod级指标:Pod是Kubernetes的基本部署单位。通过监控与pod相关的指标,您可以评估它们的资源消耗、运行状况和整体性能。关键的pod级指标包括CPU和内存使用情况、网络吞吐量和请求成功率。  

容器级指标:pod中的容器封装了单独的应用程序组件。监控容器级指标有助于您了解特定应用程序服务或流程的资源消耗和行为。CPU使用率、内存使用率和文件系统使用率等指标提供了对容器性能的洞察。

  • 特定应用指标:根据应用程序的需求,您可能需要监控特定业务逻辑或领域的定制指标。这些指标可以包括交互率、错误率、缓存命中率或其他相关的性能指标。

图片

5、自定义Kubernetes事件增强可观测性

自定义事件在K8S组件之间以及K8S和外部系统之间进行通信。它们可以发出重要事件的信号,比如部署、伸缩操作、配置更改,甚至是容器中特定于应用程序的事件。

通过利用自定义事件,您可以在可观测性方面获得几个好处:

  • 主动监控:自定义事件允许您定义和监控需要注意的特定条件。例如可以创建事件来指示何时资源不足、何时pod出现故障或何时超过特定阈值。通过捕获这些事件,您可以在问题升级之前主动检测并解决问题。
  • 上下文信息自定义事件包括有助于故障排除和分析根本原因的附加上下文信息。您可以附加相关的详细信息,例如错误消息、时间戳、受影响的资源或任何其他元数据,以便深入了解事件的重要性。这种额外的背景有助于更有效地理解和解决问题。
  • 与外部系统的集成:K8S自定义事件可以由外部系统使用,例如监控平台或事故管理工具。集成这些系统允许您基于特定事件触发自动响应或通知。这简化了事件响应流程,并确保及时解决关键问题。

利用自定义K8S事件,您可以使用K8S事件挂钩(event hooks)、定制控制器,甚至使用K8S API开发您的事件驱动应用程序。通过定义事件触发器、捕获相关信息并对事件做出反应,您可以建立一个健壮的可观测性框架,补充传统的监视方法。

6、整合综合监控实现可观测性主动发现

综合监控模拟用户行为或代表与应用程序日常交互的特定事务。这些综合监控可以设置在不同的位置定期运行,模拟用户行为并测量关键性能指标。

在您的K8S环境中集成合成监控有几个主要好处:

  • 主动问题检测:综合监控允许您在真实用户受到影响之前发现问题。通过定期模拟用户交互,您可以识别性能下降、错误或无响应的组件。这种早期检测使您能够主动解决问题并保持高应用程序可用性。
  • 性能基准测试:综合监控为性能基准和SLA合规性提供了基线。通过从不同的位置运行一致的测试,您可以测量正常情况下的响应时间、延迟和可用性。这些基准可作为检测异常和确保最佳性能的参考。
  • 位置监测:可以将综合监控配置为从不同的位置运行,从而在不同区域深入了解应用程序的性能。这有助于识别可能影响用户体验的延迟问题或位置差异。通过这些信息优化您的应用性能,您可以确保全球一致的用户体验。

可以利用专业工具将综合监控整合进你的K8S环境。这些工具提供了创建和部署综合监控、监控性能指标以及生成报告的能力。

为基于微服务的应用程序获得 K8S 可观测性的一种方法是使用 Datadog、Splunk、Middleware 和 Dynatrace 等第三方工具。这些工具能够捕获指标和事件,提供多个现成的报告、图表和警报以节省时间。

7、支持微服务、k8s的开发工具

市场上的开发工具有很多,JNPF快速开发平台是一款基于SpringBoot+Vue3的全栈开发平台,采用微服务、前后端分离架构,基于可视化流程建模、表单建模、报表建模工具,快速构建业务应用,平台即可本地化部署,也支持K8S部署。

通过可视化拖拽的方式,传统模式下需要2 周完成开发的应用,用JNPF只要 2小时。用JNPF搭建应用,你只需要关注业务本身。数据存储、运行环境、服务器、网络安全等,平台为你全部搞定。

还配置了图表引擎、接口引擎、门户引擎、组织用户引擎等可视化功能引擎,基本实现页面UI的可视化搭建。内置有百种功能控件及使用模板,使得在拖拉拽的简单操作下,也能大限度满足用户个性化需求。体验地址:https://www.jnpfsoft.com/?csdn

由于篇幅有限,这边仅做带过介绍,可以自行体验了解。

8、总结

通过利用以上提到的6种策略,您可以增强对 K8S 部署的行为和性能的理解。实施这些策略将提供对分布式系统的全面洞察,从而实现高效的故障排除、性能优化、主动问题检测和改进的用户体验。

无论您是在运营小规模 K8S 环境还是管理复杂的混合云部署,应用这些策略都将有助于应用程序的成功和可靠性的提升。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/26704.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

命令模式 Command Pattern 《游戏设计模式》学习笔记

对于一般的按键输入,我们通常这么做,直接if按了什么键,就执行相应的操作 在这里我们是将用户的输入和程序行为硬编码在一起,这是我们很自然就想到的最快的做法。 但是如果这是一个大型游戏,往往我们需要实现一个按键…

研发工程师玩转Kubernetes——hostPath

有别于《研发工程师玩转Kubernetes——emptyDir》一文中介绍的emptyDir,hostPath可以在同一个Node的不同Pod间共享卷。 下面的清单文件利用了Pod亲和性,让Pod集中到一个Node上。 apiVersion: apps/v1 kind: Deployment metadata:name: hostpath-deploy…

中间人攻击

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、启动 Kali Linux准备 Apache 服务器使用Ettercap插件进行欺骗使用 Wireshark 捕获 Https 流量总结 前言 您可能已经熟悉中间人攻击:攻击者通过…

网络安全(秋招)如何拿到offer?(含面试题)

以下为网络安全各个方向涉及的面试题,星数越多代表问题出现的几率越大,祝各位都能找到满意的工作。 注:本套面试题,已整理成pdf文档,但内容还在持续更新中,因为无论如何都不可能覆盖所有的面试问题&#xf…

C语言预处理命令 #error 学习

#error命令是C/C语言的预处理命令之一,当预处理器预处理到#error命令时将停止编译并输出用户自定义的错误消息。 如下代码输出数字1000,如果加了 #error,构建时不会通过,提示出错如下; 这可能在大型项目中比较有用&am…

8.4一日总结

1.远程仓库的提交方式(免密提交) a.ssh:隧道加密传输协议,一般用来登录远程服务器 b.使用 git clone 仓库名 配置(生成公私钥对) ssh-Keygen [-t rsa -C 邮箱地址] 通过执行上述命令,全程回车,就会在~/.ssh/id_rsa(私钥)和id_rsa.pub(公钥),私钥是必须要保存好的,并不能…

TeeChart NET for MAUI Crack

TeeChart NET for MAUI Crack 跨平台图表-移动或桌面应用程序的核心图表代码相同。 图表集合-60多种图表类型和50多种财务和统计指标。 图表类型 60多种2D和3D图表类型以及多种组合,包括: 标准:线条(条形)、条形、区域、饼图、快线、点(散点…

【Java可执行命令】(十七)JVM运行时信息动态维护工具 jinfo:一个维护 JVM 相关的配置参数和系统属性的工具,辅助故障排除、诊断和优化 ~

Java可执行命令之jinfo 1️⃣ 概念2️⃣ 优势和缺点3️⃣ 使用3.1 语法格式3.2 -flags&#xff1a;查看进程的启动参数3.3 -sysprops&#xff1a;查看进程的系统属性3.4 -flag < name>&#xff1a;查看特定虚拟机参数的值3.5 -flag [/-]< name>&#xff1a;启用或禁…

2023年8月份华为H12-811更新了

801、[单选题]178/832、在系统视图下键入什么命令可以切换到用户视图? A quit B souter C system-view D user-view 试题答案&#xff1a;A 试题解析&#xff1a;在系统视图下键入quit命令退出到用户视图。因此答案选A。 802、[单选题]“网络管理员在三层交换机上创建了V…

【CSS】CSS 选择器

CSS 选择器 1.基础选择器 1.1 元素选择器 语法&#xff1a;标签名{...} 元素选择器会选中对应标签名的HTML元素&#xff0c;例如&#xff1a;p{...}&#xff0c;div{...}&#xff0c;span{...}等 1.2 类选择器 语法&#xff1a;.类名{...} 类选择器会选中class属性为指定…

配置两台数据库为主从数据库模式

一、主库配置 1、修改配置文件 /etc/my3306.cnf #mysql服务ID&#xff0c;保证整个集群环境中唯一&#xff0c;默认为1server-id1#是否只读&#xff0c;1代表只读&#xff0c;0代表读写read-only0#忽略的数据&#xff0c;指不需要同步的数据库#binlog-ignore-dbmysql#指定同步…

OSPF作业3

题目 地址配置 R1&#xff1a; R2&#xff1a; R3&#xff1a; R4&#xff1a; R5&#xff1a; R6&#xff1a; R7&#xff1a; R8&#xff1a; R9&#xff1a; R10&#xff1a; R11&#xff1a; R12&#xff1a; 私网通及LSDB优化 R1&#xff1a; ospf 1 router-id 1.1.1.1 …

【图论】强连通分量进阶

一.作用 强连通分量可以判断环和进行缩点。还有一系列作用.... 这篇文章介绍缩点 二.题目 https://www.luogu.com.cn/problem/P2341 三.思路 我们分析可以知道当一个点没有出度时&#xff0c;则为最受欢迎的牛。但如果有多个出度&#xff0c;则没有最受欢迎的牛。 这是只有…

AcWing 93:递归实现组合型枚举 ← DFS

【题目来源】https://www.acwing.com/problem/content/95/【题目描述】 从 1∼n 这 n 个整数中随机选出 m 个&#xff0c;输出所有可能的选择方案。【输入格式】 两个整数 n&#xff0c;m&#xff0c;在同一行用空格隔开。【输出格式】 按照从小到大的顺序输出所有方案&#xf…

【TypeScript】交叉类型联合类型(四)

【TypeScript】交叉类型&联合类型&#xff08;四&#xff09; 【TypeScript】交叉类型&联合类型&#xff08;四&#xff09;一、简介二、交叉类型2.1 交叉类型使用的注意点2.2 基本数据类型交叉2.3 对象类型交叉 三、联合类型四、类型缩减 一、简介 TypeScript 中的交…

用于实体对齐的联合学习实体和关系表示2019 AAAI 8.7

用于实体对齐的联合学习实体和关系表示 摘要介绍相关工作实体对齐图卷积网络 问题公式我们的方法整体架构初步实体对齐图卷积层近似关系表示联合实体和关系对齐 实验总结 摘要 实体对齐是在不同知识图之间集成异构知识的一种可行方法。该领域的最新发展通常采用基于嵌入的方法…

Neo4j笔记-数据迁移(导出/导入)

这里先说明以下几点&#xff1a; Neo4j在4.0下版本默认的库名是&#xff1a;graph.db Neo4j在4.0上版本默认的库名是&#xff1a;neo4j.db 不管是Neo4j&#xff0c;还是Neo4j Desktop&#xff0c;都会在bin目录下有neo4j、neo4j-admin软件。在conf目录下&#xff0c;有neo4j.…

【状态估计】一维粒子滤波研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

代理模式(C++)

定义 为其他对象提供一种代理以控制(隔离&#xff0c;使用接口)对这个对象的访问。。 应用场景 在面向对象系统中&#xff0c;有些对象由于某种原因(比如对象创建的开销很大&#xff0c;或者某些操作需要安全控制&#xff0c;或者需要进程外的访问等)直接访问会给使用者、或…

Pytorch迁移学习使用MobileNet v3网络模型进行猫狗预测二分类

目录 1. MobileNet 1.1 MobileNet v1 1.1.1 深度可分离卷积 1.1.2 宽度和分辨率调整 1.2 MobileNet v2 1.2.1 倒残差模块 1.3 MobileNet v3 1.3.1 MobieNet V3 Block 1.3.2 MobileNet V3-Large网络结构 1.3.3 MobileNet V3预测猫狗二分类问题 送书活动 1. MobileNet …