返回列表 发帖

Zabbix创建模板监控Linux下的MariaDB

笺注:这是在 CentOS8编译安装Zabbix4.4.5 的基础上进行的,监控本机的MariaDB


配置本机的MariaDB数据库:( 使用数据库管理员root@localhost )
[root@centos8 ~]# mysql -u"root" -h"localhost"
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 100
Server version: 10.3.17-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]>

注释:
此时,数据库管理员root@localhost没有设置密码;
-h"localhost" 是可以省略的;



查看当前登录的数据库用户:
MariaDB [(none)]> Select user();
+----------------+
| user()         |
+----------------+
| root@localhost |
+----------------+
1 row in set (0.000 sec)

MariaDB [(none)]>



再授权数据库用户zbx_monitor@localhost(密码168),只能本地登录,对所有的库有完全控制的权限:
MariaDB [(none)]> create user zbx_monitor@localhost identified by '168';
Query OK, 0 rows affected (0.002 sec)

MariaDB [(none)]> grant all on *.* to zbx_monitor@localhost;
Query OK, 0 rows affected (0.001 sec)

MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.001 sec)

MariaDB [(none)]>


查看本地数据库用户zbx_monitor@localhost的权限:
MariaDB [(none)]> show grants for zbx_monitor@localhost;
+-----------------------------------------------------------------------------------------------------------------------------+
| Grants for zbx_monitor@localhost                                                                                            |
+-----------------------------------------------------------------------------------------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'zbx_monitor'@'localhost' IDENTIFIED BY PASSWORD '*242E46A1E8D30FE06F7CE37B55BFC25BA981D70C' |
+-----------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.001 sec)

MariaDB [(none)]>



显示所有库:
[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -e "show databases;"
+--------------------+
| Database           |
+--------------------+
| db1                |
| information_schema |
| mysql              |
| performance_schema |
| zabbix             |
+--------------------+

[root@centos8 ~]#


[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -sN -e "show databases;"
db1
information_schema
mysql
performance_schema
zabbix

[root@centos8 ~]#



显示所有库的总大小:(以字节为单位)
[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES;"
+----------+
| data     |
+----------+
| 10971378 |
+----------+

[root@centos8 ~]#


[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES;" |awk '{print $1}'|tail -1
10971378
[root@centos8 ~]#


[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -sN -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES;"
10971378
[root@centos8 ~]#



显示库zabbix的大小:(以字节为单位)
[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES where table_schema = 'zabbix';"
+---------+
| data    |
+---------+
| 9650176 |
+---------+

[root@centos8 ~]#


[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES where table_schema = 'zabbix';" |awk '{print $1}'|tail -1
9650176
[root@centos8 ~]#


[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -sN -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES where table_schema = 'zabbix';"
9650176
[root@centos8 ~]#



显示库zabbix的表users的大小:(以字节为单位)
[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -e "select concat(sum(DATA_LENGTH))as data from information_schema.TABLES where table_schema='zabbix' and table_name='users';"
+-------+
| data  |
+-------+
| 16384 |
+-------+

[root@centos8 ~]#


[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -e "select concat(sum(DATA_LENGTH))as data from information_schema.TABLES where table_schema='zabbix' and table_name='users';" |awk '{print $1}'|tail -1
16384
[root@centos8 ~]#


[root@centos8 ~]# mysql -u"zbx_monitor" -p"168" -sN -e "select concat(sum(DATA_LENGTH))as data from information_schema.TABLES where table_schema='zabbix' and table_name='users';"
16384
[root@centos8 ~]#





#############
#############

修改Zabbix服务器的Agent配置文件:
[root@centos8 ~]# vi /usr/local/zabbix/etc/zabbix_agentd.conf

# UnsafeUserParameters=0
修改为:(启用该功能)
UnsafeUserParameters=1

接着插入:
  1. UserParameter=command_0,mysql -u"zbx_monitor" -p"168" -sN -e "show databases;"

  2. UserParameter=command_1,mysql -u"zbx_monitor" -p"168" -sN -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES;"

  3. UserParameter=command_2,mysql -u"zbx_monitor" -p"168" -sN -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES where table_schema = 'zabbix';"

  4. UserParameter=command_3[*],mysql -u"zbx_monitor" -p"168" -sN -e "select concat(sum(DATA_LENGTH)) as data from information_schema.TABLES where table_schema = '$1';"

  5. UserParameter=command_4[*],mysql -u"zbx_monitor" -p"168" -sN -e "select concat(sum(DATA_LENGTH))as data from information_schema.TABLES where table_schema='$1' and table_name='$2';"
复制代码


保存好配置文件后,重启一下Zabbix本机的客户端和服务端:
pkill -9 -U zabbix
/usr/local/zabbix/sbin/zabbix_agentd
/usr/local/zabbix/sbin/zabbix_server



######

在Zabbix服务器测试,验证能否获取本机(127.0.0.1)的键值:

显示所有库:
[root@centos8 ~]# /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -k command_0
db1
information_schema
mysql
performance_schema
zabbix

[root@centos8 ~]#


显示所有库的总大小:(以字节为单位)
[root@centos8 ~]# /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -k command_1
10971378
[root@centos8 ~]#


显示库zabbix的大小:(以字节为单位)
[root@centos8 ~]# /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -k command_2
9650176
[root@centos8 ~]#


显示库zabbix的大小:(以字节为单位)
[root@centos8 ~]# /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -k command_3["zabbix"]
9650176
[root@centos8 ~]#


显示库db1的大小:(以字节为单位)
[root@centos8 ~]# /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -k command_3["db1"]
374779
[root@centos8 ~]#


显示库zabbix的表users的大小:(以字节为单位)
[root@centos8 ~]# /usr/local/zabbix/bin/zabbix_get -s 127.0.0.1 -k command_4["zabbix","users"]
16384
[root@centos8 ~]#





##################Zabbix创建模板:

配置》模板》创建模板:(群组可以随便选)
图片1.png
2022-9-2 19:59




在模板Template DB MariaDB_2中创建监控项:
监控项名称: MariaDB command_1
键值: command_1
信息类型: 数字(无正负)
图片2.png
2022-9-2 19:59

备注:其他地方保持默认,点击底下的“添加”按键。



在模板Template DB MariaDB_2中创建监控项:
监控项名称: MariaDB command_2
键值: command_2
信息类型: 数字(无正负)
图片3.png
2022-9-2 20:00

备注:
单位留空时,结果在单位换算时会每超过1000就除以1000,保留两位小数,是四舍五入;
在监控项对应的图形中可以看到结果;



在模板Template DB MariaDB_2中创建监控项:
监控项名称: MariaDB command_3["zabbix"]
键值: command_3["zabbix"]
信息类型: 数字(无正负)
单位: B
图片4.png
2022-9-2 20:00

备注:
使用单位“B”时,结果在单位换算时会每超过1024就除以1024,保留两位小数,是四舍五入;



在模板Template DB MariaDB_2中创建监控项:
监控项名称: MariaDB command_3["db1"]
键值: command_3["db1"]
信息类型: 数字(无正负)
单位: Bytes
图片5.png
2022-9-2 20:00

备注:
使用单位“Bytes”时,结果在单位换算时会每超过1000就除以1000,保留两位小数,是四舍五入;



在模板Template DB MariaDB_2中创建监控项:
监控项名称: MariaDB command_4["zabbix","users"]
键值: command_4["zabbix","users"]
信息类型: 数字(无正负)
图片6.png
2022-9-2 20:01

本页拖下去:
图片7.png
2022-9-2 20:01



至此,模板Template DB MariaDB_2有了5个监控项:
图片8.png
2022-9-2 20:02






############

在模板Template DB MariaDB_2中,给监控项“MariaDB command_1”创建图形:
图片9.png
2022-9-2 20:02

监控项:
图片10.png
2022-9-2 20:02




在模板Template DB MariaDB_2中,给监控项“MariaDB command_2”创建图形:
图片11.png
2022-9-2 20:03

监控项:
图片12.png
2022-9-2 20:03




在模板Template DB MariaDB_2中,给监控项“MariaDB command_3["zabbix"]”创建图形:
图片13.png
2022-9-2 20:03

监控项:
图片14.png
2022-9-2 20:04




在模板Template DB MariaDB_2中,给监控项“MariaDB command_3["db1"]”创建图形:
图片15.png
2022-9-2 20:04

监控项:
图片16.png
2022-9-2 20:04




在模板Template DB MariaDB_2中,
给监控项“MariaDB command_4["zabbix","users"]”创建图形:
图片17.png
2022-9-2 20:05

监控项:
图片18.png
2022-9-2 20:05



至此,模板Template DB MariaDB_2有了5个图形:
图片19.png
2022-9-2 20:05






##################Zabbix添加被监控主机:

配置》主机》创建主机:  (主机名称无需与被监控主机的真实主机名一致;群组可以随便选)
图片20.png
2022-9-2 20:06

注释:
使用agent代理程序的接口。
IP地址: 127.0.0.1 (同一台主机可以被重复添加,只要主机名称不一样即可)
使用 TCP 10050 端口。


主机MariaDB_2添加成功:
图片21.png
2022-9-2 20:06



给主机MariaDB_2添加模板:( Template DB MariaDB_2  )
图片22.png
2022-9-2 20:06



模板Template DB MariaDB_2添加成功:
图片24.png
2022-9-2 20:09



笺注:主机会继承所使用的模板的监控项、触发器、图形等等。



######

监测》图形:

查看主机MariaDB_2的图形“MariaDB command_1 image”:
图片25.png
2022-9-2 20:10


图片26.png
2022-9-2 20:11


图片27.png
2022-9-2 20:11




查看主机MariaDB_2的图形“MariaDB command_2 image”:
图片28.png
2022-9-2 20:11


图片29.png
2022-9-2 20:11


图片30.png
2022-9-2 20:12




查看主机MariaDB_2的图形“MariaDB command_3["zabbix"] image”:
图片31.png
2022-9-2 20:12


图片32.png
2022-9-2 20:12


图片33.png
2022-9-2 20:12




查看主机MariaDB_2的图形“MariaDB command_3["db1"] image”:
图片34.png
2022-9-2 20:13


图片35.png
2022-9-2 20:13


图片36.png
2022-9-2 20:13




查看主机MariaDB_2的图形“MariaDB command_4["zabbix","users"] image”:
图片37.png
2022-9-2 20:13


图片38.png
2022-9-2 20:14


图片39.png
2022-9-2 20:14






############
############

在模板Template DB MariaDB_2中,
给监控项“MariaDB command_3["zabbix"]”创建一个触发器:(返回值大于9.5MB就告警)

触发器名称: Database zabbix is bigger than 9.5MB
严重性: 警告
图片40.png
2022-9-2 20:14


插入表达式:( 监控项 Template DB MariaDB_2: MariaDB command_3["zabbix"]
图片41.png
2022-9-2 20:15


自动生成的表达式:(触发器的表达式要用到监控项中的键值)
{Template DB MariaDB_2:command_3["zabbix"].last()}>9.5M
图片42.png
2022-9-2 20:15


本页拖下去:
图片43.png
2022-9-2 20:15



至此,模板Template DB MariaDB_2有了1个触发器:
图片44.png
2022-9-2 20:16




############

使用了模板Template DB MariaDB_2的主机会立即继承新的触发器:
图片45.png
2022-9-2 20:17


图片46.png
2022-9-2 20:17



主机MariaDB_2的图形“MariaDB command_3["zabbix"] image”会自动发生改变:(多了一条告警线,多了一个触发器)
图片47.png
2022-9-2 20:17


图片48.png
2022-9-2 20:17




主机MariaDB_2的监控项“MariaDB command_3["zabbix"]”的返回值大于9.5MB
时,仪表板会如下图显示:(显示对应触发器的名称)
Database zabbix is bigger than 9.5MB
图片49.png
2022-9-2 20:18


图片50.png
2022-9-2 20:18




######

在主机MariaDB_2中禁用触发器:
图片51.png
2022-9-2 20:18


笺注:触发器被禁用后,仪表板的告警会自动消失,在主机MariaDB_2的图形“MariaDB command_3["zabbix"] image”中也看不到这个触发器了。





############
############

在模板Template DB MariaDB_2的监控项中更改“单位”:
监控项名称: MariaDB command_2
键值: command_2
信息类型: 数字(无正负)
单位: uptime
图片52.png
2022-9-2 20:19

备注:
现在假设返回值是时间“秒”;
uptime - 转换成 hh:mm:ss
天,hh:mm:ss

再次,查看主机MariaDB_2的图形“MariaDB command_2 image”:
图片53.png
2022-9-2 20:19


图片54.png
2022-9-2 20:19


图片55.png
2022-9-2 20:20






相关文章:
使用Navicat远程管理MySQL
Zabbix创建模板监控Windows下的MariaDB

返回列表