[rrdtool]监控和自动画图,简单的监控.md
现在想要监控服务的流量和并发数,可是又没那么多时间来写系统,其他的运维系统又不熟悉,于是就用现有的rrdtool shell做了个简单的监控界面,临时用下,也算是个小实验把。 rrdtool也是刚接触,算是一个小练习
流程
大致的流程是这样的(centos6操作系统)
- 初始化rrd数据库
- shell脚本定时更新rrd中的数据
- shell脚本定时画图(这里就画了一个24小时的)生成图片
- html,把图片包含里面。 界面可以直接访问
开发
初始化
主要就是2个功能,24小时流量图,24小时并发图(5分钟抽样,不是全部的实时监控)
rrdtool create eth1.rrd --step 300 \
DS:eth1_in:COUNTER:600:0:U \
DS:eth1_out:COUNTER:600:0:U \
RRA:AVERAGE:0.5:1:600 \
RRA:AVERAGE:0.5:4:600 \
RRA:AVERAGE:0.5:24:600 \
RRA:AVERAGE:0.5:288:730 \
RRA:MAX:0.5:1:600 \
RRA:MAX:0.5:4:600 \
RRA:MAX:0.5:24:600 \
RRA:MAX:0.5:288:730
rrdtool create curnum.rrd --step 300 \
DS:num:GAUGE:600:0:U \
RRA:AVERAGE:0.5:1:600 \
RRA:AVERAGE:0.5:4:600 \
RRA:AVERAGE:0.5:24:600 \
RRA:AVERAGE:0.5:288:730 \
RRA:MAX:0.5:1:600 \
RRA:MAX:0.5:4:600 \
RRA:MAX:0.5:24:600 \
RRA:MAX:0.5:288:730
更新数据
更新脚本,并画图,假如cron,5分钟一次
*/5 * * * * /bin/sh /home/erya/run/monitor/rrd_update.sh >/dev/null 2>&1
[root@localhost moniter]# cat rrd_update.sh
#!/bin/bash
#orangleliu
#centos 获取某个网卡某个时间 收发包的大小
eth_name="eth1"
in=$(cat /proc/net/dev|grep eth1|cut -d ':' -f 2|awk '{print $1}')
out=$(cat /proc/net/dev|grep eth1|cut -d ':' -f 2|awk '{print $9}')
curnum=$(netstat -nat|grep ESTABLISHED|wc -l)
echo "$eth_name int is ${in}"
echo "$eth_name out is ${out}"
echo "curnum is ${curnum}"
#udpate rrd
rrd_dir=/home/erya/run/monitor
/usr/bin/rrdtool updatev ${rrd_dir}/eth1.rrd N:${in}:${out}
/usr/bin/rrdtool updatev ${rrd_dir}/curnum.rrd N:${curnum}
定时画图
画图脚本,每5分钟一次(cron, 或者追加在更新脚本的最后部分
*/5 * * * * /bin/sh /home/erya/run/monitor/rrd_graph.sh >/dev/null 2>&1
#!/bin/bash
#5分钟画图一次,给页面访问
cd /home/erya/run/monitor
/usr/bin/rrdtool graph net.png \
--start -86400 --end now \
--title "100 server net flow 1 day" \
DEF:value1=eth1.rrd:eth1_in:AVERAGE \
DEF:value2=eth1.rrd:eth2_out:AVERAGE \
AREA:value1#00ff00:in \
LINE2:value2#ff0000:out:STACK
/usr/bin/rrdtool graph curnum.png \
--start -86400 --end now \
--title "100 server concurrency number 24 hours" \
DEF:value1=curnum.rrd:num:AVERAGE \
AREA:value1#00ff00:num
然后我写了一个html,把两个图片包含进去,配置到nginx 中(就是几个location),就可以直接从浏览器访问了。
也算是,超级简陋的监控方式把。
界面
root@localhost moniter]# cat monitor.html
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<tilte> 100服务器流量 并发监控图</title>
</head>
<body>
<h3>24小时内流量趋势</h3>
<img src="http://xxx/rrd/net.png" />
<h3>24小时内并发趋势</h3>
<img src="http://xxx/rrd/curnum.png" />
</body>
</html>
nginx配置片段
location ^~/rrd/net.png {
alias /home/erya/run/monitor/net.png;
}
location ^~/rrd/curnum.png {
alias /home/erya/run/monitor/curnum.png;
}
location ^~/rrd/monitor.html {
alias /home/erya/run/monitor/monitor.html;
}
效果图
声明:
本文出自 “orangleliu笔记本” 博客,转载请务必保留此出处http://blog.csdn.net/orangleliu/article/details/46739853作者orangleliu 采用署名-非商业性使用-相同方式共享协议
[rrdtool]监控和自动画图,简单的监控.md的更多相关文章
- ReadDirectoryChangesW 监控文件夹 (一个简单的监控示例程序)(文件被修改了,也可以探测到)
// .h文件 #pragma once typedef void (*PFN_NotifyAction)(DWORD dwAction, LPWSTR szFile, DWORD dwLength) ...
- [rrdtool]监控和自己主动绘图,简单的监控.md
如今想要监控服务的流量和并发数,但是又没那么多时间来写系统.其它的运维系统又不熟悉,于是就用现有的rrdtool shell做了个简单的监控界面,暂时用下,也算是个小实验把. rrdtool也是刚接触 ...
- zabbix通过简单命令监控elasticsearch集群状态
简单命令监控elasticsearch集群状态 原理: 使用curl命令模拟访问任意一个es节点可以反馈的集群状态,集群的状态需要为green curl -sXGET http://serverip: ...
- Linux监控二之cacti简单安装部署
目录 cacti简单部署 1 环境依赖包部署 1 1. cacti中文版0.8e搭建 2 2. cacti安装向导 url:http://192.168.200.243/ ...
- zabbix模板的自动发现规则(ldd)实现被监控项自动发现
zabbix模板的自动发现规则(ldd)实现被监控项自动发现 自动发现规则(ldd)用途说明 在zabbix自带的linux模板的自动发现规则中,有一个Mounted filesystem disco ...
- 探索Windows Azure 监控和自动伸缩系列1 - 连接中国区Azure
最近准备基于Microsoft Azure Management Libraries 实现虚拟机的监控.主要的需求就是获取虚拟机内置的性能计数器数据,基于性能计数器实现后续的监控和自动伸缩. 作为这一 ...
- python简单的监控脚本-利用socket、psutil阻止远程主机运行特定程序
python简单的监控脚本-利用socket.psutil阻止远程主机运行特定程序 psutil是一个跨平台的库(http://code.google.com/p/psutil/),能够轻松的实现获取 ...
- zabbix 添加自动发现端口并监控
最近在部署zabbix监控 有些服务器上开启的服务端口非常多 如果一个个添加监控会很繁琐,于是想到了自动发现规则 自动发现服务器上的服务端口并进行监控. 在zabbix客户端服务器上进行操作 1 ...
- 运维监控篇(2)_Zabbix简单的性能调优
Zabbix是一款高性能的分布式监控报警系统.比如现在常见的家用台式机配置处理器I5-3470.内存4GB1600MHz.硬盘7200rpm就能够监控1000台左右的HOST,是的没错Zabbix就是 ...
随机推荐
- JVM基础
1.基础 JDK 将java文件编译成class文件 JRE 包含JVM JVM可以进行内存管理 利用JDK(调用JAVA API)开发了属于我们自己的JAVA程序后,通过JDK中的编译程序(j ...
- instanceof的用法
转载自:http://blog.csdn.net/cnmilan/article/details/41696093package myPackage; /** * instanceof运算符用法 * ...
- 树莓派3B(2)- 配置多个wifi,自动寻找可用网络
一.背景 在上篇<Raspberry Pi 3B 安装系统并联网>中,树莓派使用wifi连接,但是把树莓派带到公司,树莓派就连不了公司的wifi,要是支持连接多个wifi就好了,在此整理分 ...
- 欢迎大家来到DevLegal的博客
申明:以下博文欢迎转载,转载请注明出处和作者 若非作者原创,则会标记出处与原作者,其余则为原创. 本人在校大学僧一枚,软件工程专业,希望通过将自己的学习心得与体会写出来,勉励自己学习,同时与大家一起分 ...
- Linux用户管理命令大全
1.添加用户,首先用adduser命令添加一个普通用户,命令如下: $ adduser tommy //添加一个名为tommy的用户 $ passwd tommy //修改密码 Changing pa ...
- python中修改字符串的几种方法
在Python中,字符串是不可变类型,即无法直接修改字符串的某一位字符.因此改变一个字符串的元素需要新建一个新的字符串.常见的修改方法有以下4种. 方法1:将字符串转换成列表后修改值,然后用join组 ...
- 安卓高级6 CoordinatorLayout
原作者大神地址:http://blog.csdn.net/huachao1001/article/details/51554608 曾在网上找了一些关于CoordinatorLayout的教程,大部分 ...
- 让你的代码量减少3倍!使用kotlin开发Android(一)
让你的代码量减少3倍!使用kotlin开发Android(一) 创建Kotlin工程 本文同步自博主的私人博客:wing的地方酒馆 写在前面 使用kotlin开发android已经两周多了.得到的好处 ...
- Lucene 6.0下使用IK分词器
Lucene 6.0使用IK分词器需要修改修改IKAnalyzer和IKTokenizer. 使用时先新建一个MyIKTokenizer类,一个MyIkAnalyzer类: MyIKTokenizer ...
- Java中常用缓存Cache机制的实现
缓存,就是将程序或系统经常要调用的对象存在内存中,一遍其使用时可以快速调用,不必再去创建新的重复的实例. 这样做可以减少系统开销,提高系统效率. 缓存主要可分为二大类: 一.通过文件缓存,顾名思义文件 ...