1. 环境的准备
1.1 MySQL多实例创建
yum -y install mariadb-server
设置三个 MySQL配置文件
mkdir /data/{3307,3308} -p
chown -R mysql.mysql /data/*
vim /etc/my3307.cnf
[mysqld]
datadir=/data/3307/
socket=/data/3307/mysql.sock
port=3307
user=mysql
symbolic-links=0
[mysqld_safe]
log-error=/data/3308/mysqld.log
pid-file=/data/3307/mysqld.pid
vim /etc/my3308.cnf
[mysqld]
datadir=/data/3308/
socket=/data/3308/mysql.sock
port=3307
user=mysql
symbolic-links=0
[mysqld_safe]
log-error=/data/3308/mysqld.log
pid-file=/data/3308/mysqld.pid
初始化
mysql_install_db --user=mysql --defaults-file=/etc/my3307.cnf
mysql_install_db --user=mysql --defaults-file=/etc/my3308.cnf
启动多实例
mysqld_safe --defaults-file=/etc/my3307.cnf
mysqld_safe --defaults-file=/etc/my3308.cnf
登录进去
mysql -S /data/3307/mysql.sock
grant all on *.* to root@localhost identified by '123456';
flush privileges;
exit
mysql -S /data/3308/mysql.sock
grant all on *.* to root@localhost identified by '123456';
flush privileges;
exit
改完就可以登录了
mysql -uroot -p123456 -P 3307
mysql -uroot -p123456 -P 3308
查看进程,检查端口
[root@web03 data]
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 30396/mysqld
tcp 0 0 0.0.0.0:3307 0.0.0.0:* LISTEN 31682/mysqld
tcp 0 0 0.0.0.0:3308 0.0.0.0:* LISTEN 32737/mysqld
1.2 创建自动发现文件
vim /etc/zabbix/zabbix_agentd.d/mysql_discovery.conf
cat /etc/zabbix/zabbix_agentd.d/mysql_discovery.conf
UserParameter=mysql.discovery,/bin/bash /server/scripts/mysql_discovery.sh
mkdir -p /server/scripts
vim /server/scripts/mysql_discovery.sh
res=$(netstat -lntp|awk -F "[ :\t]+" '/mysqld/{print$5}')
port=($res)
printf '{'
printf '"data":['
for key in ${!port[@]}
do
if [[ "${#port[@]}" -gt 1 && "${key}" -ne "$((${#port[@]}-1))" ]];then
printf '{'
printf "\"{#MYSQLPORT}\":\"${port[${key}]}\"},"
else [[ "${key}" -eq "((${#port[@]}-1))" ]]
printf '{'
printf "\"{#MYSQLPORT}\":\"${port[${key}]}\"}"
fi
done
printf ']'
printf '}\n'
测试:
[root@web03 scripts]
{"data":[{"{#MYSQLPORT}":"3306"},{"{#MYSQLPORT}":"3307"},{"{#MYSQLPORT}":"3308"}]}
重启
systemctl restart zabbix-agent.service
zabbix_get测试取key
zabbix_get -s 172.16.1.9 -k mysql.discovery
(Not all processes could be identified, non-owned process info
will not be shown, you would have to be root to see it all.)
{"data":[]}
这时我们发现取不出来并提示了个错误 原因是zabbix用户不能使用netstat的-p参数 解决方法为给netstat命令添加s权限
在web03上边
which netstat
/usr/bin/netstat
chmod u+s /usr/bin/netstat
[root@zabbix ~]
{"data":[{"{#MYSQLPORT}":"3306"},{"{#MYSQLPORT}":"3307"},{"{#MYSQLPORT}":"3308"}]}
1.3 web页面操作
data:image/s3,"s3://crabby-images/c41bb/c41bb0187e8af4b811e9792f13956a933712e165" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/1d8e8/1d8e8a080165f1764c43230235dc914fc71369ec" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/41050/410508f8eed7dbfea9824b65b5e948bb8b509dc4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/5b0db/5b0db878ce00673b9e6601cdb09927944ff6c0e5" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/49aa8/49aa82e17c69bf5d70ea0dec4de09a45d2c9443e" alt="在这里插入图片描述" 这个是脚本里边的参数
{#MYSQLPORT}
@mysql.discovery
表达式创建 data:image/s3,"s3://crabby-images/4f72d/4f72d8f7b10ebaa62335cc664385f16188256e44" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e0970/e09703e06116aeeb41042925de0e1c0d7c3c1e8e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/43e6d/43e6dffdcbfe72ef8bb60552d920a738ced1e24b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/bb4f0/bb4f06974d4032e7b301b49460f9e783d24b5b62" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/0cb21/0cb21e3e0ab8330d75cff17a64e2ea825b64770a" alt="在这里插入图片描述"
1.4 模仿zabbix自带的mysql监控配置修改监控项
cat /etc/zabbix/zabbix_agentd.d/userparameter_mysql.conf
修改一下
UserParameter=mysql.status[*],echo "show global status where Variable_name='$1';" | HOME=/var/lib/zabbix mysql -uroot -p123456 -P $2 -N | awk '{print $$2}'
systemctl restart zabbix-agent.service
访问监控项
zabbix_get -s 172.16.1.9 -k mysql.status[Uptime,3307]
zabbix_get -s 172.16.1.9 -k mysql.status[Uptime,3308]
data:image/s3,"s3://crabby-images/84115/84115de0304b35c25f96ceaad81ea9af62aab494" alt="在这里插入图片描述"
1.5 web页面添加监控项原型
data:image/s3,"s3://crabby-images/b0d56/b0d56b2b7444d8cff63b954ae1f314eb000d6f54" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/cd6f9/cd6f929317c692f742ea424a556aa899be0a9c86" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c888a/c888a6371d0413ab332b6ae40a0c0a5824bd4e88" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e2a29/e2a291d579732749965d8b832930e2b06c3f8834" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e5d4e/e5d4e14ffa7fb8340bd547d91d8ad0f17a5c6828" alt="在这里插入图片描述"
1.6 web页面设置主机关联模版
data:image/s3,"s3://crabby-images/edd35/edd3517afb432e8a8d203e40d46534fa1f8b3413" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c9254/c92549463cd1fcb4371e17860396da9662048753" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/78c53/78c53982636a9c843176495c651b35897b17ceaa" alt="在这里插入图片描述"
|