zabbix概述

Zabbix是什么

Zabbix 是由Alexei Vladishev创建,目前由Zabbix SIA在持续开发和支持。

Zabbix 是一个企业级的分布式开源监控方案。

Zabbix是一款能够监控各种网络参数以及服务器健康性和完整性的软件。Zabbix使用灵活的通知机制,允许用户为几乎任何事件配置基于邮件的告警。这样可以快速反馈服务器的问题。基于已存储的数据,Zabbix提供了出色的报告和数据可视化功能。这些功能使得Zabbix成为容量规划的理想方案。

Zabbix支持主动轮询和被动捕获。Zabbix所有的报告、统计信息和配置参数都可以通过基于Web的前端页面进行访问。基于Web的前端页面可以确保您从任何方面评估您的网络状态和服务器的健康性。适当的配置后,Zabbix可以在IT基础架构监控方面扮演重要的角色。对于只有少量服务器的小型组织和拥有大量服务器的大型公司也同样如此。

Zabbix是免费的。Zabbix是根据GPL通用公共许可证第2版编写和发行的。这意味着它的源代码都是免费发行的,可供公众任意使用。

zabbix定义

在本节中,你可以了解一些Zabbix常用术语的含义。

主机 (host)

– 一台你想监控的网络设备,用IP或域名表示

主机组 (host group)

– 主机的逻辑组;它包含主机和模板。一个主机组里的主机和模板之间并没有任何直接的关联。通常在给不同用户组的主机分配权限时候使用主机组。

监控项 (item)

– 你想要接收的主机的特定数据,一个度量数据。

触发器 (trigger)

– 一个被用于定义问题阈值和“评估”监控项接收到的数据的逻辑表达式

当接收到的数据高于阈值时,触发器从“OK”变成“Problem”状态。当接收到的数据低于阈值时,触发器保留/返回一个“OK”的状态。

事件 (event)

– 单次发生的需要注意的事情,例如触发器状态改变或发现有监控代理自动注册

异常 (problem)

– 一个处在“异常”状态的触发器

动作 (action)

– 一个对事件做出反应的预定义的操作。

一个动作由操作(例如发出通知)和条件(当时操作正在发生)组成

升级 (escalation)

– 一个在动作内执行操作的自定义场景; 发送通知/执行远程命令的序列

媒介 (media)

– 发送告警通知的手段;告警通知的途径

通知 (notification)

– 利用已选择的媒体途径把跟事件相关的信息发送给用户

远程命令 (remote command)

– 一个预定义好的,满足一些条件的情况下,可以在被监控主机上自动执行的命令

模版 (template)

– 一组可以被应用到一个或多个主机上的实体(监控项,触发器,图形,聚合图形,应用,LLD,Web场景)的集合

模版的任务就是加快对主机监控任务的实施;也可以使监控任务的批量修改更简单。模版是直接关联到每台单独的主机上。

应用 (application)

– 一组监控项组成的逻辑分组

web 场景 (web scenario)

– 利用一个或多个HTTP请求来检查网站的可用性

前端 (frontend)

– Zabbix提供的web界面

Zabbix API

– Zabbix API允许你使用JSON RPC协议来创建、更新和获取Zabbix对象(如主机、监控项、图形和其他)信息或者执行任何其他的自定义的任务

Zabbix server

– Zabbix软件实现监控的核心程序,主要功能是与Zabbix proxies和Agents进行交互、触发器计算、发送告警通知;并将数据集中保存等

Zabbix agent

– 一个部署在监控对象上的,能够主动监控本地资源和应用的程序

Zabbix proxy

– 一个帮助Zabbix Server收集数据,分担Zabbix Server的负载的程序

zabbix部署

1.安装源码库配置部署包

安装源码库配置部署包。这个部署包包含了yum配置文件。

 rpm -ivh http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-1.el7.centos.noarch.rpm

2.安装Zabbix部署包

安装Zabbix部署包。

[root@ken ~]# yum install zabbix-server-mysql zabbix-web-mysql -y

Error: Package: zabbix-web-3.4.15-1.el7.noarch (zabbix)
Requires: php-bcmath
Error: Package: zabbix-web-3.4.15-1.el7.noarch (zabbix)
Requires: php-mbstring

如果报上面的错误,需要执行这条命令,使用163的源 wget  http://mirrors.163.com/.help/CentOS6-Base-163.repo

3.安装Zabbix Agent

agent客户端,你想要监控那台服务器就安装这个软件并启动,我这里演示就和服务器端安装在了一起,即服务器端自己监控自己。

[root@ken ~]# yum install zabbix-agent -y

4.安装初始化数据库

在MySQL上安装Zabbix数据库和用户。在安装完zabbix-server-mysql已经自带了这个压缩包。

只要解压,然后导入初始架构(Schema)和数据即可。

[root@ken ~]# rpm -ql zabbix-server-mysql
/etc/logrotate.d/zabbix-server
/etc/zabbix/zabbix_server.conf
/usr/lib/systemd/system/zabbix-server.service
/usr/lib/tmpfiles.d/zabbix-server.conf
/usr/lib/zabbix/alertscripts
/usr/lib/zabbix/externalscripts
/usr/sbin/zabbix_server_mysql
/usr/share/doc/zabbix-server-mysql-3.0.22
/usr/share/doc/zabbix-server-mysql-3.0.22/AUTHORS
/usr/share/doc/zabbix-server-mysql-3.0.22/COPYING
/usr/share/doc/zabbix-server-mysql-3.0.22/ChangeLog
/usr/share/doc/zabbix-server-mysql-3.0.22/NEWS
/usr/share/doc/zabbix-server-mysql-3.0.22/README
/usr/share/doc/zabbix-server-mysql-3.0.22/create.sql.gz ##解压这个yasuobao
/usr/share/man/man8/zabbix_server.8.gz
/var/log/zabbix
/var/run/zabbix

复制到家目录下,解压

[root@ken ~]# cp /usr/share/doc/zabbix-server-mysql-3.0.22/create.sql.gz ./
[root@ken ~]# ls
anaconda-ks.cfg create.sql.gz ks-pre.log original-ks.cfg
[root@ken ~]# gunzip create.sql.gz

导入到数据库

root@localhost:mysql3306.sock [zabbix]>create database zabbix;
root@localhost:mysql3306.sock [zabbix]>use zabbix;
root@localhost:mysql3306.sock [zabbix]>source /root/create.sql
root@localhost:mysql3306.sock [zabbix]>grant all on *.* to zabbix@'localhost' identified by '123';
root@localhost:mysql3306.sock [zabbix]>flush privileges;

5.启动apache服务

[root@ken ~]# systemctl restart httpd
[root@ken ~]# ss -tnl | grep 80
LISTEN 0 128 :::80 :::*

6.通过浏览访问zabbix

输入ip/zabbix即可访问,访问前务必先关闭selinux以及防火墙

[root@ken ~]# systemctl stop firewalld
[root@ken ~]# setenforce 0

点击下一步

这里报了时区的错误,需要修改一下配置文件

[root@ken ~]# vim /etc/httpd/conf.d/zabbix.conf
1 #
2 # Zabbix monitoring system php web frontend
3 #
4
5 Alias /zabbix /usr/share/zabbix
6
7 <Directory "/usr/share/zabbix">
8 Options FollowSymLinks
9 AllowOverride None
10 Require all granted
11
12 <IfModule mod_php5.c>
13 php_value max_execution_time 300
14 php_value memory_limit 128M
15 php_value post_max_size 16M
16 php_value upload_max_filesize 2M
17 php_value max_input_time 300
18 php_value max_input_vars 10000
19 php_value always_populate_raw_post_data -1
20 php_value date.timezone Asia/Shanghai ##时区修改为亚洲/上海
21 </IfModule>
22 </Directory>
23
24 <Directory "/usr/share/zabbix/conf">
25 Require all denied
26 </Directory>
27
28 <Directory "/usr/share/zabbix/app">
29 Require all denied
...
[root@ken ~]# systemctl restart httpd ##重启APACHE服务

再次刷新页面

确认无误之后,点击下一步

输入刚才创建的数据库zabbix,以及创建的用户zabbix及密码,然后点击下一步

这里又报了一个无法通过sock文件,连接到数据库的错误。

这里补充一下造成这个错误的原因主要有如下几点:

1.防火墙,selinux没有关

2.配置文件的sock文件没有在/var/lib/mysql/下

3.对于/var/lib/mysql/,没有权限读取,需要修改为chown -R mysql.mysql /var/lib/mysql

4.zabbix用户授权错误,是查看是授予的localhost权限还是%权限,即可以在哪个主机上面登录

5.mysql是否正常启动

主要会有如上这些错误,大家在平时搭建的时候可以逐一进行排查。

查看一下我的配置文件,sock文件是在/tmp下需要修改为/var/lib/mysql/mysql.sock.并重新启动mysql

[root@ken ~]# vim /etc/my.cnf
#my.cnf
[client]
port = 3306
#socket = /tmp/mysql3306.sock
socket = /var/lib/mysql/mysql.sock [mysql]
prompt="\\u@\\h:\\p [\\d]>"
#pager="less -i -n -S"
#tee=/opt/mysql/query.log
no-auto-rehash [mysqld]
#misc
user = mysql
basedir = /usr/local/mysql
datadir = /data/mysql/mysql3306/data
port = 3306
#socket = /tmp/mysql3306.sock
socket = /var/lib/mysql/mysql.sock
event_scheduler = 0 tmpdir = /data/mysql/mysql3306/tmp
#timeout
interactive_timeout = 300
wait_timeout = 300 #character set
character-set-server = utf8
...

[root@ken ~]# mkdir /var/lib/mysql -p
[root@ken ~]# chown -R mysql.mysql /var/lib/mysql

[root@ken ~]# pkill msyqld
[root@ken ~]# mysqld &
[2] 2272
[root@ken ~]# ss -tnl
State Recv-Q Send-Q Local Address:Port Peer Address:Port
LISTEN 0 128 *:111 *:*
LISTEN 0 128 *:22 *:*
LISTEN 0 70 :::3306 :::*
LISTEN 0 128 :::111 :::*
LISTEN 0 128 :::80 :::*
LISTEN 0 128 :::22 :::*

再次网站刷新页面

点击下一步

点击下一步

点击完成

输入用户名Admin 密码zabbix

至此就已经安装并启动成功了。

zabbix启动

zabbix已经安装完后,现在就可以来启动了。

[root@ken ~]# vim /etc/zabbix/zabbix_server.conf
02 #
103 # Mandatory: no
104 # Default:
105 # DBUser=
106
107 DBUser=zabbix
108
109 ### Option: DBPassword
110 # Database password. Ignored for SQLite.
111 # Comment this line if no password is used.
112 #
113 # Mandatory: no
114 # Default:
115 # DBPassword=
116 DBPassword=123 ##输入你的数据库密码,仅仅修改这一处即可
117
118 ### Option: DBSocket
119 # Path to MySQL socket.
120 #
121 # Mandatory: no
122 # Default:
123 # DBSocket=/tmp/mysql.sock
..
[root@ken ~]# systemctl restart zabbix-server ##启动zabbix服务器端

现在在页面查看zabbix启动状态,发现zabbix已经在运行状态了。

点击configuretion–hosts-disabled启动被监控节点

执行如下命令启动被监控节点

[root@ken ~]# systemctl restart zabbix-agent

再次刷新页面之后发现enable后面的ZBX已经变成绿色,表示已经启动。

点击monitoring–latest data–hosts–select选择刚才的hosts即可看到下面监控输出的内容

分布式系统监视zabbix-安装的更多相关文章

  1. 分布式系统监视zabbix讲解七之分布式监控--技术流ken

    分布式监控 概述 Zabbix通过Zabbix proxy为IT基础设施提供有效和可用的分布式监控 代理(proxy)可用于代替Zabbix server本地收集数据,然后将数据报告给服务器. Pro ...

  2. 分布式系统监视zabbix讲解二之邮件报警通知--技术流ken

    概述 在上一篇博客<分布式系统监视zabbix讲解一技术流ken>中已经详细讲解了如何安装zabbix,本篇博客将详细讲解如何使用zabbix监控另外一台主机,并实现email报警通知机制 ...

  3. 分布式系统监视zabbix讲解七之分布式监控

    分布式监控 概述 Zabbix通过Zabbix proxy为IT基础设施提供有效和可用的分布式监控 代理(proxy)可用于代替Zabbix server本地收集数据,然后将数据报告给服务器. Pro ...

  4. 分布式系统监视zabbix讲解二之邮件报警通知

    概述 在上一篇博客<分布式系统监视zabbix讲解一技术流ken>中已经详细讲解了如何安装zabbix,本篇博客将详细讲解如何使用zabbix监控另外一台主机,并实现email报警通知机制 ...

  5. 分布式系统监视zabbix讲解三之用户和用户组--技术流ken

    概述 Zabbix 中的所有用户都通过 Web 前端去访问 Zabbix 应用程序.并为每个用户分配唯一的登陆名和密码. 所有用户的密码都被加密并储存于 Zabbix 数据库中.用户不能使用其用户名和 ...

  6. 分布式系统监视zabbix讲解三之用户和用户组

    概述 Zabbix 中的所有用户都通过 Web 前端去访问 Zabbix 应用程序.并为每个用户分配唯一的登陆名和密码. 所有用户的密码都被加密并储存于 Zabbix 数据库中.用户不能使用其用户名和 ...

  7. 分布式系统监视zabbix讲解一之zabbix安装--技术流ken

    zabbix概述 Zabbix是什么 Zabbix 是由Alexei Vladishev创建,目前由Zabbix SIA在持续开发和支持. Zabbix 是一个企业级的分布式开源监控方案. Zabbi ...

  8. 分布式系统监视zabbix讲解十一之zabbix升级--技术流ken

    思考 现在有这样一个需求,业务场景想要使用的监控模版没有3.0版本的,只有2.0,我们都知道2.0的模版无法导入进3.0版本的zabbix中,这个时候应该怎么获得3.0的监控模版哪?本篇博客将详细演示 ...

  9. 分布式系统监视zabbix讲解十之监控tomcat--技术流ken

    前言 在Zabbix中,JMX监控数据的获取由专门的代理程序来实现,即Zabbix-Java-Gateway来负责数据的采集,Zabbix-Java-Gateway和JMX的Java程序之间通信获取数 ...

  10. 分布式系统监视zabbix讲解九之使用snmp监控windows--技术流ken

    前言 使用zabbix监控windows主要有两种方法,一种是在windows端安装zabbix-agent客户端工具,安装麻烦.另外一种是使用snmp协议,配置简单快捷.两种配置都可以实现同样的效果 ...

随机推荐

  1. String、StringBuilder、StringBuffer三者的区别

    StringBuffer.StringBuilder和String都可以用来代表字符串.String类是不可变类,任何对String的改变都会引发新的String对象的生成:StringBuffer. ...

  2. JQ选择器总结

    jQuery 的选择器可谓之强大无比,这里简单地总结一下常用的元素查找方法 $("#myELement") 选择id值等于myElement的元素,id值不能重复在文档中只能有一个 ...

  3. Fiddler显示指定host请求,以及过滤无用的css,js

    第一步 右侧窗口点击filters 第二步 点击Use Fiters 第三步 第一个选项不动 no zone filter ,第二个选项选择 show only following hosts 第四步 ...

  4. Nginx进程模型

    多进程模式 在开始介绍Nginx的进程模型之前先说明下:Nginx也支持Single Master单进程模式,但是这个模式效率较低,一般只用在开发环境.所以不是本文介绍的重点. Nginx默认采用多进 ...

  5. postman with xdebug

    Set the url with ?XDEBUG_SESSION_START=PHPSTORM and set a header Cookie: XDEBUG_SESSION=PHPSTORM

  6. Golang omitempty 的用法

    原文链接:https://blog.csdn.net/skh2015java/article/details/90720692omitempty作用是在json数据结构转换时,当该字段的值为该字段类型 ...

  7. 操作系统-I/O(4)I/O控制方式

    I/O控制的方式分为: 程序直接控制方式(最简单的I/O方式)                   •    无条件传送:对简单外设定时(同步)进行数据传送                   •   ...

  8. 百度与谷歌seo优化的差别

    http://www.wocaoseo.com/thread-126-1-1.html 常有朋友问谷歌(google)和百度(baidu)到底有什么区别?我在纠结这个问题该如何回答.如果从公平公正的角 ...

  9. zstd和zip操作6g的文本

    ssd是在固态硬盘上的时间 1.txt   7038308223 bytes 都是默认级别 ======================================== zstd-v1.4.4-w ...

  10. 学习一下 JVM (三) -- 了解一下 垃圾回收

    一.简单了解几个概念 1.什么是垃圾(Garbage)?什么是垃圾回收(Garbage Collection,简称 GC)? (1)什么是垃圾(Garbage)? 这里的垃圾 指的是 在程序运行过程中 ...