zabbix--远程执行命令

zabbix 远程执行命令 重启应用 服务器

使用远程执行命令可以在某些时候帮我做一些事情,达到轻量级的自动化,比如当 nginx、mysql、php、redis、tomcat、等等应用挂掉时帮我们自动重启并告警。再比如当磁盘空间满了,自动帮我们清理垃圾日志文件等。看下官网的描述:

使用远程命令,您可以定义在某些情况下,监视的主机上会自动执行某个预定义的命令。

在功能最明显的用途中,您可以尝试:

  • 如果没有响应,则自动重新启动某些应用程序(Web服务器,中间件,CRM)
  • 如果不响应请求,请使用IPMI“reboot”命令重新启动一些远程服务器
  • 如果磁盘空间不足,可自动释放磁盘空间(删除较旧的文件,清理/tmp)
  • 根据CPU负载,将VM从一个物理机移植到另一个物理机
  • 在CPU(磁盘,内存,任何资源)不足的情况下,将新节点添加到云环境中

远程命令限制为255个字符。可以通过将多个命令放置在新行上来执行多个命令。远程命令可能包含宏。

  • 如果没有响应,则自动重新启动某些应用程序(Web服务器,中间件,CRM)
  • 如果不响应请求,请使用IPMI“reboot”命令重新启动一些远程服务器
  • 如果磁盘空间不足,可自动释放磁盘空间(删除较旧的文件,清理/ tmp)
  • 根据CPU负载,将VM从一个物理盒移植到另一个物理盒
  • 在CPU(磁盘,内存,任何资源)不足的情况下,将新节点添加到云环境中

参考官档:https://www.zabbix.com/documentation/4.0/zh/manual/config/notifications/action/operation/remote_command

实战

描述:该实战是完全创建一个新的模板,用于专们管理日常的一些服务等,在新建的模板上面创建对应服务的监控项、触发器、动作等。

具体步骤:

zabbix-agent端

1)根据官网提示 首先打开zabbix-agent上的 EnableRemoteCommands 参数

# vim /etc/zabbix/zabbix_agentd.conf
EnableRemoteCommands=1

2)创建一个脚本存放路径

# mkdir /etc/zabbix/script

3)创建一个新的脚本

# vim /etc/zabbix/script/service_status.sh
#!/bin/bash
#Desc:zabbix 远程执行命令、重启应用 nginx、mysql、php、等
#Date:2019-5-8
#by:Lee-YJ

case $1 in
    Nginx)
        result=`pidof nginx  |wc -l`
        echo $result
        ;;
    Php)
        result=`pidof php-fpm  |wc -l`
        echo $result
        ;;
    Mysql)
        result=`pidof mysqld  |wc -l`
        echo $result
        ;;
    *)
        echo "Usage:$0(Nginx|Php|Mysql)"
        ;;
esac

"pidof nginx  |wc -l" 这条命令用于判断nginx进程是否存在,如果存在则返回1,不存在返回0

脚本补充说明

4)赋予脚本执行权限

# chmod +x /etc/zabbix/script/service_status.sh

5)创建一个新的专门用于服务监控的子配置文件

# cd /etc/zabbix/zabbix_agentd.d
# vim userparameter_service.conf
# 获取服务运行状态
UserParameter=service.status[*],/etc/zabbix/script/service_status.sh $1

6)重启 zabbix-agent

# service zabbix-agent restart

7)在 zabbix-server 端用命令进行测试

# zabbix_get -s 47.104.xx.xx -k "service.status[Nginx]"
1
# zabbix_get -s 47.104.xx.xx -k "service.status[Mysql]"
1
# zabbix_get -s 47.104.xx.xx -k "service.status[Php]"
1

当返回1时表示客户端服务正常,当返回0时表示客户端服务不正常(根据上面脚本内容所得)

测试结果补充说明

zabbix-server Web端

1)创建一个模板 Check Service (自定义名字)

创建完成后里面什么东西都没有(应用集、监控项、触发器、图形等)

2)创建一个应用集 service (自定义名字)

3)创建监控项(键值说明,这里我们得根据配置文件里面定义的来进行配置;service.status[Nginx])

4)创建触发器(最新的t值说明:根据前面的命令结果判断,pidof vsftpd  |wc -l ,如果nginx处于运行状态该值为1,反正为0则为挂了,所以这里触发器判断是否为0)

5)给监控的主机链接上 Check Service 模板

6)测试;在配监控的主机上停掉nginx,后观察仪表盘

从上面可以看到当nginx挂掉后会第一时间发送邮件告知相关人员;但是我们更多的是希望能够帮我们自动重启nginx;那么接下来配置自动重启

7)配置动作(远程执行命令、恢复操作等)

进入:配置 -> 动作 -> 创建动作

配置操作:配置操作时执行重启命令,(注意:因为zabbix 进程是使用zabbix用户来维护的,所以它没有权限去执行重启nginx命令,这里需要先在 zabbix-agent 上授权)

# chmod 640 /etc/sudoers
# vim /etc/sudoers    //编辑sudo文件,添加如下两行
# Allow ‘zabbix‘ user to restart nginx without password
zabbix  ALL=NOPASSWD: /etc/init.d/nginx restart

添加恢复操作:

到这里就配置完成了,当我在 zabbix-agent 上面停掉 nginx,便会自动帮我们重启并发送邮件

至此,zabbix远程执行命令就配置完成了。

附zabbix-agent端上的配置脚本(只针对当前配置里面的nginx、mysql、php)

#!/bin/bash
#Desc:用于配置zabbix远程执行命令,zabbix-agent端上面的操作(包括nginx、mysql、php)
#Date:2019-5-8
#by:Lee-YJ

mkdir /etc/zabbix/script -p

cat >>/etc/zabbix/script/service_status.sh<<EOF
#!/bin/bash
#Desc:zabbix 远程执行命令、重启应用 nginx、mysql、php、等
#Date:2019-5-8
#by:Lee-YJ

case \$1 in
    Nginx)
        result=\`pidof nginx  |wc -l\`
        echo \$result
        ;;
    Php)
        result=\`pidof php-fpm  |wc -l\`
        echo \$result
        ;;
    Mysql)
        result=\`pidof mysqld  |wc -l\`
        echo \$result
        ;;
    *)
        echo "Usage:\$0(Nginx|Php|Mysql)"
        ;;
esac
EOF

chmod +x /etc/zabbix/script/service_status.sh

sed -i ‘s/# EnableRemoteCommands=0/EnableRemoteCommands=1/‘ /etc/zabbix/zabbix_agentd.conf

cat >/etc/zabbix/zabbix_agentd.d/userparameter_service.conf<<EOF
# 获取服务运行状态
UserParameter=service.status[*],/etc/zabbix/script/service_status.sh \$1
EOF

service zabbix-agent restart

chmod 640 /etc/sudoers
echo "zabbix  ALL=NOPASSWD: /etc/init.d/nginx restart" >> /etc/sudoers
echo "zabbix  ALL=NOPASSWD: /etc/init.d/mysqld restart" >> /etc/sudoers
echo "zabbix  ALL=NOPASSWD: /etc/init.d/php-fpm restart" >> /etc/sudoers

zabbix-agent_config.sh

原文地址:https://www.cnblogs.com/yanjieli/p/10833311.html

时间: 2024-10-20 21:27:05

zabbix--远程执行命令的相关文章

Zabbix远程执行命令

原文发表于cu:2016-06-14 Zabbix触发器(trigger)达到阀值后会有动作(action)执行:发送告警信息或执行远程命令. 本文主要配置验证zabbix执行远程命令. 一.环境 Server:基于CentOS-7-x86_64-1511: Zabbix:zabbix-3.0.1server/agent. 二.注意事项 一些能想到的比较重要的注意事项: 远程执行命令是server端向agent端执行,不支持主动模式的agent: 不支持代理模式: zabbix用户必须对命令具有

Linux监控平台(主被动模式,添加监控主机,添加图形,处理图形乱码,远程执行命令)

一.主动模式和被动模式(针对客户端) 主动模式:客户端使用完数据后,每隔自定义事件主动上报给服务端 应用环境:当客户端数量非常多,建议使用主动模式,这样可以降低服务端的压力. 被动模式:服务端会主动连接客户端,客户端被动连接,把监控信息传递给服务端 应用环境:服务端有公网ip,客户端只有内网ip,但是能连接外网,可以主动上报. 这种场景适合主动模式. 二.添加监控主机 添加主机: 再添加主机之前,我们要先添加一个主机群组,在配置中 主机群组的右上角有一个创建主机 然后点主机,右上角有一个创建主机

20.27分发系统介绍;20.28expect脚本远程登录;20.29expect脚本远程执行命令;20.30expect脚本传递参数

20.27 分发系统介绍 shell项目-分发系统-expect 20.28 expect脚本远程登录 1. 安装expect [[email protected] ~]# yum install -y expect 自动远程登录 2. 创建配置1.expect脚本(远程登录) [[email protected] ~]# vim 1.expect 添加内容(自动远程登录hao2机器并执行命令) #! /usr/bin/expect set host "192.168.211.129"

使用ansible远程执行命令

使用ansible远程执行命令 1.ansible简介 ansible的官方定义:"Ansible is Simple IT Automation"--简单的自动化IT工具.这个工具的目标: 自动化部署APP 自动化管理配置项 自动化的持续交付 自动化的(AWS)云服务管理. 其本质上就是在远程在多台服务器执行一系列命令和文件同步,和以前的介绍的使用并行ssh提高工作效率功能类似,他们都是使用ssh协议进行远程操作,但ansible比pssh功能更强大,比如支持主机列表分组.支持pla

python之实现批量远程执行命令(堡垒机)

python远程批量执行 我并不是一个专业的开发,我一直在学习linux运维,对于python也是接触不久,所以代码写的并不是很规范简洁. 前段时间一个同学找我一起做一个自动化运维平台,我对python的django还没有了解,并且对于HTML和JS这类开发学习还没有涉及,所以我说我做些后台的实现,前端就交给我的同学做.不扯淡了,下面说下我做批量执行的思路. 用到的模块:paramiko 功能:很简单就是批量执行命令,类似于ansible,本来想用Fabric,但是想一想还是用paramiko,

python模块paramiko的上传下载和远程执行命令

#!/usr/bin/python # -*- coding: utf-8 -*- import paramiko,os,datetime server_ip = '192.168.1.123' server_user = 'root' server_passwd = '10241010' server_port = 22 #local_dir='C:\Python27' #remote_dir='/soft2/nba/' def ssh_connect(): ssh = paramiko.SS

ssh远程执行命令使用明文密码

经过不懈的搜索终于找到ssh远程执行命令使用明文密码使用sshpass. 例子: sshpass -p "sequoiadb" ssh [email protected] "ls /" sshpass在centos无法直接安装 cd /etc/yum.repos.d/ wget http://download.opensuse.org/repositories/home:Strahlex/CentOS_CentOS-6/home:Strahlex.repo yum

python 实现ssh远程执行命令 上传下载文件

使用密码远程执行命令 [[email protected] script]# cat daramiko_ssh.py  #!/usr/bin/env python #_*_coding:utf-8 _*_ __author__ = 'gaogd' import paramiko import sys,os host = sys.argv[1] user = 'root' password = 'ddfasdsasda2015' cmd = sys.argv[2] s = paramiko.SSH

Linux下使用SSH非交互式远程执行命令脚本---ssh无密码登陆

通过SSH命令远程执行命令首先需要建立相关主机间的信任关系.否则,在执行命令前SSH命令会提示你输入远程主机的密码.建立主机间信任关系的方法如下-即ssh无密码输入: 假设我们有两台主机.主机名分别为linuxa和linuxb.首先在linuxa上以当前用户运行如下命令生成本主机的公钥和私钥文件: ssh-keygen -t rsa     上述命令执行后,隐藏目录~/.ssh下会出现两个文件:id_rsa和id_rsa.pub.其中,id_rsa.pub为公钥文件. 将该文件的内容追加到对端主

一键帮你复制多个文件到多个机器——PowerShell小脚本(内附PS远程执行命令问题解析)

作为一个后台程序猿,经常需要把一堆程序集(DLL)或者应用程序(EXE)复制到多个服务器上,实现程序的代码逻辑更新,用以测试新的功能或改动逻辑.这里给大家介绍一个自己实现的PowerShell脚本,方便大家替换DLL或者EXE到多个Windows机器上. 一.   脚本用途 用于方便复制多个文件到多个服务器上. 二.   脚本功能 脚本的主要功能如下: 支持通过最后修改时间过滤文件,设定时间之前的文件不进行复制操作(逻辑设计源于Rebuild代码后只替换新Build出来的有改动的文件): 支持多