【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

结果

相关推荐
iRayCheung4 小时前
Docker安装的mysql限制ip访问
tcp/ip·mysql·docker
SunTecTec8 小时前
Flink Docker Application Mode 命令解析 - 修改命令以启用 Web UI
大数据·前端·docker·flink
好记忆不如烂笔头abc8 小时前
HTTPSConnectionPool(host=‘files.pythonhosted.org‘, port=443): Read timed out.
docker
KubeSphere 云原生9 小时前
云原生周刊:Kubernetes v1.33 正式发布
云原生·容器·kubernetes
内网渗透10 小时前
OpenWrt 与 Docker:打造轻量级容器化应用平台技术分享
linux·docker·容器·openwrt·软路由
qq_3392822311 小时前
docker打开滚动日志
运维·docker·容器
Hoking11 小时前
SpringBoot应用原生或docker镜像容器集成Skywalking
docker·容器·skywalking
Kendra91912 小时前
Docker 容器虚拟化技术和自动化部署
docker·容器·自动化
ITCharge13 小时前
Docker 万字教程:从入门到掌握
后端·docker·容器
智想天开13 小时前
13.组合模式:思考与解读
docker·设计模式·容器·组合模式