munin-因为plugin而亮

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介:

Munin is a networked resource monitoring tool that can help analyze resource trends and "what just happened to kill our performance?" problems. It is designed to be very plug and play. A default installation provides a lot of graphs with almost no work.

munin是一个网络监控软件。

munin是一个server-nodes的结构,一个server对应多台node,每台node就是被监控的节点,server是统计node的数据并进行绘图生成html的节点。server的配置文件是:/etc/munin/munin.conf ,每个node都有各自的配置文件:/etc/munin/munin-node.conf

 

先看一下最后的统计效果:

image

 

image

 

如何安装:

http://munin-monitoring.org/wiki/LinuxInstallation

 

谈及为什么使用munin,一定会提到的一点:munin能让使用者非常快捷方便的编写和使用插件。当需要定制某些特制的功能的时候,写一个插件的代价非常小。插件就是一个脚本,可以使用php,bash,perl等语言进行编写。下面以一个插件,使用php语言,完成统计redis的使用内存为例:

1 在有redis的机子上(192.168.0.19)安装munin-node

2 进入/usr/share/munin/plugins/ (其实在任意一个目录都是可以的)

3 创建文件redis_memory_

这里的redis_memory_最后一个下划线后面的内容我默认是希望填写端口号,因为我在192.168.0.19上有2个redis,分别放在7000和7001两个端口上

所以最后的redis插件应该是redis_memory_7000 和 redis_memory_7001

4 编辑redis_memory_

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#!/usr/local/bin/php
<?php
if  (isset($argv[1]) && $argv[1] == 'config' ) {
     
     echo 'graph_title redis_memory_'  . sGetPort($argv[0]) . PHP_EOL;
     echo 'graph_category open_message'  . PHP_EOL;
     echo 'graph_vlabel memory'  . PHP_EOL;
     echo 'memory.label memory'  . PHP_EOL;
     exit;
}
 
echo 'memory.value '  . iGetMemory(sGetPort($argv[0])) . PHP_EOL;
 
if  (isset($argv[1]) && $argv[1] == 'suggest' ) {
     echo '7000'  . PHP_EOL;
     echo '7001'  . PHP_EOL;
}
 
function iGetMemory($port)
{
     $cmd = sprintf( "/usr/local/bin/redis-cli -p %s info | grep '^used_memory:'|awk -F : '{print $2}'" , $port);
     return  exec($cmd);
}

 

a) 脚本成功的标志是

./redis_memory_ 能出现:memory.value 653653653

./redis_memroy_ config 能出现:

graph_title redis_memory_7000

graph_category open_message

graph_vlabel memory

memory.label memory

 

munin在生成图片的时候会调用这两个命令来生成统计图片的,graph_title是图片标题,graph_category是分类,memory.label 是memory的标签,graph_vlabel memory是纵坐标的内容,memory.value 是具体的值。

还有更多的属性:

http://munin-monitoring.org/wiki/protocol-config

 

b)这个脚本运行成功的条件有:

安装了php,并且php 命令安装在/usr/local/bin/php

安装了redis,redis-cli 安装在/usr/local/bin/redis-cli

c)我这边是使用redis-cli命令来取memory信息,当然也可以使用redis的客户端phpredis等来取

5 chmod +x redis_memory_

6 做链接(必须使用绝对路径)

ln –s /usr/share/munin/plugins/redis_memory_ /etc/munin/plugins/redis_memory_7000

ln –s /usr/share/munin/plugins/redis_memory_ /etc/munin/plugins/redis_memory_7001

7 设置有哪些server能进入munin取数据,/etc/munin/munin-node.conf

allow ^127\.0\.0\.1 a l l o w 1 92 \. 168 \. 0 \. 19

8 /etc/init.d/munin-node restart

 

 

server(192.168.0.19):

1 安装munin

2 修改/etc/munin/munin.conf

要修改的部分:

htmldir /home/yejianfeng/www/munin

要增加的部分:

[zwt-01] 
address 192.168.0.17 
use_node_name yes

 

好了,完成了。但是还有几个想说的:

1 如果在过程中出现错误, /var/log/munin/munin_node.log是非常好的信息记录

 

2 曾经被问过一个问题

为什么不在server端使用http来获取node的信息(比如要获取ngnix status或者redis的),这样node就不用配置munin-node了,这样在server同样可以生成图片。

我是这样说服自己的:

a) munin是使用tcp在server和node之间进行通信的,如果使用http,这就像是大炮换鸟枪的做法

b) 使用node模式有node的log,便于调试

c) 如果不使用server-node,那就相当于纯粹把munin当做画图工具而已,还不如XXOO

d) 如果不使用node的话category的排版会相当复杂

 

3 munin  server会每5分钟到node中进行munin node中进行取数据操作,所以,如果刚修改后发现图片还没变,请稍安勿躁。

 

一些有用的munin链接:

http://munin-monitoring.org

http://os.51cto.com/art/201012/238964.htm

http://huacnlee.com/blog/munin-plugin-seo-check-for-gogle-baidu-collected-pages/

http://munin-monitoring.org/wiki/protocol-config

http://blog.jploh.com/2007/06/14/how-to-install-munin-on-centos/

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
关系型数据库 Apache MySQL
|
JavaScript Java 应用服务中间件
|
JavaScript 前端开发
|
移动开发 监控 网络协议
|
JavaScript Apache 关系型数据库
|
关系型数据库 Apache MySQL
|
关系型数据库 MySQL Apache