【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

结果

相关推荐
凯新生物1 小时前
mPEG-SS-PLGA-DTX:智能药物递送系统
eureka·flink·ffmpeg·etcd
专家大圣2 小时前
摆脱局域网束缚!Neko+cpolar 让跨网共享成日常
服务器·网络·docker·内网穿透·cpolar
Haooog3 小时前
Docker面试题(不定时更新)
java·docker·面试
树下水月3 小时前
docker 启动后 如何通过对应的进程 找docker-compose.yaml 编排文件
运维·docker·容器
凯子坚持 c3 小时前
Docker 网络管理深度解析与实践指南
运维·docker·容器
kevin_水滴石穿4 小时前
在镜像生成时从内网获取字体安装包并配置
linux·docker·容器
人生匆匆4 小时前
部署使用rathole内网穿透
linux·运维·docker
LILR_4 小时前
简单学docker
运维·docker·容器
Empty_7775 小时前
K8S-网络原理
网络·容器·kubernetes
永不停歇的蜗牛5 小时前
K8S之创建cm指令create和 apply的区别
java·容器·kubernetes