zabbix自定义监控(服务进程和日志)

zabbix自定义监控

自定义监控进程

测试监控httpd,需要在监控端部署httpd,以方便监控

配置监控脚本

#在监控端
[root@localhost ~]# dnf -y install httpd
[root@localhost ~]# systemctl start httpd
[root@localhost ~]# ss -anlt | grep 80
LISTEN 0      128                *:80               *:*

#编写脚本
[root@localhost ~]# mkdir /scripts
[root@localhost ~]# vim /scripts/check_process.sh
#!/bin/bash

count=$(ps -ef|grep -Ev "grep|$0" | grep $1 | wc -l)
if [  $count -eq 0 ];then
        echo '1'
else
        echo '0'
fi
[root@localhost ~]# chmod +x /scripts/check_process.sh
[root@localhost ~]# ll /scripts/check_process.sh
-rwxr-xr-x. 1 root root 119 Sep  6 21:09 /scripts/check_process.sh

#在监控端,修改配置文件
[root@localhost ~]# vim /usr/local/etc/zabbix_agentd.conf
UnsafeUserParameters=1
UnsafeUserParameters=check_process[*],/bin/bash /scripts/check_process.sh $1

#服务端检查key是否可用
[root@zabbix ~]# zabbix_get -s 192.168.111.137 -k check_process[httpd]
0
[root@zabbix ~]# zabbix_get -s 192.168.111.137 -k check_process[mysql]
1
[root@zabbix ~]# zabbix_get -s 192.168.111.137 -k check_process[zabbix]
0

添加监控项

zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)
查看监控数据
zabbix自定义监控(服务进程和日志)

添加触发器

zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)

手动关闭httpd,进行测试触发报警

[root@localhost ~]# systemctl stop httpd

查看报错

zabbix自定义监控(服务进程和日志)

发送邮件

zabbix自定义监控(服务进程和日志)

查看邮件

zabbix自定义监控(服务进程和日志)

自定义监控日志

初学者复制的脚本
忘情的log脚本日志

#由于是python的脚本,需要在python环境中
[root@localhost ~]# dnf -y install python36

#编写脚本
[root@localhost ~]# cd /etc/scripts/
[root@localhost scripts]# vim log.py
#!/usr/bin/env python3
import sys
import re

def prePos(seekfile):
    global curpos
    global curpos
    try:
        cf = open(seekfile)
    except IOError:
        curpos = 0
        return curpos
    except FileNotFoundError:
        curpos = 0
        return curpos
    else:
        try:
            curpos = int(cf.readline().strip())
        except ValueError:
            curpos = 0
            cf.close()
            return curpos
        cf.close()
    return curpos

def lastPos(filename):
    with open(filename) as lfile:
        if lfile.readline():
            lfile.seek(0,2)
        else:
            return 0
        lastPos = lfile.tell()
    return lastPos

def getSeekFile():
    try:
        seekfile = sys.argv[2]
    except IndexError:
        seekfile = '/tmp/logseek'
    return seekfile

def getKey():
    try:
        tagKey = str(sys.argv[3])
    except IndexError:
        tagKey = 'Error'
     return tagKey

 def getResult(filename,seekfile,tagkey):
     destPos = prePos(seekfile)
     curPos = lastPos(filename)

     if curPos < destPos:
         curpos = 0

    try:
        f = open(filename)
    except IOError:
        print('Could not open file: %s' % filename)
    except FileNotFoundError:
        print('Could not open file: %s' % filename)
    else:
        f.seek(destPos)

        while curPos != 0 and f.tell() < curPos:
            rresult = f.readline().strip()
            global result
            if re.search(tagkey, rresult):
                result = 1
                break
            else:
                result = 0

        with open(seekfile,'w') as sf:
            sf.write(str(curPos))
        finally:
            f.close()
        return result

if __name__ == "__main__":
    result = 0
    curpos = 0
    tagkey = getKey()
    seekfile = getSeekFile()
    result = getResult(sys.argv[1],seekfile,tagkey)
    print(result)
[root@localhost scripts]# chmod +x log.py
[root@localhost scripts]# ll
total 12
-rwxr-xr-x. 1 root root  128 Sep  6 21:53  check_process.sh
-rwxr-xr-x. 1 root root 1890 Sep  6 22:49  log.py

#&#x4FEE;&#x6539;&#x914D;&#x7F6E;&#x6587;&#x4EF6;
[root@localhost ~]# vim /usr/local/etc/zabbix_agentd.conf
UserParameter=check_logs[*],/etc/scripts/log.py $1 $2 $3
[root@localhost ~]# pkill zabbix
[root@localhost ~]# zabbix_agentd

#&#x9700;&#x8981;&#x7ED9;/var/log/httpd&#x76EE;&#x5F55;&#x6DFB;&#x52A0;&#x6743;&#x9650;
[root@localhost ~]# chmod 755 /var/log/httpd/
[root@localhost ~]# ll /var/log/httpd/
total 8
-rw-r--r--. 1 root root  704 Sep  6 21:42 access_log
-rw-r--r--. 1 root root 2635 Sep  6 22:12 error_log
#&#x7ED9;httpd&#x7684;error&#x65E5;&#x5FD7;&#xFF0C;&#x6DFB;&#x52A0;&#x4E00;&#x4E2A;&#x9519;&#x8BEF;&#x4FE1;&#x606F;
[root@localhost ~]# echo "Error" >> /var/log/httpd/error_log
#&#x670D;&#x52A1;&#x7AEF;&#x6D4B;&#x8BD5;
[root@zabbix ~]# zabbix_get -s 192.168.111.137 -k check_logs['/var/log/httpd/error_log']
1
[root@zabbix ~]# zabbix_get -s 192.168.111.137 -k check_logs['/var/log/httpd/error_log']
0

添加监控项

zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)

添加触发器

zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)
zabbix自定义监控(服务进程和日志)

手动添加错误日志,触发报警

[root@localhost httpd]# echo "Error123" >> /var/log/httpd/error_log

zabbix自定义监控(服务进程和日志)

zabbix自定义监控(服务进程和日志)

Original: https://www.cnblogs.com/Their-own/p/16663203.html
Author: 事愿人为
Title: zabbix自定义监控(服务进程和日志)

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/612481/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 送分题,ArrayList 的扩容机制了解吗?

    1. ArrayList 了解过吗?它是啥?有啥用? 众所周知,Java 集合框架拥有两大接口 Collection 和 Map,其中, Collection 麾下三生子 List…

    数据库 2023年6月6日
    0113
  • JDK安装

    环境变量–>新建JAVA_HOME–>D:\Environment\java\jdk1.8 配置path变量–>新建%JAVA…

    数据库 2023年6月11日
    0120
  • 计算机组成原理——组成篇

    计算机的总线 1 、总线的作用及概述 解决设备间通讯问题。 总线是为了解决不同设备之间的通信问题。 总线可以连接CPU和IO设备。 2 、总线分类:片内总线、系统总线 片内总线:连…

    数据库 2023年6月16日
    098
  • 工作中常用Less知识点实践总结

    工作中常用Less知识点实践总结,帮助你更好的使用Less 我所理解的Less的一些好处 函数式编程css 自定义变量用于整体主题调整 嵌套语法简化开发复杂度 mixin的写法 ….

    数据库 2023年6月11日
    0122
  • MySQL存储过程和函数

    存储过程与函数 类似与Java的方法和C语言的函数 存储过程概述 含义 一组经过 预先编译的SQL语句的封装 执行过程:存储过程预先存储在MySQL服务器上,客户端发出命令后,服务…

    数据库 2023年5月24日
    0112
  • Linux–>定时任务调度

    指定系统在某个时间执行特点的命令或程序。 任务调度分类: crontab 选项 常用选项 选项 说明 -e 编辑crontab定时任务 -l 查询crontab任务 -r 删除当前…

    数据库 2023年6月14日
    0100
  • MySql 删除数据表

    定义: 删除数据表就是删除数据库中已经存在的表。请注意,当表被删除时,表的定义和表中的所有数据都将被删除。因此,在执行删除操作之前,最好对表中的数据进行备份,以避免无法挽回的后果。…

    数据库 2023年5月24日
    0135
  • navicat~导出数据库密码

    当我们mysql密码忘记了,而在navicat里有记录,我们应该如何导出这个密码呢? 第一步:文件菜单,导出链接,导出连接获取到 connections.ncx 文件 这里需要勾选…

    数据库 2023年5月24日
    0220
  • 第十八章 AOP底层实现原理

    1.核心问题 1. AOP如何创建动态代理类 2. Spring工厂如何加工创建代理对象 通过原始对象的id值,获得的是代理对象 2.动态代理类的创建 2.1 JDK动态代理 通过…

    数据库 2023年6月14日
    0153
  • 23种设计模式之模板模式

    文章目录 概述 模版模式的优缺点 * 优点 缺点 模版模式的使用场景 模板模式的结构和实现 * 模式结构 模式实现 总结 ; 概述 模板模式指:一个抽象类中,有一个主方法,再定义1…

    数据库 2023年6月6日
    0122
  • 06-ElasticSearch搜索结果处理

    * package com.coolman.hotel.test; import com.coolman.hotel.pojo.HotelDoc; import com.faste…

    数据库 2023年6月16日
    0136
  • mysql视图,索引

    一、视图 View 视图是一个 虚拟表,是sql语句的查询结果,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据,在使用视图时动态生成。视图的数据变化会影响到基…

    数据库 2023年6月9日
    090
  • Vue(十一)—key特殊attribute

    预期: number | string | boolean (2.4.2 &#x65B0;&#x589E;) | symbol (2.5.12 &#x65B…

    数据库 2023年6月16日
    0134
  • js异步编程终级解决方案 async/await

    在最新的ES7(ES2017)中提出的前端异步特性:async、await。 async、await是什么 async顾名思义是”异步”的意思,async用…

    数据库 2023年6月9日
    0145
  • 3. 视图-触发器-存储过程-索引

    404. 抱歉,您访问的资源不存在。 可能是网址有误,或者对应的内容被删除,或者处于私有状态。 代码改变世界,联系邮箱 contact@cnblogs.com 园子的商业化努力-困…

    数据库 2023年6月16日
    0100
  • MySQL隐式转换的坑

    MySQL以以下规则描述比较操作如何进行转换: 两个参数至少有一个是 NULL 时,比较的结果也是 NULL,例外是使用 实际使用中经研究发现字符串和数字比较时,优先把字符串转换为…

    数据库 2023年6月9日
    0110
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球