【docker】资源使用率验证及告警

说明

Docker资源使用率可以通过以下命令进行验证:

使用 docker stats 命令查看容器的实时资源使用情况,例如:

bash 复制代码
docker stats <container_id>

该命令会展示容器的CPU、内存、网络IO、磁盘IO等各项资源的使用情况。2. 使用 docker stats 命令结合 --no-stream 参数导出容器的资源使用情况快照,例如:

bash 复制代码
docker stats --no-stream <container_id> > stats.txt

该命令将容器的资源使用情况快照导出到 stats.txt 文件中,可以在需要时查看。3. 使用 top 命令查看容器的资源使用情况,例如:

bash 复制代码
docker exec -it <container_id> top

该命令会展示容器中运行的进程信息,包括CPU、内存等资源的使用情况。

脚本

bash 复制代码
#!/bin/bash

cd `dirname $0`

hostname=$(hostname)
ip=$(/sbin/ifconfig -a | grep inet | grep -v 127.0.0.1 | grep -v inet6 | grep -E "10|192" | awk '{print $2}')

# 获取docker的资源使用情况
ids=`docker ps | awk '{print $1}'`

if [ -n "${ids}" ]; then
   index=0 
   for id in ${ids}
    do
       # 删除第一行的数据i
       if [[ $index == 0 ]]; then
	        index=1
	        continue
        fi

        # docker 资源使用率
	    resource=`docker stats --no-stream | grep $id`
	    echo "$resource"
	
	    # 名称
	    docker_name=`echo $resource | awk '{print $2}'`
	    echo "docker名称:$docker_name"
	
	    # cpu使用率
	    cpu_rate=`echo $resource | awk '{print $3}'`
	    echo "CPU使用率:$cpu_rate"
	
	    # 内存使用
	    mem_used=`echo $resource | awk '{print $4}'`
	    mem_total=`echo $resource | awk '{print $6}'`
	    mem_rate=`echo $resource | awk '{print $7}'`
	    echo "内存: 总共$mem_total,已用$mem_used,使用率$mem_rate"
	
	    # 网络
        net_input=`echo $resource | awk '{print $8}'`
        net_output=`echo $resource | awk '{print $10}'`
        echo "网路流量:流入$net_input,流出$net_output"
	
	    # 磁盘读写
	    block_in=`echo $resource | awk '{print $11}'`
	    block_out=`echo $resource | awk '{print $13}'`
	    echo "磁盘:写$block_in,读$block_out"
	
	    # 进程数量
        pids=`echo $resource | awk '{print $14}'`
        echo "进程数:$pids"
	
	    # 逻辑验证,发送告警

    done
fi

结果

相关推荐
糠帅傅蓝烧牛肉面12 小时前
单实例多MCP聚合服务:两种实现方案深度对比
前端·docker·ai
汪碧康13 小时前
一文掌握k8s的升级更新策略
云原生·容器·kubernetes·k8s·亲和性·xkube
杨浦老苏15 小时前
离线优先的自托管笔记应用Anchor
笔记·docker·群晖
zcz160712782115 小时前
docker部署 WVP-Pro
容器
AC赳赳老秦17 小时前
Kubernetes 与 DeepSeek:高效 Pod 部署配置与资源调度优化指南
人工智能·云原生·容器·kubernetes·自动化·notepad++·deepseek
阿方索18 小时前
Kubernetes Pod 管理
云原生·容器·kubernetes
哪里不会点哪里.18 小时前
Docker
运维·docker·容器
汪碧康19 小时前
一文掌握k8s的健康检查探针
云原生·容器·kubernetes·k8s·xkube·k8s管理平台
七七powerful19 小时前
docker 搭建wtsap代理
运维·docker·容器