shell+kafka实现服务器健康数据搜集

今天有一个徒弟问我,分发、代理服务器都装有kafka,如何快速收集服务器的健康数据,每10秒就收集一次?

我当时听完之后,楞了一下,然后说出了我的见解:认为最快速的方法无法就是建议shell脚本直接采集,然后发送给nginx,nginx传入到kafka中。

但是徒弟又说,shell脚本已经有8年没有大型使用过啦,不太会,两个小时之内要,我又懵啦。

无奈,还是我自己来写吧,代码如下:

#!/bin/sh
while true
do
    cpuParam = `top -bn 1 | grep load | awk '{printf "\"cpuParam\":%.2f", $(NF-1)}'`
    memoryParam = `free -h | awk 'NR==2 {printf "\"memoryParam\":%.2f", $3/$2*100}'`
    diskParam = `df -h | grep -w '/' | awk '{printf $(NF-1)}' | awk -F'%' '{printf "\"diskParam\":%.2f",$1}'`
    curl -H "Content-Type: application/json" -X POST -d "{$cpuParam,$memoryParam,$diskParam}" "http://127.0.0.1:8080"
    sleep 10
done

这就是最简单的定时获取本服务器的内存参数、cpu参数及硬盘参数脚本

相关推荐
不爱学英文的码字机器39 分钟前
[操作系统] 进程等待
linux·运维·服务器
黑夜无路人40 分钟前
kafka消费端之再均衡
分布式·kafka
9毫米的幻想1 小时前
【Linux系统】—— 简易进度条的实现
linux·运维·服务器·c语言·c++
久绊A1 小时前
状态监控与流量分析
linux·运维
ThisIsClark2 小时前
【linux】xargs命令的使用方法详解
linux·运维·chrome·操作系统
文牧之3 小时前
MySQL的字符集(Character Set)和排序规则(Collation)
运维·数据库·mysql
wanger614 小时前
Kafka知识点总结
分布式·kafka·linq
陈志化5 小时前
kafka了解-笔记
笔记·分布式·kafka
一行16 小时前
docker配置国内源
运维·docker·容器