【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 小时前
Kubernetes 配置检查与发布安全清单
安全·容器·kubernetes
感哥2 小时前
Docker网络
docker
xy_recording2 小时前
Day20 K8S学习
学习·容器·kubernetes
九章云极AladdinEdu3 小时前
Kubernetes设备插件开发实战:实现GPU拓扑感知调度
人工智能·机器学习·云原生·容器·kubernetes·迁移学习·gpu算力
泡沫冰@3 小时前
K8S集群管理(4)
云原生·容器·kubernetes
蒋星熠3 小时前
深入 Kubernetes:从零到生产的工程实践与原理洞察
人工智能·spring boot·微服务·云原生·容器·架构·kubernetes
泡沫冰@4 小时前
K8S集群管理(2)
云原生·容器·kubernetes
敲上瘾4 小时前
Docker 存储卷(Volume)核心概念、类型与操作指南
linux·服务器·数据库·docker·容器·架构
IT利刃出鞘5 小时前
Docker--宿主机和容器相互拷贝文件
运维·docker·容器
学Linux的语莫7 小时前
kubekey离线搭建k8s高版本>23安装,cri-dockerd通信
云原生·容器·kubernetes