广告
返回顶部
首页 > 资讯 > 数据库 >MySQL主从复制的常见问题和有效解决方案
  • 463
分享到

MySQL主从复制的常见问题和有效解决方案

2024-04-02 19:04:59 463人浏览 薄情痞子
摘要

下面讲讲关于Mysql主从复制的常见问题和有效解决方案,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完mysql主从复制的常见问题和有效解决方案这篇文章你一定会有所受益。 一

下面讲讲关于Mysql主从复制的常见问题和有效解决方案,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完mysql主从复制的常见问题和有效解决方案这篇文章你一定会有所受益。

一、复制的问题和解决方案:

(1)数据损坏或丢失:

            某个slave上损坏:在slave上重放二进制日志,各种原因,导致数据不一致。例如硬件故障        

            //使用其他master上的备份的数据集,在新的slave上进行还原,从备份的位置开始从master上进行复制。

    重新复制即可//下线故障的slave,还原然后重新复制即可

    master数据损坏或丢失:

        //在各个slave上根据其gtid,找出最新的salve,然后提升为master

        //MHA+semi repl //MHA和一个node半同步复制,提升半同步node为新的master即可

//最后方案:

    二进制日志分析,然后还原

    单个故障了:活该!

(2)混合使用存储引擎;//坚决杜绝

    MyISAM不支持事务//不能回滚的

    InnoDB支持事务

(3)不唯一的server id 

    整个复制集群,可能导致错乱。

    //例如某个slave的server id和master的server id一样,那么他就不会重放master发来的server-id 

    修改server id 重新复制 

(4)复制延迟

    从node落后于master

    自己写脚本,不断监控,发现落后的时间不等于0,后,可以重启slave的io线程

    需要额外的监控工具来辅助实现。

    在master上事务是可以并发的,但是往同一个二进制日志写入是单线程的

    因此slave在本地应用也是单线程的

    master上有多个库,每一个库的事务是可以并行的,因为对A库的,对B库是没有影响的,但是反映到二进制日志中必然有先后的顺序

    因此slave落后是没有办法避免的,因此mysql 5.5之后引入了多线程机制。

    

    支持一从多主和多线程复制

    多线程复制//每一个数据库只启用一个线程

     //但是主库是不能一样的

    多线程复制:还是有用的,依赖于gtid 

        //MySQL 5.6.3之后,MariaDB10.0.5之后

    复制线程:Master上的IO线程和Slave上的IO、SQL线程,

数据库服务的衡量指标:

qps:query per second 

tps:事务per second 

数据库压力测试工具:

sysbench 

二、Galera Cluster:多用于MySQL的数据复制

Http://galeracluster.com/

更底层的复制机制

需要单独编译实现。

安装方式

msyql官方或者galera //官方提供的支持galera 的版本

percona-cluster //整合过mysql版本

mariadb-cluster //专用的复制

base和epel都没有提供galera-cluster的源

默认的mariadb版本是不支持galera的

需要用到的包:

MariaDB-5.5.46-Centos7-x86_64-client.rpm

MariaDB-5.5.46-centos7-x86_64-common.rpm

MariaDB-Galera-5.5.46-centos7-x86_64-common.rpm

//至少需要3个node


1.前提:hosts文件和时间同步

node1:192.168.1.67

node2:192.168.1.68

node3:192.168.1.69


node1: 

建议在本地配置yum源

yum remove mariadb //卸载client和server端

yum install MairaDB-Galera-server 

node2: 

建议在本地配置yum源

yum remove mariadb //卸载client和server端

yum install MairaDB-Galera-server 

node3: 

建议在本地配置yum源

yum remove mariadb //卸载client和server端

yum install MairaDB-Galera-server 


2.配置文件说明/etc/my.cnf.d/server.cnf 

...

[galera] 

# Manatory settings //强制配置

#wresp_provider = /usr/lib64/galera/libgalera_smm.so 

#wresp_cluster_address = "GComm://192.168.1.67, 192.168.1.68, 192.168.1.69"  

#wresp_cluster_name = "mycluster" 

#wresp_node_name = 'node1'

#wresp_node_address = '192.168.1.67' //这两个可以省略

#binlog_fORMat = row 

#default_storage_engine=InnoDB

#bind-address=0.0.0.0


# Optional setting 

#wsrep_slave_threads=1

#innodb_flush_logs_at_trx_commit=0 

...


首次启动:需要初始化集群,在其中一个node上执行如下命令

/etc/init.d/mysql start --wsreq-new-cluster 

而后正常启动其他节点即可

3.修改配置文件

node1: 

[galera] 

wresp_provider=/usr/lib64/galera/libgalera_smm.so 

wresp_cluster_address="gcomm://192.168.1.67, 192.168.1.68, 192.168.1.69"  

binlog_format=row 

default_storage_engine=InnoDB

innodb_autoinc_lock_mode=2 

bind-address=0.0.0.0

wresp_cluster_name="mycluster" 

node2: 和 node3: 配置文件相同 


node1:任意一个node都可以

/etc/rc.d/init.d/mysql start --wsrep-new-cluster

node2: 

service mysql start 

node3:

service mysql start 

3.测试 

mysql> 任何一个node创建数据

在其他node上可以看到有数据

node1:

> use mydb;

> create table tb2 (id int unsigned auto_increment not null primary key,name char(30));

> insert into tb2 (name) values ('hi'),('hello');

node2:

> select * from tb2; 

id | name 

---------

1 | h2 

4 | hello  

> insert into tb2 (name) values ('to'),('from');

> select * from tb2 

1 hi 

4 hello 

5 to 

8 from 

使用全局id生成器

r/w分离器:

要么自己写

要么使用开源的工具

或者在应用层配置实现 //一旦故障需要手动修改或者使用vrrp

亲测方法:

1.复制所有的rpm文件

2.createrepot /testrepo 

3.修改yum文件指向该yum源即可

4.使用yum进行安装即可


三、MySQL 5.6的多线程复制、GTID

注意:任何服务或者主机都应该被监控

mysql落后的原因:单线程复制,

5.5 半同步

5.6 GTID、多线程复制,

MariaDB在配置文件的mysqld选项组中添加:

slave-parallel-threads

MASTER: my.cnf添加以下参数 

binlog_format = row 

gtid_mode = ON 

enforce-gtid-consistency = ON 

slave_parallel_workers=4           --开启基于库的多线程复制默认0不开启 

binlog_cache_size = 8M 

max_binlog_size = 50M 

max_binlog_cache_size = 100M 

sync_binlog = 1 

expire_logs_days = 1 

log-slave-updates=true 

SLAVE: my.cnf添加以下参数  

binlog_format = row 

gtid_mode = ON 

enforce-gtid-consistency = ON 

binlog_cache_size = 8M 

max_binlog_size = 50M 

max_binlog_cache_size = 100M 

sync_binlog = 1 

expire_logs_days = 1 

slave_parallel_workers=4 

max_relay_log_size = 50M 

relay_log_purge = 1 

relay_log_recovery = 1  

master_verify_checksum = 1        --主事件校验 

slave_sql_verify_checksum = 1     --从事件校验 

slave_allow_batching = 1 

log-slave-updates=true 

对于以上MySQL主从复制的常见问题和有效解决方案相关内容,大家还有什么不明白的地方吗?或者想要了解更多相关,可以继续关注我们的数据库板块。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL主从复制的常见问题和有效解决方案

本文链接: https://www.lsjlt.com/news/35141.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL主从复制的常见问题和有效解决方案
    下面讲讲关于MySQL主从复制的常见问题和有效解决方案,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL主从复制的常见问题和有效解决方案这篇文章你一定会有所受益。 一...
    99+
    2022-10-18
  • mysql 主从复制存在问题及解决方法
    主从形式 mysql主从复制 灵活一主一从主主复制一主多从---扩展系统读取的性能,因为读是在从库读取的;多主一从---5.7开始支持联级复制---  用途及条件 m...
    99+
    2022-10-18
  • MySQL有何常见问题及对应的解决方案
    下文给大家带来关于MySQL有何常见问题及对应的解决方案,感兴趣的话就一起来看看这篇文章吧,相信看完MySQL有何常见问题及对应的解决方案对大家多少有点帮助吧。一、 忘记 MySQL 的 root 密码1....
    99+
    2022-10-18
  • 常见的MySQL锁问题及其解决方案
    MySQL 锁的常见问题与解决方案MySQL 是一种常用的关系型数据库管理系统,它使用锁来实现并发控制,保证数据的一致性和完整性。然而,MySQL 锁的使用也会带来一些问题。本文将介绍一些常见的 MySQL 锁的问题,并提供相应的解决方案。...
    99+
    2023-12-21
    解决方案 常见问题 MySQL
  • 解决MySQL主从复制不一致问题的主要几个方法
    下面讲讲关于解决MySQL主从复制不一致问题的主要几个方法,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完解决MySQL主从复制不一致问题的主要几个方法这篇文章你一定会有所受益。...
    99+
    2022-10-18
  • MySQL主从复制架构实践:主从不同步的解决方案
    前言 大家好,我是沐风晓月,本文收录于《MySQL入门到精通》专栏,希望对你有用; 之前在做MySQL主从架构的时候,遇到了形形色色的问题,比如: 主从配置好之后,双yes的情况下,居然不能同步;切换...
    99+
    2023-10-25
    架构 服务器 运维 云原生 linux
  • MySQL中事务处理的常见问题和解决方案
    MySQL中事务处理的常见问题和解决方案在数据库操作中,事务处理是非常重要的,它可以确保数据库操作的一致性和完整性。然而,在MySQL中进行事务处理时,常常会遇到一些问题。本文将介绍常见的MySQL事务处理问题,并提供相应的解决方案。问题一...
    99+
    2023-10-22
    解决方案 问题 事务处理
  • Redis主从复制问题和扩容问题的解决思路
    一、解决主从复制问题 当使用Redis作为存储引擎的时候,并且使用Redis读写分离,从机作为读的情况,从机宕机或者和主机断开连接都需要重新连接主机,重新连接主机都会触发全量的主从复制,这时候主机会生成内存...
    99+
    2022-06-04
    主从 思路 Redis
  • C++中常见的代码复用问题解决方案
    C++中常见的代码复用问题解决方案在C++编程中,代码复用是一种重要的技术,可以提高开发效率和代码的可维护性。然而,常常会遇到一些常见的代码复用问题,例如重复的代码片段、复杂的继承关系等。本文将介绍几种解决这些问题的常用方法,并提供具体的代...
    99+
    2023-10-22
    继承(Inheritance) 组合(Composition) 泛型编程(Generic programming)
  • 教你彻底解决MySQL 5.7 主从复制的延迟问题方法
    本文主要给大家简单讲讲彻底解决MySQL 5.7 主从复制的延迟问题方法,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望彻底解决MySQL 5.7 主从复制的...
    99+
    2022-10-18
  • 如何解决mysql主从复制中产生了锁的问题
    这篇文章给大家分享的是有关如何解决mysql主从复制中产生了锁的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一套主主复制的mysql库产生了死锁,导致主从同步出现问题, ...
    99+
    2022-10-18
  • mysql主从复制中出现的error和解决方法
    这篇文章主要介绍“mysql主从复制中出现的error和解决方法”,在日常操作中,相信很多人在mysql主从复制中出现的error和解决方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望...
    99+
    2022-10-18
  • 实例解读:MySQL并行复制如何解决特定的主从问题?
    并行复制存世已多年,但是在实际应用场景中的使用并不常见。这次很幸运,我们刚好遇到一个客户,主的写入工作量非常大,但是从难以跟上,在这种情况下,我建议它使用并行从属线程。 那么,如何衡量并行复制是否在客...
    99+
    2022-10-18
  • 日志重定向:Java和NPM中的常见问题和解决方案。
    日志重定向:Java和NPM中的常见问题和解决方案 日志记录是软件开发中非常重要的一部分,它可以帮助我们跟踪应用程序的运行状态,检测错误和性能问题。在Java和NPM中,日志记录是非常常见的。然而,在实际开发中,我们经常会遇到一些与日志记录...
    99+
    2023-06-04
    npm 日志 重定向
  • 云服务器常见故障有哪些类型的问题和解决方案
    常见的云服务器故障类型有以下几种: 网络故障:云服务器与互联网之间的网络连接可能会出现问题,如无法连接、无法访问互联网等。解决方法是检查云服务器的网络连接设置,如使用VPN等。 内存故障:云服务器需要使用大量内存资源来存储数据,如果内存...
    99+
    2023-10-27
    常见故障 解决方案 类型
  • PHP笔试中常见的问题和解决方法有哪些
    今天小编给大家分享一下PHP笔试中常见的问题和解决方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。语言基础在PHP的...
    99+
    2023-07-05
  • MySQL表结构设计:学校管理系统的常见问题与解决方案
    MySQL表结构设计:学校管理系统的常见问题与解决方案引言:学校管理系统在现代教育管理中扮演着重要的角色。为了能够高效地管理学校的各种信息和数据,一个良好设计的数据库表结构是至关重要的。然而,在设计学校管理系统的数据库时,常常会遇到一些问题...
    99+
    2023-10-31
    MySQL 学校管理系统 表结构设计
  • 云服务器常见故障有哪些类型的问题及解决方案
    无法启动:首先可以检查云服务器的电源是否打开,网线是否连接正常,如果有任何问题,则可以通过启动服务的方式来解决。 资源超载:如果云服务器资源过载,会导致无法正常启动,可以通过增加服务器的硬盘容量或删除一些资源来释放资源。 系统崩溃:云服务...
    99+
    2023-10-27
    常见故障 解决方案 类型
  • 挖掘MySQL主从复制的集群技术潜力:开源方案与商业解决方案比较评估
    挖掘MySQL主从复制的集群技术潜力:开源方案与商业解决方案比较评估随着互联网业务的不断发展和数据量的不断增加,对于数据库集群方案的需求也日益强大。MySQL主从复制技术正好满足了这一需求,它能够将数据库的读写操作在多个节点上进行分别处理,...
    99+
    2023-10-22
    集群技术 MySQL主从复制 开源方案 商业解决方案 比较评估
  • Web项目部署在Tomcat上的最佳实践和常见问题解决方案
    Tomcat部署Web项目的最佳实践和常见问题解决方法引言:Tomcat作为一个轻量级的Java应用服务器,在Web应用开发中得到了广泛应用。本文将介绍Tomcat部署Web项目的最佳实践和常见问题解决方法,并提供具体的代码示例,帮助读者更...
    99+
    2023-12-29
    tomcat 部署 Web项目
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作