首页 > 代码库 > zabbix 从0开始学习的步骤
zabbix 从0开始学习的步骤
注明:以下学习过程参考了很多文档,如有问题,请留言联系!谢谢
一、系统版本
CentOS-6.5-x86_64
二、环境
1、主机名
1.1 hostname
1.2 vim /etc/sysconfig/network
HOSTNAME=
2、网卡
vim /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE=eth0
ONBOOT=yes
BOOTPROTO=static
IPADDR=192.168.2.35
3、selinux
vim /etc/selinux/config
SELINUX=disabled
setenforce 0 #使配置立即生效
4、时间同步
ntpdate 0.pool.ntp.org
方法二
ln -s /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
vi /etc/ntp/step-tickers
加入一行:
pool.ntp.org
service ntpd start
5、防火墙
iptables -I INPUT -p tcp --dport 80 -j ACCEPT
iptables -I INPUT -p tcp --dport 21 -j ACCEPT
iptables -I INPUT -p tcp --dport 5901 -j ACCEPT
service iptables save
或:service iptables stop 关闭防火墙
二、LAMP环境
yum -y groupinstall "Development Tools"
1、安装Apache
yum install -y httpd
vim /etc/httpd/conf/httpd.conf
ServerName www.domain.com:80去掉注释并把域名改成localhost或本机地址
service httpd start
chkconfig httpd on
2、安装PHP与关联
yum -y install php php-gd php-xml php-bcmath php-mbstring php-mysql
3、安装Mysql
yum -y install mysql mysql-server mysql-devel
service mysqld start
chkconfig mysqld on
mysqladmin -u root password ‘123456‘ 创建数据库登陆账户和密码
查看数据库:show databases;
查看库中的表:show tables FROM zabbix
4、测试
vim /var/www/html/index.php
<?php phpinfo(); ?>
三、安装zabbix
1、安装依赖软件包
yum -y install curl curl-devel net-snmp net-snmp-devel perl-DBI gcc libxml2*
2、下载zabbix(可供选择的下载地址)
http://www.zabbix.com/download.php
http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/ http://jaist.dl.sourceforge.net/project/zabbix/
3、下载,解压zabbix (在官网选择要安装的版本)
2.4
wget http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/2.4.0/zabbix-2.4.0.tar.gz
2.48(汉化)
http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/2.4.8/zabbix-2.4.8.tar.gz
2.2
wget http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/2.2.5/zabbix-2.2.5.tar.gz
tar xf zabbix
cd zabbix
4、编译
./configure --prefix=/usr/local/zabbix --enable-server --enable-agent --enable-proxy --with-mysql --with-net-snmp --with-libcurl --with-libxml2
注1://--prefix指定zabbix安装目录,--enable-server 支持zabbix服务器,--enable-agent支持zabbix代理,--enable-proxy 支持zabbix代理服务器,--with-mysql 使用MySQL客户端库可以选择指定路径mysql_config,--with-net-snmp 使用net - snmp软件包,择性地指定路径NET- SNMP配置,--with-libcurl 使用curl包
注2:
报错:error: MySQL library not found
安装:yum install mariadb-devel
报错:error: LIBXML2 library not found,
安装:yum install -y libxml2*
报错:error: Invalid Net-SNMP directory
安装:yum install -y net-snmp-devel
5、安装执行
make&&make install
6、 进入zabbix目录创建用户
groupadd zabbix 创建用户组zabbix
useradd -g zabbix -m zabbix 创建用户zabbix属于zabbix组
chown -R zabbix.zabbix /usr/local/zabbix 改变zabbix安装目录的拥有者和组群
7、创建数据库
mysql -u root -p
mysql> create database zabbix character set utf8;
mysql> grant all on zabbix.* to zabbix@localhost identified by ‘zabbix‘;
授权:本机能访问mysql,root用户下授权
mysql> flush privileges; ##刷新系统授权
mysql>quit;
8、导入数据库
在解压后的zabbix目录中执行
mysql -uzabbix -pzabbix -hlocalhost zabbix < database/mysql/schema.sql
mysql -uzabbix -pzabbix -hlocalhost zabbix < database/mysql/images.sql
mysql -uzabbix -pzabbix -hlocalhost zabbix < database/mysql/data.sql
10、服务器端配置文件
vim /usr/local/zabbix/etc/zabbix_server.conf
DBName=zabbix 数据库名
DBUser=zabbix 数据库登陆账户
DBPassword=zabbix 数据登陆密码
11、配置PHP
vi /etc/php.ini
max_input_time = 600
# sed -i ‘s/max_input_time = 60/max_input_time = 600/g‘ php.ini
max_execution_time = 300
# sed -i ‘s/max_execution_time = 30/max_execution_time = 300/g‘ php.ini
date.timezone = Asia/Shanghai
post_max_size = 16M
# sed -i ‘s/post_max_size = 8M/post_max_size = 16M/g‘ php.ini
memory_limit = 128M
service httpd restart
12、启动设置
1、修改启动参数
修改启动脚本中的路径/usr/local改成/usr/local/zabbix
cp misc/init.d/fedora/core/* /etc/init.d/
sed -i ‘s/BASEDIR=\/usr\/local/BASEDIR=\/usr\/local\/zabbix/g‘ /etc/init.d/zabbix_server
sed -i ‘s/BASEDIR=\/usr\/local/BASEDIR=\/usr\/local\/zabbix/g‘ /etc/init.d/zabbix_agentd
2、启动进程
echo "/etc/init.d/zabbix_server start" >> /etc/rc.local
echo "/etc/init.d/zabbix_agentd start" >> /etc/rc.local
/etc/init.d/zabbix_server start
/etc/init.d/zabbix_agentd start
ps -ef | grep zabbix 查看进程
3、开放端口
iptables -I INPUT -p tcp --dport 10050:10051 -j ACCEPT
iptables -I INPUT -p udp --dport 10050:10051 -j ACCEPT
service iptables save
查看端口
netstat -npl|grep 10050
netstat -npl|grep 10051
四、页面初始化
cd zabbix-2.2.5
cp -R frontends/php/ /var/www/html/zabbix
打开:
http://192.168.2.35/zabbix/
五、客户机端安装配置
1、主机名
1.1 hostname
1.2 vim /etc/sysconfig/network
HOSTNAME=
2、依赖环境
yum -y install curl curl-devel net-snmp net-snmp-devel perl-DBI gcc
3、下载与服务器端同版本,步骤相似
编译:
./configure --prefix=/usr/local/zabbix --enable-agent --with-mysql --with-net-snmp --with-libcurl --with-libxml2
4.1、客户端配置文件
vim /usr/local/zabbix/etc/zabbix_agentd.conf
Server= #修改为zabbix服务器端IP
ServerActive= #修改为zabbix服务器端IP
Hostname=Zabbix server
UnsafeUserParameters=1 #启用自定义key
5、防火墙,端口
iptables -I INPUT -p tcp --dport 10050:10051 -j ACCEPT
iptables -I INPUT -p udp --dport 10050:10051 -j ACCEPT
service iptables save
或:service iptables stop
6、进入zabbix目录创建用户
groupadd zabbix 创建用户组zabbix
useradd -g zabbix -m zabbix 创建用户zabbix属于zabbix组
chown -R zabbix.zabbix /usr/local/zabbix 改变zabbix安装目录的拥有者和组群
7、启动设置
1、修改启动参数
修改启动脚本中的路径/usr/local改成/usr/local/zabbix
cp misc/init.d/fedora/core/* /etc/init.d/
sed -i ‘s/BASEDIR=\/usr\/local/BASEDIR=\/usr\/local\/zabbix/g‘ /etc/init.d/zabbix_agentd
2、启动进程
echo "/etc/init.d/zabbix_agentd start" >> /etc/rc.local
/etc/init.d/zabbix_agentd start
ps -ef | grep zabbix 查看进程
3、开放端口
iptables -I INPUT -p tcp --dport 10050:10051 -j ACCEPT
iptables -I INPUT -p udp --dport 10050:10051 -j ACCEPT
service iptables save
查看端口
netstat -npl|grep 10050
netstat -npl|grep 10051
8、测试与主机的链接(在zabbix-service端)
/usr/local/zabbix/bin/zabbix_get -s 192.168.190.2 -p 10050 -k "system.uptime"
注:192.168.190.2 指agentd端IP
#有数据显示说明通信正常
9、服务重启(如不能正常重启,则使用以下方法)
查看进程
ps ax|grep zabbix_agentd
关闭进程
ps ax|grep zabbix_agentd|grep -v grep |awk ‘{print $1}‘|xargs kill -9
启动服务
/etc/init.d/zabbix_agentd restart
六、控制台使用
1、添加主机(主机组一样的创建方法)
configuration(配置)---> Hosts(主机)---> Create host(创建主机)
1.1 Host选项
host name 主机IP
visible name (显示的名字)
Groups (组)
New host group (新建组)
Agent interfaces
IP address 被监控端IP
1.2 链接模板
configuration ---> hosts ---> Name前选择要链接的服务器 ---> 左下角(下拉菜单)选择mass update(go) ---> 模板 ---> 选择模板“Template OS liunx”
2、用户
创建新登录用户
管理 ---> 用户 ---> 右上下拉菜单处选择‘用户’ ---> 右上‘创建用户’ ---> 组群(添加超级超级管理员组) ---> 添加媒介(比如邮件) ---> 许可权 ---> 保存
注:许可权 指:权限,当前用户对哪些主机有权限,选择”超级管理员“。
3、图表数据
Monitoring ---> Graphs ---> group / host / Graph
4、item(监控项)
configuration(配置)---> Hosts(主机)---> (主机) ---> (item) ---> Create item
重点:key
Name item的名字
Type item类型,采集数据的方式
key item的标识符(标记item的键),唯一,可接受参数
Type of information 采集的数据类型
Flexible intervals 采集数据间隔数据
New flexible interval 添加采集数据间隔数据
application item组
5、创建图像
5.1 Graphs
Configuration ---> Hosts ---> Graphs ---> Create Graphs
Name 图像名
Graph type 图像类型
items (add) 添加需要加进来的item(监控项)
5.2 Screen
configuration(配置)---> Screen ---> Create Screen
6、Triggers(触发器)
6.1 表达格式:{<server>:<key>.<function>(<parameter>)}<operator><constant>
server 主机名
key 主机上关系,相应监控项(item)的key
function 评估采集到的数据是否在河里范围内时所使用的函数
parameter 函数参数
举例:
{192.168.0.104:system.cpu.load[all,avg1].last(0)}>3
说明:
主机192.168.0.104上所有CPU的过去1分钟内的平均负载的最后一次取值大于3时将触发状态变换
6.2 创建triggers(触发器)
configuration(配置)---> Hosts(主机)---> triggers ---> Create triggers
6.2.1 Triggers(触发器)
configuration(配置)---> Hosts(主机)---> triggers ---> Create triggers
Name (Triggers名)
Expression (定义条件)
Severity 触发级别
7、action (动作,操作)
(宏参考文档:https://www.zabbix.com/documentation/2.2/manual/appendix/macros/supported_by_location)
7.1 定义媒介
Administration ---> Media types ---> Create media type
Name:媒介名字(自定义)
Type:(媒介类型)
7.2 接收人配置
Administration ---> Users ---> (用户)---> Media ---> add:
Type: (选择上一步自定义的媒介名)
send to:(收件邮箱)
---> add ---> save
7.3设置Action
Configration ---> Action ---> Create action
1.Actions项(发送邮件的格式和内容)
Name:action的名字
Default message (信息内容)
Recovery message (转换成OK时发送信息)
2.Conditions(发送警告的条件)
Trigge = PROBLEM (触发器)
3.Operation ---> New
Step (告警级别)
Operation type (告警方式)
Send message(发送信息)
******Remote command (命令操作)
Send to User groups (发送到的用户组)
Send to Users (发送到的用户)
Send only to (选择调用脚本)
---> add ---> save
8、模板
Configration ---> Templates
Create Templates (创建模板)
七、web监控
网页状态码获取(正常值为200):
curl -I -m 10 -o /dev/null -s -w %{http_code}"\n" www.baidu.com
1、首页是否能打开
创建application
1.1********* configuration ---> Host ---> Application ---> create application
1.2 configuration ---> Host ---> 你的主机 ---> web ---> 右上角Create scenario
scenario 主要选项:
Name:监控项的名称
Application:放到哪个应用中
Update interval:更新周期,默认60秒
Agetn:模拟浏览器
Variables:宏变量(没有可以不填)
steps 主要选项
name:当前step名称,item key中可以用到
url:需要检测的网址
POST:你需要post提交上去的内容(没有可以不填)
Timeout:超时时间,默认15秒
Required status codes:响应代码必须包含在里面,多个响应代码用逗号分隔
正常响应码为:200
web监控方案创建后自动添加以下item,可在创建trigger中直接使用
说明:使用时,Scenario换为真是方案的名称
web.test.in[Scenario,,bps]
说明:页面(step)的下载速度,默认单位bps
web.test.fail[Scenario]
说明:出现错误的步骤(步骤指监控的页面):ailed step of scenario "Scenario".
web.test.error[Web1]
说明:最后一次的错误信息:Last error message of scenario "Scenario".
web.test.in[Scenario,step,bps]
说明:页面(step)的下载速度(指定相应方案Scenario的相应步骤step)
web.test.rspcode[Scenario,step]
说明:指定步骤中的页面的响应码,页面正常的响应码为200
web.test.time[Scenario,step,resp]
说明:指定步骤中的页面的响应时间
2、登陆*********
scenario 选项:
Variables:宏变量
用来定义能登录的账号密码
user=
password
steps 主要选项
POST:你需要post提交上去的内容,
例如:使用宏变量:user={user}&password={password}&Sign in
3、验证登录*********
steps 主要选项:
Required string :Profile
4、查看结果
monitorning ---> web---> 筛选出你的主机 ---> 查看“WEB性能监控_FOR_TTLSA”,Status,显示OK 便是正常
5、监控项*********
web方案监控项当web监控项创建好之后,下面的key会被自动添加好(备注:Scenario为web方案的名称)
web.test.in[Scenario,,bps] 整个阶段中的下载速度,单位字节/秒
web.test.rspcode[Scenario,Step] 检索指定阶段的http响应代码
八、自定义邮件报警
1、linux zabbix-server端配置
mutt+msmtp下载安装:
下载MSMTP
# wget http://down1.chinaunix.net/distfiles/msmtp-1.4.30.tar.bz2
# tar xvf msmtp-1.4.17.tar.bz2
# cd msmtp-1.4.17
# ./configure --prefix=/usr/local/msmtp
# make
# make install
# cd /usr/local/msmtp/
# mkdir etc #配置文件目录和配置文件都要自己建
# cd etc
# vim msmtprc #手动创建配置文件
# account default
# host smtp.163.com
# port 25
# from xman@163.com #要从哪个邮箱发出
# auth login #这里如果使用on的话会报 "msmtp: cannot use a secure authentication method"错误
# tls off
# user xman@163.com #邮箱用户名
# password xmanufo #邮箱密码,这里可是明文的,如果你觉得不安全可以把文件改为600属性
# logfile /var/log/mmlog
保存退出。简单测试一下
/usr/local/msmtp/bin/msmtp xman@163.com
随便输入一些内容用ctrl+d结束。然后到邮箱查看
安装MUTT
yum -y install mutt
# vim /etc/Muttrc
# set sendmail="/usr/local/msmtp/bin/msmtp"
# set use_from=yes
# set realname="fan******_007@163.com"
# set editor="vim"
测试一下吧!
echo "testmail" | mutt -s "测试" ufo@sina.com
这里的-a 是指添加附件,如果是多个附件的话就 多加几个 -a 文件名
脚本路径
cd /usr/local/zabbix/share/zabbix/alertscripts/
编写sendmail脚本:
#!/bin/bash
#zabbix use msmtp+mutt sendmail script.
echo $1; #to email address.
echo $2; #title.
echo $3; #content.
echo "$3" | mutt -s "$2" $1
脚本权限:
chmod +x sendmail.sh
测试:
./sendmail.sh $1 $2 $3
$1 收邮件地址
$2 邮件标题
$3 邮件内容
2、控制台配置使用sendmail.sh脚本
2.1创建媒介
Administration ---> Media types ---> Create media type
# Name:媒介名字(自定义)
# Type :Script (选择脚本Script)
# Scriptname:sendmail.sh (脚本名)
2.2接收人配置
Administration ---> Users ---> (用户)---> Media ---> add:
# Type: (选择上一步自定义的媒介名)
# send to:(收件邮箱)
---> add ---> save
2.3设置Action
(宏参考文档:https://www.zabbix.com/documentation/2.2/manual/appendix/macros/supported_by_location)
Configration ---> Action ---> Create action
1.Actions项(发送邮件的格式和内容)
Name:action的名字
# Default message (信息内容)
# Recovery message (转换成OK时发送信息)
2.Conditions(发送警告的条件)
# Trigger value = http://www.mamicode.com/PROBLEM (触发器)
3.Operation ---> New
Step (告警级别)
Operation type (告警方式,选择:Send message(发送信息))
Send to User groups (发送到的用户组)
# Send to Users (发送到的用户)
# Send only to (选择调用脚本)
# ---> add ---> save
2.4 测试
十、测试操作
1、 主机:node1 无任何模板和触发器
用户:admin
2、自定义item
选定node1对应的items ---> greate item --->
Name:Network Outbound Rating
key:net.if.out[eth0]
store value:Delta(speed per second)
application:Net
Name:Network Inbound Rating
key:net.if.in[eth0]
store value:Delta(speed per second)
application:Net
Name:CPU Switches
key:system.cpu.switches
store value:As is
application:CPU
Name:CPU Interrupts
key:system.cpu.intr
store value:As is
application:CPU
save 保存
查看各个item采集的数据图像
Monitoring ---> Latest data ---> Graph
3、 可视图
3.1 自定义Graphs
图一: Network Outbound Rating
Network Inbound Rating
图二: CPU Switches
CPU Interrupts
3.2 自定义Screen
4、Triggers(触发器)
configuration(配置)---> Hosts(主机)---> triggers ---> Create triggers
自定义:Network Inbound Rating 的 Triggers(触发器)
Expression (定义条件)
{node1:net.if.in[eth0].last()}>10000
Severity 触发级别
High
5、设置邮件报警
当触发Triggers,邮箱便会收到邮件
十一:本机测试
1、创建媒介
Administration ---> Media types ---> Create media type
name:localhost_mail(自定义名)
Type:Email
SMTP server:localhost
SMTP helo:localhost
SMTP email:zabbix@localhost
2、创建收件人媒介配置(测试用admin配置)
Administration ---> Users ---> (admin)---> Media ---> add:
# Type: localhost_mail
# send to:root@localhost
---> add ---> save
3、action动作配置
Configration ---> Action ---> Create action
1.Actions项(发送邮件的格式和内容)
Name:action的名字
# Default message (信息内容)
# Recovery message (转换成OK时发送信息)
2.Conditions(发送警告的条件)
# Trigger value = http://www.mamicode.com/PROBLEM (触发器)
3.Operation ---> New
Step:1-3 (告警级别)
Operation type: (告警方式,选择:Send message(发送信息))
# Send to Users:Admin
# Send only to:localhost_mail
# ---> add ---> save
十二、自定义宏
官方参考文档:
https://www.zabbix.com/documentation/2.2/manual/appendix/macros/supported_by_location
变量可以用于如下地方:
item 名称
item key 参数
触发器名称和描述
触发器表达式
其他地方
宏变量优先级:
主机宏(checked first)
主机模板定义的宏,如果有多个模板,那么按照模板越靠前那么宏的优先级越高
全局宏(checked last)
自定义宏
定义全局宏
Administration → General → Macros
十三、自定义监控
客户端配置文件 zabbix_angentd.conf 里面配置 UserParameter=1.
语法如下:
UserParameter=<key>,<command>
示例:
1、自定义监控客户端free,(zabbix_angentd端添加)
vim zabbix-agentd.conf #zabbix-agent配置文件添加
UserParameter=memory.free,/usr/bin/free | awk ‘/^Mem/{print $4}‘
重启zabbix_angentd
测试是否定义成功:(在zabbix_server端)
/usr/local/zabbix/bin/zabbix_get -s 192.168.0.104 -k "memory.free"
返回了数据,即表示成功
控制台添加items
key:memory.free
灵活的自定义 key:
UserParameter=key[*],command
示例:
自定义监控cat /proc/meminfo下的所有项,[*]指/proc/meminfo下的项目参数
UserParameter=memory.usage[*],/bin/cat /proc/meminfo | awk ‘/^$1:/{print $$2}‘
测试是否定义成功:(在zabbix_server端)
/usr/local/zabbix/bin/zabbix_get -s 192.168.0.104 -k "memory.usage[Buffers]"
/usr/local/zabbix/bin/zabbix_get -s 192.168.0.104 -k "memory.usage[MemFree]"
/usr/local/zabbix/bin/zabbix_get -s 192.168.0.104 -k "memory.usage[MemTotal]"
控制台添加items
key:memory.usage[Buffers]
key:memory.usage[MemFree]
key: memory.usage[MemTotal]
实战:监控nginx(本机IP:192.168.0.106)
(参考文档:http://www.ttlsa.com/zabbix/zabbix-monitor-nginx-performance/)
nginx status信息
curl http://127.0.0.1/ngx_status
yum安装nginx:
rpm -ivh http://nginx.org/packages/centos/6/noarch/RPMS/nginx-release-centos-6-0.el6.ngx.noarch.rpm
yum -y install nginx
service nginx start
配置:
cd /etc/nginx/conf.d/
vim default.conf
nginx.status开启方法:
server{
...
location /status {
stub_status on;
access_log off;
allow 192.168.0.0/16;
deny all;
}
}
nginx -t 检查语法
状态页面各项数据的意义
active connections - 当前 Nginx 正处理的活动链接数
serveraccepts handled requests - 总共处理了233851个链接,成功创建233851次握手(证明中间没有失败的),总共处理了687942个请求(平均每场握手处理了2.94个数据请求)
reading - nginx 读取到客户端的 header 信息数
writing - nginx 返回给客户端的 header 信息数
waiting - 开启 keep-alive 的情况下,这个值等于 active - (reading + writing),意思就是Nginx已处理完正在等候下一次骑牛指令的驻留链接
nginx压力测试:
ab -n 1000 -c 100 http://192.168.0.106/status/
vim /usr/local/zabbix/etc/zabbix_agentd.conf
修改
UnsafeUserParameters=1
文档末尾:添加以下内容:
UserParameter=Nginx.active[*],/usr/bin/curl -s "http://$1:$2/status" | awk ‘/^Active/{print $NF}‘
UserParameter=Nginx.reading[*],/usr/bin/curl -s "http://$1:$2/status" | grep ‘Reading‘ | cut -d" " -f2
UserParameter=Nginx.writing[*],/usr/bin/curl -s "http://$1:$2/status" | grep ‘Writing‘ | cut -d" " -f4
UserParameter=Nginx.waiting[*],/usr/bin/curl -s "http://$1:$2/status" | grep ‘Waiting‘ | cut -d" " -f6
UserParameter=Nginx.accepted[*],/usr/bin/curl -s "http://$1:$2/status" | awk ‘/^[ \t]+[0-9]+[ \t]+[0-9]+[ \t]+[0-9]+/{print $$1}‘
UserParameter=Nginx.handled[*],/usr/bin/curl -s "http://$1:$2/status" | awk ‘/^[ \t]+[0-9]+[ \t]+[0-9]+[ \t]+[0-9]+/{print $$2}‘
UserParameter=Nginx.requests[*],/usr/bin/curl -s "http://$1:$2/status" | awk ‘/^[ \t]+[0-9]+[ \t]+[0-9]+[ \t]+[0-9]+/{print $$3}‘
说明:
$1 指主机HOST(IP或域名)
$2 端口
服务器端测试:
/usr/local/zabbix/bin/zabbix_get -s 192.168.0.106 -k "Nginx.accepted[192.168.0.106,80]"
控制台(192.168.0.105/zabbix)key
Nginx.active[192.168.0.106,80] as is
Nginx.reading[192.168.0.106,80] as is
Nginx.writing[192.168.0.106,80] as is
Nginx.waiting[192.168.0.106,80] as is
Nginx.accepted[192.168.0.106,80] delta
Nginx.handled[192.168.0.106,80] delta
Nginx.requests[192.168.0.106,80] delta
网页的http_code:
UserParameter=web.http_code:curl -I -m 10 -o /dev/null -s -w %{http_code}"\n" 192.168.2.35/index.php
第一阶段总结:定义一次完整的监控:
1、添加主机(主机组)
2、添加item(内置的简单图形 Monitoring ---> Latest data)
3、trigger(event:OK ---> Problem,Recovery)
4、action(发通知 message(通知信息中使用宏)conditond(自定义触发条件),operation(step))
5、媒介 Administration ---> Media types
Script (脚本)
6、自定义图形
1、Graphs
2、screen
7、map(拓扑图)***********
8、定义模板
configuration ---> Templates
十四、自动发现
1、定义模板
1、创建定义模板
configuration ---> Templates ---> creat Template
必填参数:
Template name
Visible name
Groups
New group
2、为自定义的模板添加item
configuration ---> Templates ---> 创建的模板 ---> item ---> create item
3、为创建的item创建trigger
4、为创建的item创建graphs
2、discovery(发现)设置:
configuration ---> Discovery ---> create Discovery rule(自定义发现规则)
Name
Discovery by proxy
IP range:(IP范围,如:192.168.2.1-100)
Delay (in sec):(延迟时间)
Checks (New)
Check type:zabbix agent (发现规则)
Port range:10050
Key:(获取其中监控的一个key作为获取的手段)
Device uniqueness criteria: IP address
3、action添加主机:(添加主机:定义接口,关联模板)
configuration ---> Action ---> Event source:(discovery) ---> create action
1、action
Name
2、Conditions (发现条件)
New condition
Host IP=
Discovery rule =
Discovery status = Discovered
3、operations (发现后的操作)
Add host (添加发现的主机)
Link to templates: Test-Template (为添加的主机连接测试模板)
自动注册
configuration ---> Action --->Event source:(Auto registration) ---> create action
4、移除主机
configuration ---> Action ---> Event source:(discovery) ---> create action
1、action
Name
2、Conditions
Discovery status = "Lost"
Host IP=
3、operations (发现后的操作)
Remove host
十五、分布式环境中使用zabbix_proxy
1、依赖环境
yum -y install curl curl-devel net-snmp net-snmp-devel perl-DBI gcc
2、proxy安装配置
下载,解压zabbix (在官网选择要安装的版本)
2.4
wget http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/2.4.0/zabbix-2.4.0.tar.gz
2.48(汉化)
http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/2.4.8/zabbix-2.4.8.tar.gz
2.2
wget http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/2.2.5/zabbix-2.2.5.tar.gz
3、下载与服务器端同版本,步骤相似
编译:
./configure --prefix=/usr/local/zabbix --enable-agent --enable-proxy --with-mysql --with-net-snmp --with-libcurl
注:如需监控proxy端,可安装:--enable-agent
make && make install
4、安装mysql
yum -y install mysql mysql-server mysql-devel
service mysqld start
chkconfig mysqld on
mysqladmin -u root password ‘123456‘ 创建数据库登陆账户和密码
查看数据库:show databases;
查看库中的表:show tables FROM zabbix
5、创建数据库
mysql -u root -p
mysql> create database zabbix_proxy character set utf8;
注:创建数据库 zabbix_proxy
mysql> grant all on zabbix_proxy.* to zabbix@localhost identified by ‘zabbix‘;
授权:本机能访问mysql的zabbix_proxy库,root用户下授权
mysql> grant all on zabbix_proxy.* to zabbix@‘192.168.%.%‘ identified by ‘zabbix‘;
授权:192.168.网段的用户能访问mysql的zabbix_proxy库,root用户下授权
注:在其他服务器登录
mysql -u zabbix -h192.168.%.% -p
mysql> flush privileges; ##刷新系统授权
mysql>quit;
6、导入数据库
在解压后的zabbix目录中执行
mysql -uzabbix -pzabbix -hlocalhost zabbix_proxy < database/mysql/schema.sql
7、配置文档
vim /usr/local/zabbix/etc/zabbix_proxy.conf
Server= #zabbix-server端IP
Hostname= #必须和控制台端的Proxy name 保持一直,建议使用IP
DBHost=localhost #数据库主机
DBName=zabbix_proxy #数据库名,与前面创建的数据名一定要相同
DBUser=zabbix #数据库登录用户
DBPassword= zabbix #数据库密码
ConfigFrequency=1 #默认3600秒,建议修改为短时间
DataSenderFrequency=10 #默认1秒,建议修改为10-30秒
ProxyOfflineBuffer=1 #默认1小时
8、进入zabbix目录创建用户
groupadd zabbix 创建用户组zabbix
useradd -g zabbix -m zabbix 创建用户zabbix属于zabbix组
chown -R zabbix.zabbix /usr/local/zabbix
9、启动设置******
/usr/local/zabbix/sbin/zabbix_proxy
查看proxy端是否启动
ss -tanlp
重启方法:同zabbix-agentd端重启方法
10、需要被proxy监控的host的zabbix_agentd.conf的Server=指向proxy的IP
11、配置zabbix-server控制台端
11.1、创建proxy
Administration ---> DM ---> creat proxy
必填选项:
Proxy name
#必须和zabbix_proxy.conf配置文件的Hostname=保持一致
Proxy mode:Active
11.2、创建主机
Configuration ---> Hosts ---> creat host
必填选项:
Host name
Visible name
Agent interfaces
Monitored by proxy
重点:选择创建proxy时的Proxy name
11.3、创建item、trigger或嵌套模板
十六、监控Windows
1、agents端win版下载(官方下载)
conf目录存放是agent配置文件 bin文件存放windows下32位和64位安装程序
示例:
c:/zabbix
c:/zabbix/bin/
c:/zabbix/conf/
c:/zabbix/logs/
2、配置与安装
2.1 配置zabbix agent相关配置。
找到conf下的配置文件 zabbix_agentd.win.conf ,修改以下参数:
LogFile=c:/zabbix/logs/ #日志路径
Server #zabbix-server端IP
Hostname #本机名
ServerActive #zabbix-server端IP
3、启动
开始 ---> 运行 ---> CMD
cd c:\zabbix\bin
zabbix-agentd.exe -c c:\zabbix\conf/zabbix_agentd.win.conf
安装成Windows服务
service.msc 开始Windows服务控制台--->开启服务
netstat -an 查看端口是否被监控
4、控制台设置
添加主机、item、trigger
十七、监控类型
zabbix agent
zabbix 自带的客户端程序(被动模式)
需要注意的是,server 检索数据有超时限制,最大超时时间 30 秒,如果检索数据经常超过 30 秒,那么,不建议你使用主动模式的agent
zabbix agent (active )
agent主动模式
simple check
基本的检测,可以检测网络、端口、fping 这些,功能很少并且无需安装客户端。
snmp check
适用于以下场景:
客户基于安全考虑,不同意安装agent
路由器、打印机等无法安装的设备
十八、维护模式
Configuration(配置) → Maintenance(维护)—>点击 Create maintenance period (创建维护周期)
Maintenance
Maintenance type 维护类型
With data collection – 依旧收集数据
No data collection– 暂停收集数据
Active since 维护周期开始时间
Active till 维护结束时间
Periods:维护周期
十九、zabbix命令
19.1、zabbix_server
启动zabbix_server端
zabbix_server -c <file>
<file> 指配置.conf文件路径
19.2、获取agent端的key的数据
zabbix_get -s --host<hostname or IP> -p <post> -k --key <key of metric>
--host<hostname or IP> 指客户端主机名或IP
<post> 指监控端口
--key <key of metric> 指客户端的key
实例
./zabbix-get -s 127.0.0.1 -p 10050 -k "system.hostname"
19.3、zabbix_agentd
启动zabbix_agentd端
zabbix_agentd -c <file>
<file> 指配置.conf文件路径
19.4、zabbix_proxy
启动 zabbix_proxy 端
zabbix_proxy -c <file>
<file> 指配置.conf文件路径
二十、优化
1、操作系统优化
2、数据库优化
3、数据库分离
4、数据库引擎
mysql5.6或更高的版本
5、其他优化
减少item获取时间
减少不必要的监控项
终章:实战
zabbix监控
puppet_master
mem cached
mysql (master)
mysql (slave)
nginx(mogilefs) amoeba
mogilefs mogstored
tomcat
其它:
zabbix-service端安装配置,页面初始化“简易脚本”
#!/bin/bash
#
# 环境
yum -y install curl curl-devel net-snmp net-snmp-devel perl-DBI gcc libxml2*
# 下载安装
cd /usr/local/src
wget http://jaist.dl.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/2.2.5/zabbix-2.2.5.tar.gz
tar xf zabbix-2.2.5.tar.gz
cd zabbix-2.2.5
./configure --prefix=/usr/local/zabbix --enable-server --enable-agent --enable-proxy --with-mysql --with-net-snmp --with-libcurl --with-libxml2
make && make install
# 创建用户
groupadd zabbix
useradd -g zabbix -m zabbix
chown -R zabbix.zabbix /usr/local/zabbix
# 数据库设置
mysql -u root -p123456 -e "
create database zabbix character set utf8;
grant all on zabbix.* to zabbix@localhost identified by ‘zabbix‘;
flush privileges;
quit"
#数据库导入
mysql -uzabbix -pzabbix -hlocalhost zabbix < database/mysql/schema.sql
mysql -uzabbix -pzabbix -hlocalhost zabbix < database/mysql/images.sql
mysql -uzabbix -pzabbix -hlocalhost zabbix < database/mysql/data.sql
# 修改配置文件:zabbix_server.conf
cd /usr/local/zabbix/etc/
sed -i ‘s/DBUser=root/DBUser=zabbix/g‘ zabbix_server.conf
echo DBPassword=zabbix >> zabbix_server.conf
# 修改php配置文件
cd /etc/
sed -i ‘s/max_input_time = 60/max_input_time = 600/g‘ php.ini
sed -i ‘s/max_execution_time = 30/max_execution_time = 300/g‘ php.ini
sed -i ‘s/post_max_size = 8M/post_max_size = 16M/g‘ php.ini
echo ‘date.timezone = Asia/Shanghai‘ >> php.ini
service httpd restart
# 启动设置
cd /usr/local/src/zabbix-2.2.5/
cp misc/init.d/fedora/core/* /etc/init.d/
sed -i ‘s/BASEDIR=\/usr\/local/BASEDIR=\/usr\/local\/zabbix/g‘ /etc/init.d/zabbix_server
sed -i ‘s/BASEDIR=\/usr\/local/BASEDIR=\/usr\/local\/zabbix/g‘ /etc/init.d/zabbix_agentd
echo "/etc/init.d/zabbix_server start" >> /etc/rc.local
echo "/etc/init.d/zabbix_agentd start" >> /etc/rc.local
/etc/init.d/zabbix_server start
/etc/init.d/zabbix_agentd start
cp -R frontends/php/ /var/www/html/zabbix
zabbix 从0开始学习的步骤