mysql主从配置和从库zabbix监控

2024-01-29 01:18

本文主要是介绍mysql主从配置和从库zabbix监控,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Mysql的主从架构模式,是很多企业广泛使用,并且大家所广为熟知的一种架构模式

mysql主从复制主要用途

  • 实时灾备,用于故障切换
  • 读写分离,提供查询服务
  • 备份,避免影响业务

mysql主从复制存在的问题

  • 主库宕机后, 数据可能丢失
  • 主库写压力大, 复制可能会延时
主从复制原理

在这里插入图片描述
主从复制步骤:

  • 主库将所有的写操作记录到binlog日志中并生成一个log dump线程,将binlog日志传给从库的I/O线程

  • 从库生成两个线程,一个I/O线程,一个SQL线程

    • I/O线程去请求主库的binlog,并将得到的binlog日志写到relay log(中继日志) 文件中
    • SQL线程会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,达到最终数据一致的目的
主从复制配置

主从复制配置步骤:

确保从数据库与主数据库里的数据一样
在主数据库里创建一个同步账号授权给从数据库使用
配置主数据库(修改配置文件)
配置从数据库(修改配置文件)

需求:
搭建两台MySQL服务器,一台作为主服务器,一台作为从服务器,主服务器进行写操作,从服务器进行读操作

环境说明:

数据库角色IP应用与系统版本有无数据
主数据库192.168.230.16centos7/redhat7
mysql-5.7
有数据
从数据库192.168.230.15centos7/redhat7
mysql-5.7
无数据

这里mysql的安装都是源码编译的,详情见前面几篇博客

主库

[root@master ~]# mysql -uroot -p
mysql> create database cs;
mysql> use cs;
mysql> create table aa (id int,name varchar(30));
mysql> insert into aa values (1,'apple'),(2,'banana');
mysql> select * from aa;
+------+--------+
| id   | name   |
+------+--------+
|    1 | apple  |
|    2 | banana |
+------+--------+
做全备
[root@master ~]# mysqldump -uroot -p'cs123.com' --all-databases > $(date +%F-%H-%M)-all.sql
拷贝到从主机
[root@master ~]# scp 2019-02-27-14-36-all.sql 192.168.230.15:/root/

从库

[root@slave ~]# mysql -uroot -p'cs123.com' < 2019-02-27-14-36-all.sql 
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| cs                 |
| mysql              |
| performance_schema |
| sys                |
| zabbix             |
+--------------------+
mysql> use cs;
mysql> show tables;
+--------------+
| Tables_in_cs |
+--------------+
| aa           |
+--------------+
mysql> select * from aa;
+------+--------+
| id   | name   |
+------+--------+
|    1 | apple  |
|    2 | banana |
+------+--------+

主库

mysql> grant replication slave on *.* to 'rep'@'192.168.230.15' identified by 'rep123.com';
mysql> flush privileges;

从库

[root@slave ~]# mysql -urep -p'rep123.com' -h 192.168.230.16
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
+--------------------+

主库

[root@master ~]# vim /etc/my.cnf
log-bin=mysql-bin
server-id=1
[root@master ~]# service mysqld restartmysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 |   804259 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+

从库

[root@slave ~]# vim /etc/my.cnf
log-bin=mysql-bin
server-id=2
[root@slave ~]# service mysqld restart
mysql> change master to master_host='192.168.230.16',master_user='rep',master_password='rep123.com',master_log_file='mysql-bin.000001',master_log_pos=804259;
mysql> start slave;
mysql> show slave status \G
*************************** 1. row ***************************Slave_IO_State: Waiting for master to send eventMaster_Host: 192.168.230.16Master_User: repMaster_Port: 3306Connect_Retry: 60Master_Log_File: mysql-bin.000001Read_Master_Log_Pos: 841636Relay_Log_File: slave-relay-bin.000002Relay_Log_Pos: 37697Relay_Master_Log_File: mysql-bin.000001Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 0Last_Error: Skip_Counter: 0Exec_Master_Log_Pos: 841636Relay_Log_Space: 37904Until_Condition: NoneUntil_Log_File: Until_Log_Pos: 0Master_SSL_Allowed: NoMaster_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: NoLast_IO_Errno: 0Last_IO_Error: Last_SQL_Errno: 0Last_SQL_Error: Replicate_Ignore_Server_Ids: Master_Server_Id: 1Master_UUID: b27045f6-36bb-11e9-b404-000c29c87115Master_Info_File: /opt/data/master.infoSQL_Delay: 0SQL_Remaining_Delay: NULLSlave_SQL_Running_State: Slave has read all relay log; waiting for more updatesMaster_Retry_Count: 86400Master_Bind: Last_IO_Error_Timestamp: Last_SQL_Error_Timestamp: Master_SSL_Crl: Master_SSL_Crlpath: Retrieved_Gtid_Set: Executed_Gtid_Set: Auto_Position: 0Replicate_Rewrite_DB: Channel_Name: Master_TLS_Version: 

看到这个就说明成功了

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

测试

主库插入数据
mysql> use cs;
mysql> show tables;
+--------------+
| Tables_in_cs |
+--------------+
| aa           |
+--------------+
mysql> insert into aa values (3,'cici'),(4,'dog');
mysql> select * from aa;
+------+--------+
| id   | name   |
+------+--------+
|    1 | apple  |
|    2 | banana |
|    3 | cici   |
|    4 | dog    |
+------+--------+从库查看
mysql> use cs;
mysql> select * from aa;
+------+--------+
| id   | name   |
+------+--------+
|    1 | apple  |
|    2 | banana |
|    3 | cici   |
|    4 | dog    |
+------+--------+
从库zabbix监控

先在zabbix客户端添加监控脚本和修改配置

[root@slave scripts]# vim Slave_IO_Running.sh
#!/bin/bash
Slave_IO_Running=$(mysql -uroot -pcs123.com -e "show slave status \G" 2> /dev/null |grep "Slave_IO_Running:" |awk -F: '{pri    nt $2}')
if [ $Slave_IO_Running == Yes ];thenecho 0
elseecho 1
fi[root@slave scripts]# vim Slave_SQL_Running.sh
#!/bin/bash
Slave_SQL_Running=$(mysql -uroot -pcs123.com -e "show slave status \G" 2> /dev/null |grep "Slave_SQL_Running:" |awk -F: '{p    rint $2}')
if [ $Slave_SQL_Running == Yes ];thenecho 0
elseecho 1
fi[root@slave scripts]# vim Read_Exec.sh
#!/bin/bash
Read_Master_Log_Pos=$(mysql -uroot -pcs123.com -e "show slave status \G" 2> /dev/null | grep "Read_Master_Log_Pos:" |awk -F: '{print $2}')
Exec_Master_Log_Pos=$(mysql -uroot -pcs123.com -e "show slave status \G" 2> /dev/null | grep "Exec_Master_Log_Pos:" |awk -F: '{print $2}')
a=$[$Read_Master_Log_Pos - $Exec_Master_Log_Pos]
if [ $a -eq 0 ];thenecho "0"
elseecho "$a"
fi[root@slave ~]# chmod -R 755 /scripts/
[root@slave ~]# chown -R zabbix.zabbix /scripts/[root@slave ~]# vim /usr/local/etc/zabbix_agentd.conf
UserParameter=check_mysql_io,/scripts/Slave_IO_Running.sh
UserParameter=check_mysql_sql,/scripts/Slave_SQL_Running.sh
UserParameter=check_mysql_wait,/scripts/Read_Exec.sh[root@slave scripts]# pkill zabbix
[root@slave scripts]# zabbix_agentd 

然后就是配置zabbix的web界面,添加监控项和触发器
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

添加完了触发器后再添加告警媒介,因为之前已经添加过了,这里就不添加直接用了,怎么添加见上个博客

然后去客户端停掉slave角色,等待报警结果

mysql> stop slave;

过一会就告警了,邮件也发过来了
在这里插入图片描述

另外两个照着上面做就行了~~

这篇关于mysql主从配置和从库zabbix监控的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/655353

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间