背景:因爲zabbix3.4裏面的mysql監控模板沒有監控mysql的key,因此須要本身從新定義須要監控的key。
mysql
Zabbix Server與Agent之間監控數據的採集主要是經過Zabbix Server主動向Agent詢問某個Key的值,
sql
Agent會根據Key去調用相應的函數去獲取這個值並返回給Server端。
緩存
監控需求:
bash
一、監控MySQL的狀態,當狀態發生異常,發出報警;
服務器
二、監控MySQL的操做,並用圖表展示;
ide
三、使用自定義腳本監控擴展Agent。
函數
1、受權mysql登陸用戶(agentd端操做)
性能
MariaDB [(none)]> grant usage on *.* to 'read'@'47.98.97.124' identified by '123456';
測試
Query OK, 0 rows affected (0.00 sec)
優化
MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.00 sec)
2、編輯userparameter_mysql.conf文件
[root@host-47-98-97-124 ~]# cp /root/zabbix-3.4.2/conf/zabbix_agentd/userparameter_mysql.conf /usr/local/zabbix/etc/zabbix_agentd.conf.d/
[root@host-47-98-97-124 ~]# vi /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_mysql.conf
UserParameter=mysql.version,mysql -V
UserParameter=mysql.status[*],/usr/local/zabbix/scripts/chk_mysql.sh $1
[root@host-47-98-97-124 ~]# mkdir /usr/local/zabbix/scripts
[root@host-47-98-97-124 ~]# chmod +x /usr/local/zabbix/scripts/chk_mysql.sh
[root@host-47-98-97-124 ~]# vi /usr/local/zabbix/etc/zabbix_agentd.conf
Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/*.conf #開啓
3、mysql服務器性能監控腳本
#!/bin/bash
#Filename:chk_mysql.sh
#Author:zhangjunchao
MYSQL_SOCK="/var/lib/mysql/mysql.sock"
MYSQL_USER='read'
MYSQL_PASSWORD='123456'
MYSQL_HOST='47.98.97.124'
MYSQL_PORT='3306'
MYSQL_Connect="/usr/bin/mysqladmin -u$MYSQL_USER -p$MYSQL_PASSWORD -h$MYSQL_HOST -P$MYSQL_PORT -S$MYSQL_SOCK"
if [ $# -ne 1 ];then
echo "please input one arguement"
fi
case $1 in
Uptime) #查詢當前MySQL本次啓動後的運行統計時間
result=`${MYSQL_Connect} status | cut -d ":" -f 2 | cut -d " " -f 2`
echo $result
;;
Slow_queries) #查看當前慢查詢語句的個數
result=`${MYSQL_Connect} extended-status | grep -w "Slow_queries" | cut -d "|" -f 3`
echo $result
;;
Com_rollback) #執行回滾的個數
result=`${MYSQL_Connect} extended-status | grep -w "Com_rollback" | cut -d "|" -f 3`
echo $result
;;
Questions)
result=`${MYSQL_Connect} extended-status | grep -w "Questions" | cut -d "|" -f 3`
echo $result
;;
Com_commit)
result=`${MYSQL_Connect} extended-status | grep -w "Com_commit" | cut -d "|" -f 3`
echo $result
;;
Bytes_sent) #發送的字節數
result=`${MYSQL_Connect} extended-status | grep -w "Bytes_sent" | cut -d "|" -f 3`
echo $result
;;
Bytes_received) #接受的字節數
result=`${MYSQL_Connect} extended-status | grep -w "Bytes_received" | cut -d "|" -f 3`
echo $result
;;
Com_begin)
result=`${MYSQL_Connect} extended-status | grep -w "Com_begin" | cut -d "|" -f 3`
echo $result
;;
Open_tables) #查看當前打開的表數量
result=`${MYSQL_Connect} status | cut -d ":" -f 5 | cut -d " " -f 2`
echo $result
;;
Threads_connected) #查看當前打開的鏈接數量
result=`${MYSQL_Connect} extended-status | grep -w "Threads_connected" | cut -d "|" -f 3`
echo $result
;;
Threads_cached) #查看線程緩存內的線程數量
result=`${MYSQL_Connect} extended-status | grep -w "Threads_cached" | cut -d "|" -f 3`
echo $result
;;
Threads_created) #查看建立用來處理鏈接的線程數。若是Threads_created較大,可能要增長thread_cache_size值。
result=`${MYSQL_Connect} extended-status | grep -w "Threads_created" | cut -d "|" -f 3`
echo $result
;;
Threads_running) #查看激活的(非睡眠狀態)線程數
result=`${MYSQL_Connect} extended-status | grep -w "Threads_running" | cut -d "|" -f 3`
echo $result
;;
Slow_launch_threads) #查看建立時間超過slow_launch_time秒的線程數
result=`${MYSQL_Connect} extended-status | grep -w "Slow_launch_threads" | cut -d "|" -f 3`
echo $result
;;
Com_select) #查看select語句的執行數
result=`${MYSQL_Connect} extended-status | grep -w "Com_select" |cut -d "|" -f 3`
echo $result
;;
Com_insert) #查看insert語句的執行數
result=`${MYSQL_Connect} extended-status | grep -w "Com_insert" |cut -d "|" -f 3`
echo $result
;;
Com_update) #查看update語句的執行數
result=`${MYSQL_Connect} extended-status | grep -w "Com_update" | cut -d "|" -f 3`
echo $result
;;
Com_delete) #查看delete語句的執行數
result=`${MYSQL_Connect} extended-status | grep -w "Com_delete" | cut -d "|" -f 3`
echo $result
;;
Connections) #查看試圖鏈接到MySQL(無論是否鏈接成功)的鏈接數
result=`${MYSQL_Connect} extended-status | grep -w "Connections" | cut -d "|" -f 3`
echo $result
;;
Table_locks_immediate) #查看當即得到的表的鎖的次數
result=`${MYSQL_Connect} extended-status | grep -w "Table_locks_immediate" | cut -d "|" -f 3`
echo $result
;;
Table_locks_waited) #查看不能當即得到的表的鎖的次數。若是該值較高,而且有性能問題,你應首先優化查詢,而後拆分表或使用複製
result=`${MYSQL_Connect} extended-status | grep -w "Table_locks_waited" | cut -d "|" -f 3`
echo $result
;;
*)
echo "Usage:$0(Uptime|Com_update|Slow_queries|Com_select|Com_rollback|Questions|Com_insert|Com_delete|Com_commit|Bytes_sent|Bytes_received|Com_begin)"
;;
esac
4、測試數據
server端測試:
[root@host-39-108-217-12 ~]# /usr/local/zabbix/bin/zabbix_get -s 47.98.97.124 -p 10050 -k mysql.status[Connections]
11232
[root@host-39-108-217-12 ~]# /usr/local/zabbix/bin/zabbix_get -s 47.98.97.124 -p 10050 -k mysql.status[Uptime]
83228
agentd端測試:
[root@host-47-98-97-124 ~]# /usr/local/zabbix/sbin/zabbix_agentd -t mysql.status[Uptime] -c /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_mysql.conf
mysql.status[Uptime] [t|83321]
[root@host-47-98-97-124 ~]# /usr/local/zabbix/sbin/zabbix_agentd -t mysql.status[Connections] -c /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_mysql.conf
mysql.status[Connections] [t|11263]
5、登陸zabbix,添加mysql監控模板
固然,mysql監控模板的key只要那麼默認的幾個,要想監控到chk_mysql.sh腳本中的數據,就須要手動建立item啦,
固然,若是須要報警通知的話,就須要先手動建立trigger了,
固然,若是想圖形刷看到數據的話,就須要手動建立graph了。