zabbix 是一个基于 WEB 界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。zabbix 能监视各类网络参数,保证服务器系统的安全运营;并提供灵活的通知机制以让系统管理员快速定位/解决存在的各类问题。php
Zabbix 的运行架构以下图所示:html
zabbix 由如下几个组件部分构成:前端
1) Zabbix Server:java
负责接收 agent 发送的报告信息的核心组件,全部配置,统计数据及操做数据均由其组织进行;node
2) Database Storage:mysql
专用于存储全部配置信息,以及由 zabbix 收集的数据;linux
3) Web interface:nginx
zabbix 的 GUI 接口,一般与 Server 运行在同一台主机上;c++
4) Proxy:web
可选组件,经常使用于分布监控环境中,代理 Server 收集部分被监控端的监控数据
并统一发往 Server 端;
5) Agent:
部署在被监控主机上,负责收集本地数据并发往 Server 端或 Proxy 端;
注:zabbix node 也是 zabbix server 的一种 。
默认状况下zabbix包含5个程序: zabbix_agentd、 zabbix_get、 zabbix_proxy、 zabbix_sender、zabbix_server,另一个 zabbix_java_gateway 是可选,这个须要另外安装。
下面来分别介绍下他们各自的做用:
zabbix_agentd
客户端守护进程,此进程收集客户端数据,例如 cpu 负载、内存、硬盘使用状况等。
zabbix_get
zabbix 工具,单独使用的命令,一般在 server 或者proxy端执行获取远程客户端信息的命令。 一般用户排错。 例如在server端获取不到客户端的内存数据, 咱们可使用zabbix_get获取客户端的内容的方式来作故障排查。
zabbix_sender
zabbix 工具,用于发送数据给 server 或者proxy,一般用于耗时比较长的检查。不少检查很是耗时间,致使 zabbix 超时。因而咱们在脚本执行完毕以后,使用 sender 主动提交数据。
zabbix_server
zabbix 服务端守护进程。zabbix_agentd、zabbix_get、zabbix_sender、zabbix_proxy、zabbix_java_gateway 的数据最终都是提交到 server
备注:固然不是数据都是主动提交给 zabbix_server,也有的是 server 主动去取数据。
zabbix_proxy
zabbix 代理守护进程。功能相似server,惟一不一样的是它只是一个中转站,它须要把收集到的数据提交/被提交到 server 里。
zabbix_java_gateway
zabbix2.0 以后引入的一个功能。顾名思义:Java 网关,相似 agentd,可是只用于 Java方面。须要特别注意的是,它只能主动去获取数据,而不能被动获取数据。 它的数据最终会给到server或者proxy。
要监控的网络设备,可由 IP 或 DNS 名称指定;
主机的逻辑容器,能够包含主机和模板,但同一个组织内的主机和模板不能互相连接;主机组一般在给用户或用户组指派监控权限时使用;
监控项(item) :
一个特定监控指标的相关的数据;这些数据来自于被监控对象;item是 zabbix 进行数据收集的核心,相对某个监控对象,每一个 item 都由"key"标识;
触发器(trigger) :
一个表达式,用于评估某监控对象的特定 item 内接收到的数据是否在合理范围内,也就是阈值;接收的数据量大于阈值时,触发器状态将从"OK"转变为"Problem",当数据再次恢复到合理范围,又转变为"OK";
事件(event) :
触发一个值得关注的事情,好比触发器状态转变,新的 agent 或从新上
线的 agent 的自动注册等;
动做(action) :
指对于特定事件事先定义的处理方法,如发送通知,什么时候执行操做;
报警媒介类型(media) :
发送通知的手段或者通道,如 Email、Jabber 或者 SMS 等;
模板 (template) :
用于快速定义被监控主机的预设条目集合, 一般包含了 item、 trigger、graph、 screen、 application 以及 low-level discovery rule;模板能够直接连接至某个主机;
前端(frontend) :
Zabbix 的 web 接口
[root@localhost rpm]# pwd /root/rpm [root@localhost rpm]# ls fontconfig-2.8.0-5.el6.x86_64.rpm libX11-common-1.6.4-3.el6.noarch.rpm fontconfig-devel-2.8.0-5.el6.x86_64.rpm libX11-devel-1.6.4-3.el6.x86_64.rpm freetype-2.3.11-17.el6.x86_64.rpm libXau-devel-1.0.6-4.el6.x86_64.rpm freetype-devel-2.3.11-17.el6.x86_64.rpm libxcb-1.12-4.el6.x86_64.rpm gd-devel-2.0.35-11.el6.x86_64.rpm libxcb-devel-1.12-4.el6.x86_64.rpm libICE-1.0.6-1.el6.x86_64.rpm libXext-1.3.3-1.el6.x86_64.rpm libSM-1.2.1-2.el6.x86_64.rpm libXpm-devel-3.5.10-2.el6.x86_64.rpm libvpx-1.3.0-5.el6_5.x86_64.rpm libXt-1.1.4-6.1.el6.x86_64.rpm libvpx-devel-1.3.0-5.el6_5.x86_64.rpm repodata libX11-1.6.4-3.el6.x86_64.rpm xorg-x11-proto-devel-7.7-14.el6.noarch.rpm [root@localhost rpm]# cat /etc/yum.repos.d/CentOS-Media.repo [c6-media] name=CentOS-$releasever - Media baseurl=file:///media/CentOS/ file:///media/cdrom/ file:///media/cdrecorder/ gpgcheck=1 enabled=1 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6 [rpm] name=rpm baseurl=file:///root/rpm/ gpgcheck=0 enabled=1 [root@localhost yum.repos.d]# yum -y install pcre pcre-devel zlib-devel libaio libaio-devel libxml2 libxml2-devel bzip2-devel openssl openssl-devel net-snmp-devel net-snmp curl-devel gd gcc gcc-c++ make libjpeg-devel libpng-devel libcurl-devel perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker mysql-devel net-snmp-utils #若是下一步出现问题,请注释掉yum配置文件里的本地光盘源 [root@localhost rpm]# yum -y install libvpx-devel gd-devel
[root@localhost ~]# useradd -s /sbin/nologin -M www [root@localhost ~]# tar xf nginx-1.10.2.tar.gz -C /usr/src/ [root@localhost ~]# cd /usr/src/nginx-1.10.2/ [root@localhost nginx-1.10.2]# ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_stub_status_module --with-http_ssl_module && make && make install [root@localhost nginx-1.10.2]# ln -s /usr/local/nginx/sbin/* /usr/local/sbin/ #建立nginx配置文件模版 [root@localhost nginx-1.10.2]# cd /usr/local/nginx/conf/ [root@localhost conf]# egrep -v "^$|#" nginx.conf.default > nginx.conf #将nginx配置文件改为以下内容 [root@localhost conf]# vim nginx.conf [root@localhost conf]# cat nginx.conf worker_processes 1; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name localhost; location / { root html; index index.php index.html index.htm; } location = /nginx-status { stub_status on; access_log off; } location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } } [root@localhost conf]# nginx -t nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@localhost ~]# tar xf mysql-5.5.32-linux2.6-x86_64.tar.gz -C /usr/local/ [root@localhost ~]# cd /usr/local/ [root@localhost local]# mv mysql-5.5.32-linux2.6-x86_64 mysql [root@localhost local]# cd mysql/ [root@localhost mysql]# /bin/cp support-files/my-small.cnf /etc/my.cnf [root@localhost mysql]# useradd -s /sbin/nologin -M mysql [root@localhost mysql]# chown -R mysql.mysql data [root@localhost mysql]# /usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql Installing MySQL system tables... OK Filling help tables... OK ...如下省略若干... [root@localhost mysql]# cp support-files/mysql.server /etc/init.d/mysqld [root@localhost mysql]# chmod +x /etc/init.d/mysqld [root@localhost mysql]# /etc/init.d/mysqld start Starting MySQL.. SUCCESS! [root@localhost mysql]# netstat -antup | grep 3306 tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 3990/mysqld
[root@localhost ~]# tar xf libmcrypt-2.5.8.tar.gz -C /usr/src/ [root@localhost ~]# cd /usr/src/libmcrypt-2.5.8/ [root@localhost libmcrypt-2.5.8]# ./configure && make && make install
[root@localhost ~]# tar xf GD-2.18.tar.gz -C /usr/src/ [root@localhost ~]# cd /usr/src/GD-2.18/ [root@localhost GD-2.18]# perl Makefile.PL [root@localhost GD-2.18]# make && make install
[root@localhost ~]# tar xf php-5.6.30.tar.gz -C /usr/src/ [root@localhost ~]# cd /usr/src/php-5.6.30/ [root@localhost php-5.6.30]# ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --with-bz2 --with-curl --enable-sockets --disable-ipv6 --with-gd --with-jpeg-dir=/usr/local --with-png-dir=/usr/local --with-freetype-dir=/usr/local --enable-gd-native-ttf --with-iconv-dir=/usr/local --enable-mbstring --enable-calendar --with-gettext --with-libxml-dir=/usr/local --with-zlib --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd --with-mysql=mysqlnd --enable-dom --enable-xml --enable-fpm --with-libdir=lib64 --enable-bcmath [root@localhost php-5.6.30]# make && make install #建立php配置文件 [root@localhost php-5.6.30]# cp php.ini-development /usr/local/php/etc/php.ini #修改php配置文件php.ini [root@localhost php-5.6.30]# cat -n /usr/local/php/etc/php.ini | sed -n '372p;382p;393p;660p;702p;820p;936p' 372 max_execution_time = 300 382 max_input_time = 300 393 memory_limit = 256M 660 post_max_size = 32M 702 always_populate_raw_post_data = -1 820 upload_max_filesize = 16M 936 date.timezone =Asia/Shanghai #建立php-fpm配置文件 [root@localhost php-5.6.30]# cd /usr/local/php/etc/ [root@localhost etc]# cp php-fpm.conf.default php-fpm.conf #修改php-fpm.conf配置文件 [root@localhost etc]# cat -n php-fpm.conf | sed -n '149,150p' 149 user = www 150 group = www
[root@localhost ~]# useradd zabbix -s /sbin/nologin -M [root@localhost ~]# tar xf zabbix-3.2.4.tar.gz -C /usr/src/ [root@localhost ~]# cd /usr/src/zabbix-3.2.4/ [root@localhost zabbix-3.2.4]# ./configure --prefix=/usr/local/zabbix --with-mysql --with-net-snmp --with-libcurl --enable-server --enable-agent --enable-proxy --with-libxml2 [root@localhost zabbix-3.2.4]# make && make install #因为zabbix启动脚本路径默认指向的是/usr/local/sbin路径,所以,须要提早简历软链接: [root@localhost zabbix-3.2.4]# ln -s /usr/local/zabbix/sbin/* /usr/local/sbin/ [root@localhost zabbix-3.2.4]# ln -s /usr/local/zabbix/bin/* /usr/local/bin/
Zabbix server 和mysql安装到一台服务器上,首先须要手动建立zabbix数据库,操做以下:
[root@localhost ~]# which mysqladmin /usr/bin/mysqladmin [root@localhost ~]# mysqladmin -uroot password '123123' [root@localhost ~]# mysql -uroot -p123123 -e 'create database zabbix character set utf8;' [root@localhost ~]# mysql -uroot -p123123 -e "grant all privileges on zabbix.* to zabbix@'localhost' identified by '123123';" [root@localhost ~]# mysql -uroot -p123123 -e 'flush privileges;' #以下数据的导入顺序不能够错 [root@localhost ~]# mysql -uzabbix -p123123 zabbix < /usr/src/zabbix-3.2.4/database/mysql/schema.sql [root@localhost ~]# mysql -uzabbix -p123123 zabbix < /usr/src/zabbix-3.2.4/database/mysql/images.sql [root@localhost ~]# mysql -uzabbix -p123123 zabbix < /usr/src/zabbix-3.2.4/database/mysql/data.sql
- Zabbix web是php代码编写的,所以须要有php环境,前面已经安装好了lnmp,所以能够直接使用。
- 默认的nginx安装的根目录为/usr/local/nginx/html,所以,只须要Zabbix web的代码放到此目录便可。
- Zabbix web的代码在Zabbix源码包中的frontends/php目录下,将这个php目录拷贝到/usr/local/nginx/html/目录下并更名zabbix便可完成Zabbix web端的安装。
- 在浏览器输入http://IP/zabbix,而后会检查zabbix web运行环境是否知足,并提供链接数据库的相关信息便可,最后将链接数据库相关信息都存入文件zabbix/conf/zabbix.conf.php中,这样就能够登陆zabbix的web平台了。
- 默认的zabbix平台登陆用户名为Admin,密码为zabbix。
[root@localhost ~]# cp -rp /usr/src/zabbix-3.2.4/frontends/php /usr/local/nginx/html/zabbix [root@localhost ~]# cd /usr/local/nginx/html/ [root@localhost html]# ls -l total 12 -rw-r--r--. 1 root root 537 Dec 8 14:15 50x.html -rw-r--r--. 1 root root 612 Dec 8 14:15 index.html drwxr-xr-x. 13 1000 1000 4096 Feb 27 2017 zabbix [root@localhost html]# chown -R www.www zabbix [root@localhost html]# ll -d zabbix/ drwxr-xr-x. 13 www www 4096 Feb 27 2017 zabbix/
[root@localhost html]# /usr/local/nginx/sbin/nginx [root@localhost html]# netstat -antup | grep nginx tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 8439/nginx [root@localhost local]# /usr/local/php/sbin/php-fpm [root@localhost local]# netstat -antup | grep php-fpm tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 8522/php-fpm
#起初并无zabbix.conf.php配置文件,咱们能够选择自动生成配置文件 [root@localhost ~]# cd /usr/local/nginx/html/zabbix/conf [root@localhost conf]# ls maintenance.inc.php zabbix.conf.php.example
在浏览器里输入http://IP/zabbix,配置zabbix数据库环境,以下图所示:
执行如上图所示的步骤生成zabbix.conf.php配置文件
[root@localhost conf]# pwd /usr/local/nginx/html/zabbix/conf [root@localhost conf]# ls maintenance.inc.php zabbix.conf.php zabbix.conf.php.example [root@localhost conf]# cat zabbix.conf.php #里面记录的信息就是咱们刚刚的操做 <?php // Zabbix GUI configuration file. global $DB; $DB['TYPE'] = 'MYSQL'; $DB['SERVER'] = 'localhost'; $DB['PORT'] = '0'; $DB['DATABASE'] = 'zabbix'; $DB['USER'] = 'zabbix'; $DB['PASSWORD'] = '123123'; // Schema name. Used for IBM DB2 and PostgreSQL. $DB['SCHEMA'] = ''; $ZBX_SERVER = 'localhost'; $ZBX_SERVER_PORT = '10051'; $ZBX_SERVER_NAME = 'zabbixserver'; $IMAGE_FORMAT_DEFAULT = IMAGE_FORMAT_PNG;
提示:
除了经过web界面的方式生成zabbix.conf.php文件外,咱们也能够利用zabbix.conf.php.example的模版文件直接修改为咱们须要的配置文件。
经过源码安装方式将zabbix安装到/usr/local/zabbix下面,zabbix server的配置文件为/usr/local/zabbix/etc/zabbix_server.conf,须要修改的内容为以下:
#须要修改的内容为以下: [root@localhost ~]# cd /usr/local/zabbix/etc/ [root@localhost etc]# cat -n zabbix_server.conf | sed -n '12p;38p;87p;103p;111p;118p;136p;165p;181p;297p;447p' 12 # ListenPort=10051 38 LogFile=/tmp/zabbix_server.log 87 DBName=zabbix 103 DBUser=zabbix 111 # DBPassword= 118 # DBSocket=/tmp/mysql.sock 136 # StartPollers=5 165 # StartTrappers=5 181 # StartDiscoverers=1 297 # ListenIP=0.0.0.0 447 # AlertScriptsPath=${datadir}/zabbix/alertscripts #将zabbix_server.conf文件内容修改为以下所示: [root@localhost etc]# cat -n zabbix_server.conf | sed -n '12p;38p;87p;103p;111p;118p;136p;165p;181p;297p;447p' 12 ListenPort=10051 #zabbix server监听端口 38 LogFile=/tmp/zabbix_server.log #zabbix server日志路径 87 DBName=zabbix #zabbix server链接MySQL数据库的数据库名 103 DBUser=zabbix #zabbix server链接MySQL数据库的用户名 111 DBPassword=123123 #zabbix server链接MySQL数据库的密码 118 DBSocket=/tmp/mysql.sock #MySQL的实例文件位置 136 StartPollers=5 #用于设置zabbix server服务启动时启动Pollers(主动收集数据进程)的数量,数量越多,则服务端吞吐能力越强,同时对系统资源消耗越大 165 StartTrappers=10 #用于设置zabbix server服务启动时启动Trappers(负责处理Agentd推送过来的数据的进程)的数量。Agentd为主动模式时,zabbix server须要设置这个值大一些。 181 StartDiscoverers=10 #用于设置zabbix server服务启动时启动Discoverers进程的数量,若是zabbix监控报Discoverers进程忙时,须要提升该值。 297 ListenIP=0.0.0.0 #zabbix server启动的监听端口对哪些ip开放,Agentd为主动模式时,这个值建议设置为0.0.0.0 447 AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts #zabbix server运行脚本存放目录,一些供zabbix server使用的脚本,均可以放在这里。
编辑/etc/services文件,在最后添加如下代码:
[root@localhost ~]# tail -4 /etc/services zabbix-agent 10050/tcp # Zabbix Agent zabbix-agent 10050/udp # Zabbix Agent zabbix-trapper 10051/tcp # Zabbix Trapper zabbix-trapper 10051/udp # Zabbix Trapper
其中,10051是zabbix server的监听端口,10050是zabbix agent的监听端口。
从zabbix源码包misc/init.d/fedora/cora/目录中找到zabbix_server和zabbix_agentd,而后复制到/etc/init.d目录下,因为咱们的zabbix_agnetd采用rpm的安装方式,会自动添加启动脚本,因此在此处,咱们不进行zabbix_agentd的启动脚本的复制。
[root@localhost ~]# cp /usr/src/zabbix-3.2.4/misc/init.d/fedora/core/zabbix_server /etc/init.d/zabbix_server [root@localhost ~]# cd /etc/init.d/ [root@localhost init.d]# chmod +x /etc/init.d/zabbix_server [root@localhost init.d]# chkconfig zabbix_server on
[root@localhost ~]# /etc/init.d/zabbix_server start Starting zabbix_server: [ OK ] [root@localhost ~]# netstat -antup | grep zabbix_server tcp 0 0 0.0.0.0:10051 0.0.0.0:* LISTEN 9319/zabbix_server
zabbix agent端的安装建议采用rpm包方式安装,可从http://repo.zabbix.com/zabbix/3.2/下载zabbix的agent端rpm包,版本与zabbix server端保持一致,安装以下:
[root@localhost chen]# wget http://repo.zabbix.com/zabbix/3.2/rhel/6/x86_64/zabbix-agent-3.2.4-1.el6.x86_64.rpm [root@localhost ~]# rpm -ivh zabbix-agent-3.2.4-1.el6.x86_64.rpm
安装完成后,zabbix agent端已经安装完成了,zabbix agent端的配置目录位于/etc/zabbix下,可在此目录进行配置文件的修改。
特别提示:
- zabbix server的源码包自己就包含了zabbix server端和zabbix agent端,所以,zabbix服务器端无需再安装zabbix agent的rpm包。
- 然而zabbix agent的rpm包是为了方便在服务器上进行快速安装而设计的快捷安装包。
- 所以为了统一,监控端和被监控端的zabbix agent咱们都用rpm的安装方式
修改zabbix agent端的配置文件
#须要修改的内容以下所示: [root@Zabbix_Server ~]# cd /etc/zabbix/ [root@localhost zabbix]# cat -n zabbix_agentd.conf | sed -n '13p;32p;95p;103p;120p;136p;147p;265p;284p' 13 PidFile=/var/run/zabbix/zabbix_agentd.pid 32 LogFile=/var/log/zabbix/zabbix_agentd.log 95 Server=127.0.0.1 103 # ListenPort=10050 120 # StartAgents=3 136 ServerActive=127.0.0.1 147 Hostname=Zabbix server 265 Include=/etc/zabbix/zabbix_agentd.d/*.conf 284 # UnsafeUserParameters=0 #将内容修改成以下所示: [root@localhost zabbix]# cat -n zabbix_agentd.conf | sed -n '13p;32p;95p;103p;120p;136p;147p;265p;284p' 13 PidFile=/var/run/zabbix/zabbix_agentd.pid #进程pid存放路径 32 LogFile=/var/log/zabbix/zabbix_agentd.log #zabbix agent日志存放路径 95 Server=127.0.0.1,192.168.0.220 #指定zabbix server端IP地址 103 ListenPort=10050 #指定agentd的监听端口 120 StartAgents=3 #指定启动agentd进程数量。设置0表示关闭 136 ServerActive=192.168.0.220:10051 #启用agnetd主动模式,启动主动模式后,agentd将主动将收集到的数据发送到zabbix server端,Server Active后面指定的IP就是zabbix server端IP 147 Hostname=192.168.0.220 #须要监控服务器的主机名或者IP地址,此选项的设置必定要和zabbix web端主机配置中对应的主机名一致。 265 Include=/etc/zabbix/zabbix_agentd.d/ #相关配置均可以放到此目录下,自动生效 284 UnsafeUserParameters=1 #启用agent端自定义item功能,设置此参数为1后,就可使用UserParameter指令了。UserParameter用于自定义item
启动zabbix_agent端进程
[root@localhost ~]# /etc/init.d/zabbix-agent start Starting Zabbix agent: [ OK ] [root@localhost ~]# netstat -antup | grep zabbix_agent tcp 0 0 0.0.0.0:10050 0.0.0.0:* LISTEN 1322/zabbix_agentd tcp 0 0 :::10050 :::* LISTEN 1322/zabbix_agentd [root@localhost init.d]# chkconfig zabbix-agent on
咱们在监控端和被监控端都进行如上所述的zabbix agent端的安装。
如何知道zabbix server监控已经生效呢,可经过zabbix server上的zabbix_get命令来完成,在zabbix server上执行以下命令便可进行测试:
#利用以下命令进行测试 /usr/local/zabbix/bin/zabbix_get -s 192.168.0.221 -p 10050 -k "system.uptime" -s 是指定zabbix agent端的IP地址 -p 是指定zabbix agent端的监听端口 -k 是监控项,即item 若是有输出结果,表面zabbix server能够从zabbix agent获取数据,配置成功。
具体操做以下:
#在监控端zabbix_server端进行以下操做 [root@localhost init.d]# /usr/local/zabbix/bin/zabbix_get -s 192.168.0.221 -p 10050 -k "system.uptime" 26330 #有数据显示就表明监控正常 [root@localhost init.d]# /usr/local/zabbix/bin/zabbix_get -s 192.168.0.220 -p 10050 -k "system.uptime" 55653 #有数据显示就表明监控正常
- 经常使用的图形:能够根据本身喜爱,添加按主机按监控项添加快捷的查看连接
- 经常使用的聚合图形:能够将多个监控图形的曲线合并显示
- 经常使用的拓扑图:集群的架构图
- 主机状态:被监控的主机的实时状态
- Web检测:发一个http请求,看看web是否能正常访问
- 系统状态:监控端zabbix server服务器的状态
- 最近20个问题:最后发生的20个告警信息
- Zabbix状态:zabbix server监控的详细汇总信息
调整后,以下所示:
特别提示
在生产环境时,主机组的名字必定要用英文,否则,当zabbix进行二次开发的时候,中文名称都是乱码。那感受很让人想死...
特别提示
在生产环境中主机的名字必定要是英文,而且务必和真实主机的主机名一致,且必须归类加入到主机组中。否则zabbix在进行二次开发的时候会很是麻烦(须要创建相似索引形式的东西去关联真实服务器)
如今假如咱们要定义一个获取nginx链接数的监控项,那么咱们先得去尝试可以获取这个值。在以前的nginx配置文件里咱们已经加入了status模块的获取
(1)咱们登陆网页获取这个信息
(2)咱们尝试经过命令获取这个信息
[root@localhost zabbix_agentd.d]# curl -s "http://192.168.0.220:80/nginx-status" Active connections: 6 server accepts handled requests 301 301 8833 Reading: 0 Writing: 1 Waiting: 5 [root@localhost zabbix_agentd.d]# curl -s "http://192.168.0.220:80/nginx-status" | grep "Active" Active connections: 6 [root@localhost zabbix_agentd.d]# curl -s "http://192.168.0.220:80/nginx-status" | grep "Active" | awk '{print $NF}' 6
(3)在zabbix agent配置文件里定义这个监控项
[root@localhost ~]# cd /etc/zabbix/ #进入zabbix agent目录 [root@localhost zabbix]# ls zabbix_agentd.conf zabbix_agentd.d [root@localhost zabbix]# vim zabbix_agentd.conf [root@localhost zabbix]# sed -n '257,270p' zabbix_agentd.conf ### Option: Include # You may include individual files or all files in a directory in the configuration file. # Installing Zabbix will create include directory in /usr/local/etc, unless modified during the compile time. # # Mandatory: no # Default: # Include= Include=/etc/zabbix/zabbix_agentd.d/ #咱们发现zabbix_agentd.d目录已经默认被include进入了主配置文件。 # Include=/usr/local/etc/zabbix_agentd.userparams.conf # Include=/usr/local/etc/zabbix_agentd.conf.d/ # Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf
因为zabbix_agentd.conf配置文件默认导入了全部zabbix_agentd.d目录下的内容,所以咱们能够将监控项定义到zabbix_agentd.d目录下。
(4)参考模版,本身定义监控项的获取命令
[root@localhost zabbix_agentd.d]# pwd /etc/zabbix/zabbix_agentd.d [root@localhost zabbix_agentd.d]# vim nginx.conf [root@localhost zabbix_agentd.d]# cat nginx.conf [root@localhost zabbix_agentd.d]# cat nginx.conf UserParameter=nginx.active,/usr/bin/curl -s "http://192.168.0.220:80/nginx-status" | grep "Active" | awk '{print $NF}'
(5)自定义监控项,等于改变了配置文件,天然须要重启zabbix_agentd
[root@localhost ~]# /etc/init.d/zabbix-agent restart Shutting down Zabbix agent: [ OK ] Starting Zabbix agent: [ OK ]
(6)在zabbix server端测试获取自定义的监控项信息
[root@localhost ~]# zabbix_get -s 192.168.0.220 -p 10050 -k "nginx.active" 6
至此zabbix自定义监控项的后台定义所有完成
(1)点选一个被监控的主机
(2)进入监控项建立模版
(3)建立监控项
(4)建立完成的监控项
监控项建立完成之后,在zabbix server这个主机里就出现这个新定义的监控项了。
(1)点选一个被监控的主机
(2)进入图形建立模版
(3)查看图形绘图
(4)关于图形的各类显示效果
正常图形:
层积图形
Pie图形
爆发的图形
(1)建立一个聚合图形
(2)编辑聚合图形
(3)选择展现图形
(4)将聚合图形添加到zabbix web首页面板
(1)进入拓扑图编辑界面
(2)添加一个新的拓扑图形
(3)拓扑图连接拓扑图
(4)拓扑图显示时时的链接带宽
上图中的标签内容以下:
{linux-node1.yunjisuan.com:net.if.out[eth0].last(0)}
linux-node1.yunjisuan.com为定义的主机名
net.if.out[eth0]为监控项的表达式
last(0)为取监控项的最后一个值
(1)熟悉Zabbix各模块操做,回家胡乱点点
(2)自学部署Smokeping网络监控
(3)自学Piwik流量分析系统