Nagios check_logfiles插件的使用记录
1 获取与安装
https://labs.consol.de/assets/downloads/nagios/check_logfiles-3.7.4.tar.gz
链接可能会失效,建议去官网下载。
https://labs.consol.de/nagios/check_logfiles/
阅读官网的使用说明,但感觉还是不太明了,毕竟是英文 的,
http://blog.chinaunix.net/uid-261392-id-2138989.html
这是开源中国上面一兄弟写的介绍,让你入门。
tar xvf check_logfiles-3.7.4.tar.gz
./configure
make && make install
安装完成。
安装的时候使用的是root用户,安装后其实是在libexec下多了一个check_logfiles程序。
建议把该程序的owner改为nagios.nagiios.其实不改也可以,它的权限是其他组也可以执行。
chown nagios:nagios /usr/local/nagios/libexec/check_logfiles
2 我以在某节点dn42上监控datanode与nodemanager进程的日志为目标,做了一下处理
a. nagios目录/usr/local/nagios/下创建var/tmp目录,如果没有,并且权限要给nagios.nagios.
因为我们需要配置check_logfiles来存储状态文件和一些信息在这个目录里面。编译时未指定,它的默认目录可能没有访问权限。
b.创建配置文件,我放在/usr/local/nagios/etc/log.cfg
配置如下:
$seekfilesdir = '/usr/local/nagios/var/tmp';
$protocolsdir = '/usr/local/nagios/var/tmp';
$scriptpath = '/usr/local/nagios/var/tmp';
@searches = (
{
tag => 'dn42_datanode',
logfile => '/home/hadoop/app/hadoop/logs/hadoop-hadoop-datanode-dn42pub.log',
rotation => 'hadoop-hadoop-datanode-dn42pub.log.[0-9]',
criticalpatterns => [
'ERROR .*',
'FAILURE .*',
] },
{
tag => 'dn42_nm',
logfile => '/home/hadoop/app/hadoop/logs/yarn-hadoop-nodemanager-dn42pub.log',
rotation => 'yarn-hadoop-nodemanager-dn42pub.log.[0-9]',
criticalpatterns => [
'ERROR .*',
'FAILURE .*',
] },
);
我这里没有配置warningpatterns,暂时没有此需要,如果有需要可以配置上。
c.在nrpe里面配置命令:
command[check_logfiles]=/usr/local/nagios/libexec/check_logfiles -f /usr/local/nagios/etc/log.cfg
d.在nagios服务器端配置这台机器的配置文件,在原有的配置文件中添加新的服务。(原来我放在nn1上/usr/local/nagios/etc/servers/dn42pub.cfg中,只需要添加如下即可)
;;monitor hadoop datanode and nodemanager process log content
define service{
use test-service
host_name dn42pub
service_description log_check
check_command check_nrpe!check_logfiles
is_volatile
max_check_attempts
}
注意,我这里使用的test-service是我在template.cfg中配置的,重写了它的检查周期为一分钟,这里需要注意。
dn42端执行:service xinetd reload即可
在nagios服务器端使用命令 nagios –v /usr/local/nagios/etc/nagios.cfg
检查如果没有错误,使用service nagios reload即可。
但是我在web端看到是unknown状态,这是因为nagios用户没有对日志目录的访问权限。
遂做以下修改。
chmod 705 /home/hadoop
即可。
3。其他机器如果需要安装,则可以如下操作,
直接scp /usr/local/nagios/libexec/check_logfiles targethost:/usr/local/nagios/libexec
makedir –p /usr/local/nagios/var/tmp
chown –R nagios:nagios /usr/local/nagios/var/tmp
修改nrpe.cfg 和并复制修改log.cfg即可
常见的问题,
我们通常会有这样的考虑,第一次运用nagios来检查文件的时候,文件可能很大了,而且会有很多旧的错误,会不会超时之类的,那check_logfiles是怎么处理的呢?
如果你不把type=>'virtual',则它是不会从头检查文件的,它只会检查文件的字节数,存一个offset,下次才会读新的数据。这正是我们想要的。这个问题我邮件咨询了
作者,以下是他的回复。
If you run check_logfiles for the first time, it does not scan the file. It positions at the end of the file and saves the position. (If it would start from the beginning, you would get very old errors)
When you run check_logfiles for the second time, it reads the saved position and then reads the _new lines_ which were appended in the meantime.
check_logfiles only scans new lines. (normally. if you use type=virtual, it scans the whole file all the time)
Nagios check_logfiles插件的使用记录的更多相关文章
- 基于MVC4+EasyUI的Web开发框架经验总结(1)-利用jQuery Tags Input 插件显示选择记录
最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开发框架保持一致,而在Web上,我主要采用EasyUI的前端界面处理技术,走MVC的技术路线,在重 ...
- Nagios+pnp4nagios+rrdtool 安装配置为nagios添加自定义插件(三)
nagios博大精深,可以以shell.perl等语句为nagios写插件,来满足自己监控的需要.本文写mysql中tps.qps的插件,并把收集到的结果以图形形式展现出来,这样输出的结果就有一定的要 ...
- jQuery Tags Input 插件显示选择记录
利用jQuery Tags Input 插件显示选择记录 最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开发框架保持一致,而在Web上,我主要采 ...
- Eclipse 导入项目与 svn 插件关联全过程记录
文章摘自:http://www.cnblogs.com/xmmcn/archive/2013/03/01/2938365.html 感谢博友分享! Eclipse 导入项目与 svn 插件关联全过程记 ...
- (转)基于MVC4+EasyUI的Web开发框架经验总结(1)-利用jQuery Tags Input 插件显示选择记录
http://www.cnblogs.com/wuhuacong/p/3667703.html 最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开 ...
- Unity3D框架插件uFrame实践记录(一)
1.概览 uFrame是提供给Unity3D开发者使用的一个框架插件,它本身模仿了MVVM这种架构模式(事实上并不包含Model部分,且多出了Controller部分).因为用于Unity3D,所以它 ...
- Nagios 自定义插件与安装使用之监控dead datanodes
现在我使用nagios来监控hadoop的核心进程,rm,nm,dn,nn,zkfc,jn,zk等,但是有时候进程虽然还在,但是日志不刷新,web ui上可以看到有些datanodes节点已经变为de ...
- 项目中jquery插件ztree使用记录
最近公司要求做一个关于后台的管理系统.在这个mvvm模式横行的年代,虽然这里用jquery做项目可能有点不符合时代的潮流,但是管他呢,能做出来先在说呗(公司以后要改用angular或者vue来统一前端 ...
- Jquery_AjaxFileUpload插件的使用记录
功能需求:Spring MVC框架下,实现无刷新页面上传图片,并展示图片预览效果 直接上代码: 1.图片预览效果 <%@ page contentType="text/html;cha ...
随机推荐
- java RSA加解密以及用途
在公司当前版本的中间件通信框架中,为了防止非授权第三方和到期客户端的连接,我们通过AES和RSA两种方式的加解密策略进行认证.对于非对称RSA加解密,因为其性能耗费较大,一般仅用于认证连接,不会用于每 ...
- .NET DLR 上的IronScheme 语言互操作&&IronScheme控制台输入中文的问题
前言 一直以来对Lisp语言怀有很崇敬的心里,<黑客与画家>对Lisp更是推崇备至,虽然看了不少有关Lisp的介绍但都没有机会去写段程序试试,就像我对C++一样,多少有点敬畏.这个周末花了 ...
- ImageLightbox.js – 响应式的图片 Lightbox 插件
ImageLightbox.js 是一款很简洁的用于显示图片灯箱效果(Lightbox)的插件,没有字幕,导航按钮或默认背景.如果默认功能不够用的话,你可以很容易地自定义 JavaScript 函数扩 ...
- [deviceone开发]-纳豆项目源码开源
一.简介 已上线的纳豆项目开源.这个App做的非常好,细节处理的很流畅,使用了很多小的动画效果,极力推荐,很多功能可以从这个应用中获取代码和灵感. 二.效果图 三.相关下载 androi ...
- C语言 指针例解
在计算机科学中,指针(Pointer)是编程语言中的一个对象,利用地址,它的值直接指向(points to)存在电脑存储器中另一个地方的值.由于通过地址能找到所需的变量单元,可以说,地址指向该变量单元 ...
- AE_复制当前图层
private void 复制ToolStripMenuItem_Click(object sender, EventArgs e) { int layercount = axMapControl2. ...
- CRM 2015 快速抓取表单上字段
var table='<table><tr><td>序号</td><td>字段名</td><td>Schema名称& ...
- APP One Link ,android and ios qrcode merge as One QRCode and one short link
Adroid and ios qrcode merge as One QRCode and one short link is publish , the web site is www.appone ...
- Net.Sf.Json java Object to JsonObject
public class People{ private String name; public void setName(String name){ this.name = name; } publ ...
- iOS 中内存分配与分区
关于RAM ROM RAM与ROM就是具体的存储空间,统称为存储器 RAM(random access memory):运行内存,CPU可以直接访问,读写速度非常快,但是不能掉电存储.它又分为: 动态 ...