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)

大家都在看

  • 线程池执行流程图

    public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeU…

    数据库 2023年6月16日
    0124
  • Redis学习笔记一

    ============================= Redis学习笔记一 注:笔记旨在记录 一、redis简介: 高性能的 key-value 数据库 特点: 支持数据持久…

    数据库 2023年6月16日
    067
  • 牛客SQL刷题第一趴——非技术入门基础篇

    id device_id gender age university province 1 2138 male 21 北京大学 Beijing 2 3214 male 复旦大学 S…

    数据库 2023年5月24日
    099
  • Mysql 连续时间分组

    该方案不限于本例的连续时间,还可以应用于其他连续组。 [En] The scheme is not limited to the continuous time of this e…

    数据库 2023年5月24日
    075
  • MySQL 数据库自动备份

    压缩文件恢复 gzip -d backup.sql.gz | mysql -h -u -p Tips: gzip -d为解压, 下面介绍下gzip用法与参数介绍(gzip命令只是压…

    数据库 2023年5月24日
    067
  • 升级JDK8的坎坷之路

    为更好的适应JAVA技术的发展,使用更先进及前沿的技术。所以推出将我们现在使用的JDK1.6(1.7)及tomcat6(7)升级至JDK1.8及tomcat8,使我们的系统获得更好…

    数据库 2023年6月6日
    085
  • ​探秘 Web 水印技术

    Web 水印技术在信息安全和版权保护等领域有着广泛的应用,对防止信息泄露或知识产品被侵犯有重要意义。水印根据可见性可分为可见水印和不可见水印(盲水印),本文将分别予以介绍,带你探秘…

    数据库 2023年6月14日
    0109
  • MySQL安装配置教程(超级详细)

    一、 下载MySQL Mysql官网下载地址:https://downloads.mysql.com/archives/installer/ 1. 选择要安装的版本,本篇文章选择的…

    数据库 2023年5月24日
    0174
  • mysql的安装和下载

    1、 MySQL 下载地址为: MySQL 下载,这里下载的是mysql的msi安装文件,选择下面的470.2M的版本,点击download进行下载。 2、在下载页面直接选择: N…

    数据库 2023年5月24日
    086
  • mybatis中文文档PDF版

    https://share.weiyun.com/2Dwd35jD 密码:dguiby Original: https://www.cnblogs.com/qingxin12345…

    数据库 2023年6月9日
    0117
  • podman(无根用户管理podman)

    用户操作在允许没有root特权的用户运行Podman之前,管理员必须安装或构建Podman并完成以下配置cgroup V2Linux内核功能允许用户限制普通用户容器可以使用的资源,…

    数据库 2023年6月14日
    087
  • Redis 文件事件

    事件驱动 Redis 服务器是事件驱动程序,分为 &#x6587;&#x4EF6;&#x4E8B;&#x4EF6;和 &#x65F6;&am…

    数据库 2023年6月6日
    095
  • JavaScript基本知识点——带你逐步解开JS的神秘面纱

    JavaScript基本知识点——带你逐步解开JS的神秘面纱 在我们前面的文章中已经深入学了HTML和CSS,在网页设计中我们已经有能力完成一个美观的网页框架 但仅仅是网页框架不足…

    数据库 2023年6月14日
    0100
  • Mybatis完整版详解

    一、简介 1.什么是MyBatis MyBatis 是一款优秀的持久层框架 它支持自定义 SQL、存储过程以及高级映射。 MyBatis 免除了几乎所有的 JDBC 代码以及设置参…

    数据库 2023年6月16日
    086
  • ubuntu设置时区

    posted @2022-06-21 08:30 一份人间烟火 阅读(2 ) 评论() 编辑 Original: https://www.cnblogs.com/zcxxcvbn/…

    数据库 2023年6月9日
    090
  • leetcode 543. Diameter of Binary Tree 二叉树的直径(简单)

    给定一棵二叉树,你需要计算它的直径长度。一棵二叉树的直径长度是任意两个结点路径长度中的最大值。这条路径可能穿过也可能不穿过根结点。 示例 :给定二叉树 1 / \ 2 3 / \ …

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