Zabbix自定义监控配置流程

本文详细介绍Zabbix自定义监控的配置流程,包括监控进程、日志、MySQL主从延迟及状态,通过具体实例演示如何在客户端进行脚本编写、权限设置及Zabbix配置修改。

自定义监控配置流程

自定义监控配置步骤:
1.创建脚本存放目录,写脚本,给执行权限,改脚本存放目录的属主为zabbix
2.改客户端配置文件agentd.conf

  • UnsafeUserParameters=1
  • UserParameter=<key_name[*]>,<shell command $1>

3.重启zabbix_agent
4.在服务端手动测试

  • zabbix_get -s 客户端IP -k key_name

5.配置网页界面,添加监控项以及触发器
6.验证

注意:自定义监控要在客户端配置

1. 自定义监控进程

这里以httpd为例:

# 在客户端安装httpd
[root@agentd ~]# yum -y install httpd
[root@agentd ~]# systemctl start httpd

# 在客户端创建脚本存放目录
[root@agentd ~]# mkdir /scripts

# 写脚本
[root@agentd ~]# cat /scripts/check_process.sh 
#!/bin/bash

process=$(ps -ef|grep -Ev "grep|$0"|grep -c $1)
if [ $process -gt 0 ];then
    echo "0"
else
    echo "1"
fi

# 给脚本执行权限
[root@agentd ~]# chmod a+x /scripts/check_process.sh 
[root@agentd ~]# ll /scripts/check_process.sh
-rwxr-xr-x 1 zabbix zabbix 135 8月  24 15:26 /scripts/check_process.sh

# 改脚本存放目录的属主
[root@agentd ~]# chown -R zabbix.zabbix /scripts/
[root@agentd ~]# ll -d /scripts/
drwxr-xr-x 2 zabbix zabbix 30 8月  24 16:34 /scripts/

# 改客户端配置文件agentd.conf
[root@agentd ~]# echo "UnsafeUserParameters=1" >>/usr/local/etc/zabbix_agentd.conf
[root@agentd scripts]# echo 'UserParameter=check_process[*],/bin/bash /scripts/check_process.sh $1' >>/usr/local/etc/zabbix_agentd.conf

# 重启zabbix_agent
[root@agentd ~]# pkill zabbix_agentd
[root@agentd ~]# zabbix_agentd 

# 在服务端手动测试
[root@zabbix ~]# zabbix_get -s 192.168.100.96 -k check_process[httpd]
0  	 # 0代表没有问题
# 停掉httpd服务再测试
[root@agentd ~]# systemctl stop httpd
[root@zabbix ~]# zabbix_get -s 192.168.100.96 -k check_process[httpd]
1	 # 1代表服务没有进程运行

配置网页界面
添加监控项

  • 配置——主机——监控项
  • 配置以下配置其他保持默认
    在这里插入图片描述

添加触发器
配置——主机——触发器
在这里插入图片描述

触发验证

[root@agentd ~]# systemctl restart httpd
[root@agentd ~]# systemctl stop httpd
在这里插入图片描述

2.自定义监控日志

这里以监控var/log/httpd/error_log为例
1.创建脚本存放目录,写脚本,给执行权限,改脚本存放目录的属主属组为zabbix

[root@96 ~]# mkdir /scripts
[root@96 ~]# cd /scripts/
[root@96 scripts]# vim log.py
#!/usr/bin/env python3
import sys
import re

def prePos(seekfile):
    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@96 scripts]# chmod +x log.py
[root@96 scripts]# chown -R zabbix.zabbix .

2.改客户端配置文件agentd.conf

[root@96 ~]# vim /usr/local/etc/zabbix_agentd.conf
UnsafeUserParameters=1
UserParameter=check_log[*],/usr/bin/python /scripts/log.py $1 $2 $3

3.重启zabbix_agent

[root@96 ~]# pkill zabbix
[root@96 ~]# zabbix_agentd

4.在服务端手动测试

[root@zabbix ~]# zabbix_get -s 192.168.100.96 -k check_log[/var/log/httpd/error_log,/tmp/qq.seek,erroe]
0

5.配置网页界面,添加监控项以及触发器
在这里插入图片描述
在这里插入图片描述
6.客户端触发验证

[root@96 ~]# echo "error" >>/var/log/httpd/error_log 
[root@96 ~]# echo "error" >>/var/log/httpd/error_log 

在这里插入图片描述

3.自定义监控mysql主从延迟

1.创建脚本存放目录,写脚本,给执行权限,改脚本存放目录的属主属组为zabbix

[root@96 ~]# mkdir /scripts
[root@96 ~]# vim /scripts/mysql_delay.sh
#!/bin/bash

num=$(mysql -uroot -pscl666 -e 'show slave status \G;' 2>/dev/null |grep Behind |awk '{print $NF}')
if [ $num -ne 0 ];then
    echo "1"
else
    echo "0"
fi

[root@96 ~]# chmod +x /scripts/mysql_delay.sh
[root@96 ~]# chown -R zabbix.zabbix /scripts
[root@96 ~]# chmod 750 /scripts/mysql_delay.sh    #里面有密码不给其他人权限
[root@96 ~]# ll /scripts/
-rwxr-x--- 1 zabbix zabbix 383 8月  25 16:44 mysql_delay.sh

2.改客户端配置文件agentd.conf

[root@96 ~]# vim /usr/local/etc/zabbix_agentd.conf
UnsafeUserParameters=1
UserParameter=check_mysql_delay,/bin/bash /scripts/mysql_delay.sh

3.重启zabbix_agent

[root@96 ~]# pkill zabbix
[root@96 ~]# zabbix_agentd

4.在服务端手动测试

[root@zabbix ~]# zabbix_get -s 192.168.100.96 -k check_mysql_delay
0

5.配置网页界面,添加监控项以及触发器
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4. 自定义配置监控mysql主从状态

1.创建脚本存放目录,写脚本,给执行权限,改脚本存放目录的属主属组为zabbix

[root@96 ~]# mkdri /scripts
[root@96 scripts]# vim mysql_state.sh
#!/bin/bash
zhuangtai=$(mysql -uroot -pscl666 -e 'show slave status \G;' 2>/dev/null |grep -E 'Slave_IO_Running:|Slave_SQL_Running:' |awk '{print $NF}' |grep Yes|wc -l)
if [ $zhuangtai -ne 2 ];then
    echo "1"
else
    echo "0"
fi



[root@96 scripts]# chmod +x mysql_state.sh
[root@96 scripts]# chown -R zabbix.zabbix .
[root@96 scripts]# chmod 750 mysql_state.sh

2.改客户端配置文件agentd.conf

[root@96 ~]# vim /usr/local/etc/zabbix_agentd.conf		#末行添加
UnsafeUserParameters=1
UserParameter=check_mysql_state,/bin/bash /scripts/mysql_state.sh

3.重启zabbix_agent

[root@96 ~]# pkill zabbix
[root@96 ~]# zabbix_agentd

4.在服务端手动测试

[root@zabbix ~]# zabbix_get -s 192.168.100.96 -k check_mysql_state
0

5.配置网页界面,添加监控项以及触发器
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

<think>好的,我需要帮助用户在Zabbix中设置自定义监控日志。根据用户提供的引用内容,我需要结合这些信息来构建一个清晰的步骤指南。首先,我应该回忆Zabbix的基本架构,尤其是Agent的作用,因为引用中提到代理主机的数据清理和监控配置。 首先,用户需要创建自定义监控脚本。引用[2]提到要重启客户端后检查日志,这可能涉及到脚本的部署和权限设置。所以步骤应该包括编写脚本,并确保其可执行权限。例如,用户可能需要在Agent上编写一个脚本,用于分析日志文件中的特定关键字,比如错误信息。 接下来是配置Zabbix Agent。引用[2]和引用[3]都涉及到了Agent的配置,比如修改zabbix_agentd.conf文件,添加UserParameter。这里需要指导用户如何正确设置参数,确保Zabbix Server能调用这些自定义监控项。可能需要提醒用户重启Agent服务以使配置生效,如引用[2]中的操作。 然后是Zabbix Server端的配置,创建监控项和触发器。引用[2]提到编写监控项和触发器,这里需要详细说明如何在Web界面中添加监控项,指定键值,以及设置触发器表达式,比如当错误数量超过阈值时触发报警。引用[3]中测试关闭httpd服务来触发告警,这说明测试步骤很重要,用户需要验证配置是否生效,所以需要指导用户如何模拟日志错误并观察Zabbix的响应。 可能还需要注意权限问题,确保Zabbix Agent有权限读取日志文件和执行脚本。此外,日志路径的正确性也是关键,避免因路径错误导致监控失败。引用中的信息虽然有限,但结合Zabbix的通用配置流程,可以补充这些细节。 最后,生成相关问题时要围绕Zabbix自定义监控展开,比如优化方法、触发器配置、主动模式与被动模式的区别,以及如何处理日志轮转问题。这些问题能帮助用户进一步深入理解相关配置和故障排除。</think>### 如何在Zabbix中设置自定义监控日志? 以下是分步配置教程: --- #### **1. 创建自定义监控脚本** 在Zabbix Agent所在服务器上编写脚本,用于分析目标日志文件。 **示例脚本** `check_log_errors.sh`: ```bash #!/bin/bash LOG_FILE=/var/log/application/error.log KEYWORD="ERROR" # 统计关键词出现次数 count=$(grep -c "$KEYWORD" "$LOG_FILE") echo $count ``` 赋予执行权限: ```bash chmod +x /check_log_errors.sh ``` --- #### **2. 配置Zabbix Agent** - **编辑Agent配置文件**: 修改 `zabbix_agentd.conf`,添加自定义参数: ```ini UserParameter=log.error.count,/path/to/check_log_errors.sh ``` - **重启Agent服务**: ```bash systemctl restart zabbix-agent ``` --- #### **3. 在Zabbix Web界面添加监控项** 1. **创建监控项**: - 路径:*配置 → 主机 → 监控项 → 创建监控项* - 名称:`Log Error Count` - 键值:`log.error.count` - 类型:`Zabbix Agent` 2. **设置数据更新间隔**:例如 `60s`[^2]。 --- #### **4. 配置触发器** - **创建触发器**: 路径:*配置 → 主机 → 触发器 → 创建触发器* ```text 表达式:{HOST:log.error.count.last()}>5 # 当错误次数超过5时触发告警 ``` 可自定义严重性(如“警告”或“严重”)[^3]。 --- #### **5. 测试与验证** - **模拟日志错误**: ```bash echo "ERROR: Test alert" >> /var/log/application/error.log ``` - **查看最新数据**: 路径:*监控 → 最新数据 → 筛选监控项* - **触发告警**: 若错误次数超过阈值,Zabbix会发送通知(邮件/钉钉等)。 --- #### **注意事项** - **权限问题**:确保Zabbix Agent用户(默认 `zabbix`)有权限读取日志文件和脚本。 - **日志轮转**:若日志按日期分割,需调整脚本或使用Zabbix日志监控内置功能。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值