CentOS7下搭建zabbix监控(一)——Zabbix监控端配置

CentOS7下搭建zabbix监控(二)——Zabbix被监控端配置

(1).配置Zabbix监控Apache服务

  主机名:youxi2  IP地址:192.168.5.102

  注意:需要找一个合适的Apache监控模板

 1)安装httpd,这里为了简化步骤直接yum安装

[root@youxi2 ~]# yum -y install httpd
[root@youxi2 ~]# systemctl enable httpd  //设置开机自启
Created symlink from /etc/systemd/system/multi-user.target.wants/httpd.service to /usr/lib/systemd/system/httpd.service.

 2)开启Apache的server-status,并重启httpd

[root@youxi2 ~]# vim /etc/httpd/conf/httpd.conf
EnableSendfile on  //这是第348行,在这行下面添加如下标签
<location /server-status>
SetHandler server-status
Order allow,deny
Allow from localhost 192.168.5.0/24
</location>
[root@youxi2 ~]# systemctl restart httpd

  还可以在/etc/httpd/conf.d/目录下创建一个.conf格式的文件,将配置写入其中。最后重启httpd。

  注意:有时候127.0.0.1不生效会导致zapache不支持,可以将IP地址改成all尝试。

 3)如果防火墙是打开的,记得添加端口号

[root@youxi2 ~]# firewall-cmd --permanent --zone=public --add-port=80/tcp
success
[root@youxi2 ~]# firewall-cmd --reload
success
[root@youxi2 ~]# firewall-cmd --permanent --zone=public --list-ports
10050/tcp 80/tcp

 4)Web验证Apache打开server-status

 5)下载模板文件

  模板文件需要在Windows和CentOS上各留一份,地址:https://github.com/lorf/zapache/archive/master.zip。然后解压

  由于下载的是zip格式文件,所以需要unzip程序

[root@youxi2 ~]# yum -y install unzip

  安装完成后解压文件

[root@youxi2 ~]# unzip zapache-master.zip
Archive: zapache-master.zip
24a764b2e224f9b8d0a6bc94dcadd7568b2fe650
creating: zapache-master/
inflating: zapache-master/README.md
inflating: zapache-master/httpd-server-status.conf.sample
inflating: zapache-master/userparameter_zapache.conf.sample
inflating: zapache-master/zapache
inflating: zapache-master/zapache-template-active.xml
inflating: zapache-master/zapache-template.xml
[root@youxi2 ~]# ls zapache-master/
httpd-server-status.conf.sample zapache
README.md zapache-template-active.xml
userparameter_zapache.conf.sample zapache-template.xml

  文件说明:

   httpd-server-status.conf.sample  用于配置httpd开启server-status

   zapache、userparameter_zapache.conf.sample  关键的脚本和配置文件

   zapache-template-active.xml、zapache-template.xml  模板文件(active是动作,是触发器模板)

 6)修改配置文件和脚本

[root@youxi2 ~]# cp zapache-master/zapache /usr/local/bin/  //拷贝脚本
[root@youxi2 ~]# chmod +x /usr/local/bin/zapache  //给脚本添加执行权限
[root@youxi2 ~]# cp zapache-master/userparameter_zapache.conf.sample /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_zapache.conf  //拷贝配置文件,并重命名
[root@youxi2 ~]# vim /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_zapache.conf
UserParameter=zapache[*],/usr/local/bin/zapache \$1  //指向脚本文件
[root@youxi2 ~]# vim /usr/local/zabbix/etc/zabbix_agentd.conf
# Include=/usr/local/etc/zabbix_agentd.userparams.conf  //第263~265行
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/  //去除注释,修改并启用该目录
# Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf

 7)Web端导入模板

   A.选择配置中的模板,点击导入

   B.选择导入文件,点击导入,就成功导入这个模板了。

 8)Web端关联模板(给现有的主机添加新的模板)

   A.选择配置中的主机,点击任意主机名称

   B.选择模板,选中Template App Apache Web Server zapache模板,添加并更新

   C.之后可以在监测的图形中选择Apache相关检测项

    也可以在监测中的最新数据选择Apache相关监控项构成图形

(2).配置Zabbix监控Mysql服务

  主机:youxi2  IP地址:192.168.5.102

  和Apache一样需要先找一个监控模板,不过Zabbix默认提供了Mysql的监控模板。

 1)安装Mysql

  具体查看:二进制包安装Mysql

  mysql安装目录/usr/local/mysql/,数据目录/usr/local/mysql/data/,mysql的root用户密码为123456。启动并设置开机自启。

 2)数据库用户授权

   创建用户和授予usage权限是一样的效果。

[root@youxi2 ~]# mysql -uroot -p123456
mysql> create user 'zabbix'@'192.168.5.%' identified by '123456';  //创建用户zabbix
Query OK, 0 rows affected (0.00 sec) mysql> show grants for 'zabbix'@'192.168.5.%';  //查看用户zabbix的权限
+----------------------------------------------+
| Grants for zabbix@192.168.5.% |
+----------------------------------------------+
| GRANT USAGE ON *.* TO 'zabbix'@'192.168.5.%' |  //usage表示只有登录和查询information_schema的权限
+----------------------------------------------+
1 row in set (0.00 sec) mysql> grant usage on *.* to 'zabbix2'@'192.168.5.%' identified by '123456';  //授权zabbix2
Query OK, 0 rows affected, 1 warning (0.00 sec) mysql> show grants for 'zabbix2'@'192.168.5.%';  //查看用户zabbix2的权限
+-----------------------------------------------+
| Grants for zabbix2@192.168.5.% |
+-----------------------------------------------+
| GRANT USAGE ON *.* TO 'zabbix2'@'192.168.5.%' |
+-----------------------------------------------+
1 row in set (0.00 sec) mysql> flush privileges;  //刷新
Query OK, 0 rows affected (0.00 sec)

 3)修改配置文件,并重启Zabbix Agent

[root@youxi2 ~]# cp /usr/local/src/zabbix-3.4.3/conf/zabbix_agentd/userparameter_mysql.conf /usr/local/zabbix/etc/zabbix_agentd.conf.d/
[root@youxi2 ~]# vim /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_mysql.conf  //HOME参数的路径必须与下方编辑的.my.cnf路径必须一致
UserParameter=mysql.status[*],echo "show global status where Variable_name='$1';" | HOME=/usr/local/zabbix/etc mysql -N | awk '{print $$2}'  //第5行
UserParameter=mysql.size[*],bash -c 'echo "select sum($(case "$3" in both|"") echo "data_length+index_length";; data|index) echo "$3_length";; free) echo "data_free";;
esac)) from information_schema.tables$([[ "$1" = "all" || ! "$1" ]] || echo " where table_schema=\"$1\"")$([[ "$2" = "all" || ! "$2" ]] || echo "and table_name=\"$2\"");"
| HOME=/usr/local/zabbix/etc/ mysql -N'  //第15行
UserParameter=mysql.ping,HOME=/usr/local/zabbix/etc mysqladmin ping | grep -c alive  //第17行
[root@youxi2 ~]# vim /usr/local/zabbix/etc/.my.cnf  //配置数据库与zabbix连接文件。与上方userparameter_mysql.conf修改路径保持一致
#Zabbix Agent
[mysql]
host=localhost
user=zabbix
password=123456
socket=/usr/local/mysql/mysql.sock [mysqladmin]
host=localhost
user=zabbix
password=123456
socket=/usr/local/mysql/mysql.sock
[root@youxi2 ~]# vim /usr/local/zabbix/etc/zabbix_agentd.conf
# Include=/usr/local/etc/zabbix_agentd.userparams.conf  //第263~265行,三个里面有且仅有一个开启
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/  //去除注释,修改并启用该目录
# Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf
[root@youxi2 ~]# /etc/init.d/zabbix_agentd restart  //重启 Restarting zabbix_agentd (via systemctl): [ 确定 ]

 4)在监控端测试

  如果提示如下错误,需要到被监控端(youxi2)将mysql和mysqladmin做一个软链接到/usr/bin下(明明有环境变量,也可以在youxi2上直接调用,但它就不认)

[root@youxi1 ~]# /usr/local/zabbix/bin/zabbix_get -s192.168.5.102 -p10050 -k mysql.status[Uptime]
sh: mysql: 未找到命令
[root@youxi1 ~]# /usr/local/zabbix/bin/zabbix_get -s192.168.5.102 -p10050 -k mysql.ping
sh: mysqladmin: 未找到命令

  做一个软链接

[root@youxi2 ~]# ln -s /usr/local/mysql/bin/mysql /usr/bin/
[root@youxi2 ~]# ln -s /usr/local/mysql/bin/mysqladmin /usr/bin/

  再次测试成功

[root@youxi1 ~]# /usr/local/zabbix/bin/zabbix_get -s192.168.5.102 -p10050 -k mysql.status[Uptime]
414
[root@youxi1 ~]# /usr/local/zabbix/bin/zabbix_get -s192.168.5.102 -p10050 -k mysql.ping
1

 5)Web端关联模板

  A.选择配置中的主机,点击任意主机名称

  B.选择模板,选中Template DB MySQL模板,添加并更新

  C.之后就可以在监测中查看了。

最新文章

  1. 页面解耦—— 统跳协议和Rewrite引擎
  2. WebSQL 查询工具
  3. LeetCode之Binary Tree Level Order Traversal 层序遍历二叉树
  4. 在.net中设置debug模式预设代码
  5. WCF学习系列一_创建第一个WCF服务
  6. DotDensityRenderer
  7. ggplot2 theme相关设置—矩形设置(rect)
  8. carryLess小笔记001_Java中16进制与字符串之间的相互转换
  9. 【面试笔试算法】Program 3 : Complicated Expression(网易游戏笔试题)
  10. VS2017离线安装包[百度云盘](收藏了)
  11. c# 复制整个文件夹的内容,Copy所有文件
  12. 转载:MySQL字段类型
  13. python之hashlib
  14. (转)nginx uwsgi wsgi django 这些东西究竟是什么关系
  15. 布局fixed和sticky
  16. ASP.NET Core 2.1 源码学习之 Options[2]:IOptions
  17. 代码规范(RL-TOC)用更合理的方式写 JavaScript
  18. socket技术详解(看清socket编程)
  19. akka cluster sharding
  20. POJ 3087 Shuffle&#39;m Up(洗牌)

热门文章

  1. [课本]JDBC课程6--使用JDBC的DAO模块化--完成数据库的增删查改_工具类JDBCTools四个(Preparedstatement)功能模块的敲定版
  2. 记一个VS连接过程中找不到cpp的解决方法
  3. XAMPP启动Apache服务时启动失败
  4. 六、用DataContractSerialize类序列化XML
  5. Java注解合并,注解继承
  6. centos7安装docker-compose
  7. spring boot, 容器启动后执行某操作
  8. 基础 | BIO、NIO与AIO
  9. 如何利用Wireshark解密SSL和TLS流量
  10. Ubuntu18.04开机动画(bootsplash)安装