• zabbix入门知识


    zabbix入门知识

    zabbix中文手册
    https://www.zabbix.com/documentation/3.4/manual/

    1.zabbix介绍

    	Zabbix 是一个企业级的分布式开源监控方案。
    	Zabbix是一款能够监控各种网络参数以及服务器健康性和完整性的软件。
    	Zabbix使用灵活的通知机制,提供了出色的报告和数据可视化功能
    	Zabbix支持主动轮询和被动捕获。
    	Zabbix基于Web的前端页面进行访问。
    	Zabbix是免费的。
    	特点:
    		数据收集
    		灵活的阀值定义
    		高度可配置化的告警
    		实时图表绘制
    		Web监控功能
    		丰富的可视化选项
    		历史数据存储
    		配置简单
    		使用模板
    		网络发现
    		简洁的Web界面
    		Zabbix API
    		权限管理系统
    		功能强大并易于扩展的监控代理
    		二进制代码
    		为复杂环境准备
    

    2.zabbix系统架构图



    3.zabbix的组件

    	zabbix agent:部署在被监控主机上,负责收集本地数据并发往server端或porxy端。
    	zabbix server:负责接收agent发送的报告信息的核心组件,所有配置信息、统计数据及操作数据都由其组织进行。
    	zabbix database:用于存储所有zabbix的配置信息、监控数据的数据库。
    	zabbix web:zabbix的web界面,通过web界面管理zabbix的配置以及查看zabbix相关的监控信息,可以单独部署在独立的服务器上,是server的一部分,通常是在一台物理机上,若使用使用SQLite则必须在一台上。
    	zabbix proxy:用于分布式监控环境中,zabbix proxy某程度上相当于server端,完成局部区域内的信息收集,最终统一发往server端。可帮server分担负载压力。
    	zabbix数据流:
    		为了创建一个监控项用于采集数据,必须先创建一个主机。转换到Zabbix功能的其他部分,你必须先有一个监控项来创建触发器,你必须有一个触发器来创建动作。 因此,如果你想收到X服务器CPU负载过高的告警,你必须先为X服务器创建一个主机实体并关联一个用于对CPU进行监控的监控项,然后如果CPU负载太高便会激活触发器,接着会执行一个动作,给你发送告警邮件。虽然看起来有很多步骤,但是使用模板的话可以会很简单。同时,这个设计可以创建一个非常灵活的配置。
    

    4.zabbix支持的通讯协议

    	理论上,zabbix能够监控几乎所有与业务相关的硬件资源。但是,能监控的前提是能相互间稳定通信。而zabbix支持的协议如下。
    	agent:通过专用的代理程序进行监控,与常见的master/agent模型类型。若支持的话,优先选用agent。
    	ssh、telnet:通过远程控制协议进行通信。
    	SNMP:simple network management protocol,通过snmp协议进行监控,大部分网络设备都支持这种协议,与常见的master/agent模型类型,一般是在这些设备中内置有snmp的agent。
    	IPMI:通过IPMI接口进行监控,来监控对象的物理特征,如电压,温度等。
    	JMX:java management extensions,通过jmx监控jvm虚拟机。
    

    5.zabbix的工作模式

    	被动(passive)模式和主动(active)模式
    	工作模式是对于agent端来说的。
    	当agent端将采集完的数据主动发往server端的模式为主动模式。
    	当agent端等待server端来垃圾数据的模式为被动过模式。
    	主动模式与被动模式在agent端并不冲突,可以同时存在。
    	agent端使用zabbix_sender工具测试能否向server端发数据,server端使用zabbix_get工具测试能否从agent端拉取数据。
    

    6.zabbix的监控过程

    	zabbix agent部署在被监控的主机上,由agent采集数据并报告给负责监控的中心主机,中心主机就是master/agent中的master;
    	负责监控的中心主机为zabbix server,server将从agent端接收信息并存储到zabbix database中;
    	管理员是从zabbix web支持的web GUI上查看各种监控信息的,而zabbix web是有php编写,所以依赖与LAMP环境;
    	zabbix server和zabbix web都需要与zabbix database相互通信来获取数据。
    	当监控规模非常庞大时,就需要用到分布式监控,使用zabbix proxy作为代理来接收agent的提交的数据信息,然后将数据统一发送给zabbix server处理,在局部proxy就相当于server。
    

    7.zabbix常用术语

    	主机 (host):要监控的网络设备,用IP或DNS名表示
    	主机组 (host group):主机的逻辑组;它包含主机和模板。一个主机组里的主机和模板之间并没有任何直接的关联。通常在给不同用户组的主机分配权限时候使用主机组。
    	监控项 (item):要接收的主机的特定数据,一个度量数据,某个监控指标。
    	键(key):想要获取监控项对应的数据,就需要通过某个key去获取,可以把key当然调用命令的对应的命令别名。
    	触发器 (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的负载的程序
    

    8.zabbix安装

    1)配置仓库

    	wget http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-2.el7.noarch.rpm
    	rpm -ivh zabbix-release-3.4-2.el7.noarch.rpm(这是个配置仓库的安装包,会自动仓库)
    	配置好仓库后,使用yum install来进行安装
    

    2)zabbix server的安装

    	yum install mariadb mariadb-libs mariadb-server zabbix-get zabbix-server-mysql.x86_64 ##(根据安装的数据库来选择包)                                     
    	初始化zabbix数据库
    		安装mysql数据
    		创建zabbix数据库和用户
    			MariaDB [(none)]> create database zabbix charset 'utf8';
    			MariaDB [(none)]> grant all on zabbix.* to zabbix@'localhost' identified by 'xm1234';  ##这里设置的本地
    			MariaDB [(none)]> flush privileges;
    		初始化zabbix数据库
    			通过rpm -ql zabbix-server-mysql找到create.sql.gz。
    			解压得到create.sql脚本
    				gunzip crete.sql.gz
    			进行初始化
    				mysql -uroot -p -Dzabbix < create.sql
    			查看初始情况
    				msyql -uroot -p
    				MariaDB [(none)]> use zabbix
    				MariaDB [zabbix]> show tables;
    		根据需要配置/etc/zabbix-server.conf
    			DBPassword=
    		启动服务
    			systemctl start zabbix-server
    

    3)zabbix proxy的安装

    	yum install zabbix-get zabbix-proxy-mysql.x86_64(根据安装的数据库来选择包)
    	初始化配置和server差不多
    

    4)zabbix web的安装

    	yum install zabbix-web.noarch  zabbix-web-mysql ##依赖了很多包,包括httpd和php
    	初始化
    		创建lamp环境
    			安装httpd和php(应该是在安装zabbix-web时,由依赖关系的原因以下都已安装,仅需要配置启动)
    				yum install httpd php(php-fpm)php-mysql  maradb mariadb-libs mariadb-server
    			启动httpd
    				systemctl enable httpd
    				systemctl start httpd
    			启动maradb
    			配置启动php
    				两种方法,选其一。
    					1)modules:
    						yum install php php-mysql
    						vim /etc/httpd/conf/httpd.conf
    							在文件尾部加两行
    								AddType application/x-httpd-php .php
    								AddType application/x-httpd-php-source .phps
    							添加修改下面行
    								<IfModule dir_module>
    									DirectoryIndex index.php index.html
    								</IfModule>
    						systemctl restart httpd
    					2)fastcgi:
    						yum install php-fpm php-mysql
    						vim /etc/httpd/conf/httpd.conf
    							在文件尾部加四行
    							AddType application/x-httpd-php .php
    							AddType application/x-httpd-php-source .phps
    							ProxyRequests Off 
    							ProxyPassMatch  ^/(.*.php)$ fcgi://127.0.0.1:9000/app/httpd24/htdocs/$1
    							修改下面行
    							<IfModule dir_module>
    								DirectoryIndex index.php index.html
    							</IfModule>
    						systemctl restart httpd
    						systemctl start php-fpm
    
    		配置/etc/httpd/conf.d/zabbix.conf
    			vim  /etc/httpd/conf.d/zabbix.conf
    				在文件头部添加
    					<VirtualHost 192.168.213.175:80>
    					servername zabbix-server
    					documentroot /usr/share/zabbix
    				在文件尾部添加
    					</VirtualHost>
    				修改
    					php_value date.timezone Asia/Shanghai
    		重启httpd服务
    	systemctl restart httpd
    

    5)zabbix agent的安装

    	agent 的运行
    		Zabbix agent运行在被监控主机上。
    		Zabbix agent在linux上以守护进程运行。
    		Zabbix agent是是设计在非root账户下的。它会以其他任何非root用户启动的进程一样的方式运行。所以,您可以使用任意非root用户运行agent,且不会产生任何问题。
    		如果您在’root’账户下运行,它将切换到硬编码的“zabbix”用户,该用户必须存在于您的系统上。如果您只想以’root’方式运行proxy,您必须在proxy配额文件里修改‘AllowRoot‘参数。
    		Zabbix agent成功退出时退出码为0,异常则退出码为1。
    	安装
    		yum install zabbix-agent zabbix-sender
    	配置
    		vim /etc/zabbix/zabbix_agentd.conf|
    		##### Passive checks related  ##被动监控相关配置
    			Server=IP1, IP2, ...##允许那台服务器拉取当前服务器的数据,用于实现基于ip的访问控制,若多个ip可用逗号隔开。
    			ListenPort=10050 ##server端访问的监听端口,默认为10050
    			ListenIP=0.0.0.0  ##本地监听的地址,默认为0.0.0.0,表示监听本地所有地址
    			StartAgents=3  ##用于指定预生成的agent进程数量
    		##### Active checks related  ##主动监控相关配置,agent端主动向server周期性发送数据;
    			ServerActive=IP1[:port], IP2[:port], ... ##信息推送到那台server服务器上,若多个ip可用逗号隔开。
    			Hostname=Unique_HOSTNAME  ##指定当前主机名,用于server端的识别。
    				必须与服务器配置的监控主机的主机名称保持一致;
    	启动
    		systemctl start zabbix-agent
    

    9.zabbix web界面初始化

    http://zabbix_web_ip/zabbix
    	1)进入安装界面,点击next step
    	2)进入check of pre-requisites,确认所有状态都为ok,点击next step
    	3)进入configure DB connection,配置数据库类型,ip,端口,数据库名,用户密码,点击next step
    		
    		端口0表示使用默认端口3306
    	4)进入zabbix server details,配置ip地址,端口,servername,添加name,这个name是你在/etc/httpd/conf.d/zabbix.conf中配置的servername,点击next step。
    	5)进入pre-installation summary,检查,点next step
    	6)进程如install,点击finish
    		
    	7)进入登录界面,默认username为admin,password为zabbix。
    	8)登录后,可以修改英文为中文。
    		若出现部分字体不能显示的情况
    			1》确保/usr/share/zabbix/include/locales.inc.php 中的
    				'zh_CN' => ['name' => _('Chinese (zh_CN)'),	'display' => true]
    			2》上传你喜欢的字体文件到/usr/share/zabbix/fonts,文件是以.ttf结尾的,不是也修改成。
    				编辑/usr/share/zabbix/include/defines.inc.php中的
    					define('ZBX_GRAPH_FONT_NAME',		'simkai'); // font file name
    					define('ZBX_FONT_NAME', 'simkai');
    			确保simkai是你上传的字体文件的文件名
    
  • 相关阅读:
    Nginx知识总结 当幸福来敲门
    JVM 当幸福来敲门
    Redis锁异步线程中使用问题
    使用Mybatis批量插入大量数据的实践
    JdbcType
    Vue和Springboot实现SM4加密和解密(前端可加密,后端可加解密,MD5同理)
    springboot2.x+quartz 实现分布式任务调度
    mpvue 入坑指南
    Vue中使用jssdk
    datax数据迁移所支持的类型及其配置(demo)[txtfilereader]
  • 原文地址:https://www.cnblogs.com/shenxm/p/7900571.html
Copyright © 2020-2023  润新知