现在想要监控服务的流量和并发数,可是又没那么多时间来写系统,其他的运维系统又不熟悉,于是就用现有的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的更多相关文章

  1. ReadDirectoryChangesW 监控文件夹 (一个简单的监控示例程序)(文件被修改了,也可以探测到)

    // .h文件 #pragma once typedef void (*PFN_NotifyAction)(DWORD dwAction, LPWSTR szFile, DWORD dwLength) ...

  2. [rrdtool]监控和自己主动绘图,简单的监控.md

    如今想要监控服务的流量和并发数,但是又没那么多时间来写系统.其它的运维系统又不熟悉,于是就用现有的rrdtool shell做了个简单的监控界面,暂时用下,也算是个小实验把. rrdtool也是刚接触 ...

  3. zabbix通过简单命令监控elasticsearch集群状态

    简单命令监控elasticsearch集群状态 原理: 使用curl命令模拟访问任意一个es节点可以反馈的集群状态,集群的状态需要为green curl -sXGET http://serverip: ...

  4. Linux监控二之cacti简单安装部署

    目录 cacti简单部署    1 环境依赖包部署    1 1.    cacti中文版0.8e搭建    2 2.    cacti安装向导 url:http://192.168.200.243/ ...

  5. zabbix模板的自动发现规则(ldd)实现被监控项自动发现

    zabbix模板的自动发现规则(ldd)实现被监控项自动发现 自动发现规则(ldd)用途说明 在zabbix自带的linux模板的自动发现规则中,有一个Mounted filesystem disco ...

  6. 探索Windows Azure 监控和自动伸缩系列1 - 连接中国区Azure

    最近准备基于Microsoft Azure Management Libraries 实现虚拟机的监控.主要的需求就是获取虚拟机内置的性能计数器数据,基于性能计数器实现后续的监控和自动伸缩. 作为这一 ...

  7. python简单的监控脚本-利用socket、psutil阻止远程主机运行特定程序

    python简单的监控脚本-利用socket.psutil阻止远程主机运行特定程序 psutil是一个跨平台的库(http://code.google.com/p/psutil/),能够轻松的实现获取 ...

  8. zabbix 添加自动发现端口并监控

    最近在部署zabbix监控  有些服务器上开启的服务端口非常多  如果一个个添加监控会很繁琐,于是想到了自动发现规则  自动发现服务器上的服务端口并进行监控. 在zabbix客户端服务器上进行操作 1 ...

  9. 运维监控篇(2)_Zabbix简单的性能调优

    Zabbix是一款高性能的分布式监控报警系统.比如现在常见的家用台式机配置处理器I5-3470.内存4GB1600MHz.硬盘7200rpm就能够监控1000台左右的HOST,是的没错Zabbix就是 ...

随机推荐

  1. 我在 B 站学习深度学习(生动形象,跃然纸上)

    我在 B 站学习深度学习(生动形象,跃然纸上) 视频地址:https://www.bilibili.com/video/av16577449/ tensorflow123 http://tensorf ...

  2. RestTemplate的异常:Not enough variables available to expand

    原因:RestTemplate使用出错,我的情况是不知道这里要求用RestTemplate的使用格式,应该很多人都是这样吧?不过,看了下RestTemplate,感觉其实还是很好用的. RestTem ...

  3. 软件测试assert

    之前实习做过一段时间测试,现做个总结: 实习测试的是一款CM系统(case 系统),来记录IT部门处理的维修,服务,反馈,预定服务等case:b/s架构,人少小项目,实习时间短,去了已经快完工,主要测 ...

  4. Ubuntu14.04安装 HP DeskJet GT 5820 打印机的方法

    原创内容发表在 http://www.linuxdiyf.com/linux/25331.html 步骤就是: 这里(https://sourceforge.net/projects/hplip/fi ...

  5. ajax跨域请求问题及解决办法总结

    1.浏览器的同源策略及规避方法 目前,所有浏览器都实行同源政策.即协议.域名.端口都相同的URI称为"同源".不同源的url之间: a.无法读取cookie.localstorag ...

  6. 更新git源以便安装最新版本

    sudo add-apt-repository ppa:git-core/ppa sudo apt-get update

  7. comtypes加word 2013批量将pdf转换为doc

    office 2013很强大. import os import sys import re import comtypes.client wdFormatPDF = 17 def covx_to_p ...

  8. 使用Spring实现定时任务

    一.分类 从实现的技术上来分类,目前主要有三种技术(或者说有三种产品): Java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务.使用这种方式可 ...

  9. Android Studio精彩案例(六)《使用一个Demo涵盖补间动画所有知识》

    转载本专栏文章,请注明出处,尊重原创 .文章博客地址:道龙的博客 元旦假期里,闲的无事,看到美团加载数据的动画,就突想写个Demo把动画知识集成一下.后来想了想,还是直接用一个Demo来把所有动画知识 ...

  10. 【Android 应用开发】 Android 各种版本简介 ( Support 支持库版本 | Android Studio 版本 | Gradle 版本 | jcenter 库版本 )

    初学者遇到 Android Studio, 导入工程后, 会出现各种奇葩错误, 如果管理好各个插件, gradle, SDK, SDK Tools, 各种官方依赖库 的版本, 会将错误大大的减少; 这 ...