Docker Container 可观测性最佳实践

server/2024/12/29 4:37:03/

Docker Container 介绍

Docker Container( Docker 容器)是一种轻量级、可移植的、自给自足的软件运行环境,它在 Docker 引擎的宿主机上运行。容器在许多方面类似于虚拟机,但它们更轻量,因为它们不需要模拟整个操作系统。相反,容器共享宿主机的操作系统内核,并在用户空间中运行。

Docker 容器可观测对于确保容器化应用程序的性能、稳定性和可用性至关重要,本文主要以纯 Docker 环境下(非K8S ),构建 Container 的可观测性。

观测云

使用观测云可以轻松采集到容器的 cpu 、内存、网络、IO 等核心指标,并自动采集容器的标准输出日志,使用观测云可以有效地监控和管理容器化应用程序,一键实现容器可观测。

部署 DataKit

登录观测云,点击集成按钮,选择 DataKit,会自动生成安装 DataKit 命令。

DataKit 安装完成后,默认开启了 container 采集器,container 采集器主要采集 K8S 和 docker 容器的指标、日志等信息。执行命令 datakit monitor 可以数据查看采集情况,在 Inputs Info 中 logging/xxx 表明正在采集当前 xxx 容器的日志,container-mertic 表明正在采集容器的指标。

关键指标

MetricDescriptionTypeUnit
block_read_byteTotal number of bytes read from the container file system (only supported docker).intB
block_write_byteTotal number of bytes wrote to the container file system (only supported docker).intB
cpu_numbersThe number of the CPU core.intcount
cpu_usageThe percentage usage of CPU on system host.floatpercent
cpu_usage_base100The normalized cpu usage, with a maximum of 100%.floatpercent
mem_capacityThe total memory in the host machine.intB
mem_limitThe limit memory in the container.intB
mem_usageThe usage of the memory.intB
mem_used_percentThe percentage usage of the memory is calculated based on the capacity of host machine.floatpercent
mem_used_percent_base_limitThe percentage usage of the memory is calculated based on the limit.floatpercent
network_bytes_rcvdTotal number of bytes received from the network (only count the usage of the main process in the container, excluding loopback).intB
network_bytes_sentTotal number of bytes send to the network (only count the usage of the main process in the container, excluding loopback).intB

视图

登录观测云控制台,点击「场景」 -「新建仪表板」,输入 “docker” , 选择 “Docker 监控视图”,点击 “确定” 即可添加内置视图。

  • 概览

  • CPU & 内存

  • IO & Network

  • 日志

监控器(告警)

容器重启告警

容器启动时间小于5分钟,触发容器重启告警。

CPU 利用率告警

容器 cpu 使用率,基于宿主机总 cpu 百分比利用率进行判断触发告警。

内存利用率告警

容器内存使用率,基于容器内存限制(没有设置容器内存限制按照主机最大内存计算)进行判断触发告警。

监控效果
  • 重启告警

  • 监控自动恢复

总结

在观测云的助力下,一键部署 Agent,自动采集 Docker 相关的日志、指标等数据, 在平台一键开启监控 Dashboard 和监控器,实时观测容器运行情况,使容器可观测性变的方便、快捷、高效。


http://www.ppmy.cn/server/154098.html

相关文章

【数据结构】数据结构整体大纲

数据结构用来干什么的?很简单,存数据用的。 (这篇文章仅介绍数据结构的大纲,详细讲解放在后面的每一个章节中,逐个击破) 那为什么不直接使用数组、集合来存储呢 ——> 如果有成千上亿条数据呢&#xff…

华为 AI Agent:企业内部管理的智能变革引擎(11/30)

一、华为 AI Agent 引领企业管理新潮流 在当今数字化飞速发展的时代,企业内部管理的高效性与智能化成为了决定企业竞争力的关键因素。华为,作为全球领先的科技巨头,其 AI Agent 技术在企业内部管理中的应用正掀起一场全新的变革浪潮。 AI Ag…

二分查找 java

在一个有序的数组内查找目标值, 若找到返回索引,若找不到返回-1; 需求: 在数组arr( 采用升序排列,允许有重复值)中 ,查找目标值target 1: int i 0 设置初始索引 int jarr.length-1; 设置最终索引 2:设置i>j ,结束查找 3: 设置中间索引 int mfloor((ij)/2) 4: 如果 targ…

递归查询全量分页数据问题

项目需要全量同步对方的用户机构数据&#xff0c;对方限制了分页条件&#xff0c;就需要递归全量拖过来。下面是实例代码&#xff1a; // 最大条数 public abstract class BaseLoader<T> {private final static Integer PAGE_SIZE 1000;private Class<T> tClass;…

接口Mock技术介绍

相信学习过程序设计的读者朋友们&#xff0c;一定对“桩&#xff08;Stub&#xff09;”这个概念并不陌生。它是指用来替换一部分功能的程序代码段。桩程序代码段可以用来模拟已有程序的某些功或者是将实现的系统代码的一种临时替代方法。插桩方法被广泛应用于开发和测试工作中…

IP属地和所在地不一致什么意思?怎么换成另外一个地方的

在数字化时代&#xff0c;IP地址作为网络设备的唯一标识符&#xff0c;不仅关乎设备间的通信&#xff0c;还涉及到用户的网络身份与位置信息。然而&#xff0c;有时我们会发现&#xff0c;社交媒体或网络平台上显示的IP属地与用户的实际所在地并不一致。这种不一致现象引发了诸…

Java通过反射实现通用查询方法

JDBC连接数据库 public class BaseDao {protected Connection conn; // 连接对象protected PreparedStatement pstmt; // 执行对象protected ResultSet rs; // 结果集对象public Connection getConnection() {try {// 1、加载驱动 ctrl alt tClass.forName("com.m…

DS的使用

使用DS和[address]实现字的传送 要解决的问题:CPU从内存单元中要读取数据 要求&#xff1a;CPU要读取一个内存单元的时候&#xff0c;必须先给出这个内存单元的地址。 原理&#xff1a;在8086PC中&#xff0c;内存地址段地址和偏移地址组成(段地址:偏移地址) 解决方案 :DS和[a…