网站建设合同概念,深圳商业网站建设哪家,网站新闻对百度优化有用吗,wordpress评论显示分页目录 前言 一、MySQL Replication概述 二、MySQL复制类型 三、部署MySQL主从异步复制 总结 前言
为了实现MySQL的读写分离#xff0c;可以使用MySQL官方提供的工具和技术#xff0c;如MySQL Replication#xff08;复制#xff09;、MySQL Group Replication#xff08;组… 目录 前言 一、MySQL Replication概述 二、MySQL复制类型 三、部署MySQL主从异步复制 总结 前言
为了实现MySQL的读写分离可以使用MySQL官方提供的工具和技术如MySQL Replication复制、MySQL Group Replication组复制等或者使用第三方的中间件工具如MySQL Proxy、MyCat等。这些工具和技术提供了一种方便和可靠的方式来实现读写分离架构。 一、MySQL Replication概述
MySQL Replication俗称MySQL AB复制、主从复制、主从同步是MySQL官方推荐的数据同步技术。数据同步基本过程为从数据库会实时去读取主数据库的二进制日志文件按照日志中记录对从库进行同样的操作以达到数据同步效果。
MySQL Replication优点
通过增加从服务器来提高数据库平台的可靠性。在主服务器上执行写入和更新在从服务器上向外提供读功能可以动态地调整从服务器地数量从而调整数据库平台地高性能。提高数据安全性因为数据已复制到从服务器主数据库异常时可以将从服务器复制进程终止来达到保护数据完整性地特点。在主服务器上生成实时数据而在从服务器上分析这些数据从而缓解主服务器地性能压力。
二、MySQL复制类型
异步复制Asynchronous repication
MySQL默认地复制是异步地主库在执行完客户端提交地事务后会立刻将结果返回给客户端并不关心从库是否已经接受并处理了事务这样就会有一个问题主库如果down掉了此时主上已经提交地事务可能没有传到从库服务器上如果此时强制将从提升为主可能会导致新主上的数据不完整。默认情况下MySQL5.5/5.6/5.7和mariaDB10.0/10.1的复制功能是异步的。
全同步复制Fully synchronous replication
指当主库执行完一个事务所有的从库都执行了该事务才返回给客户端。因为需要等待所有从库执行完该事务才能返回所以全同步复制的性能必然会收到严重的影响返回客户端的响应速度也会被拖慢。
半同步复制Semisynchronous replication
MySQL由Google贡献的补丁才开始支持半同步复制模式介于异步复制和全同步复制之间主库在执行完客户端提交的事务后不是立刻返回给客户端而是等待至少一个从库接受到并写到relay log中才返回给客户端。相对于异步复制半同步复制提高了数据的安全性同时它也造成了一定程度的延迟这个延迟最少是一个TCP/IP往返的时间。所以半同步复制最好在低延时的网络中使用。当出现超时情况时源主服务器会暂时切换到异步复制模式直到至少有一台设置为半同步复制模式的从服务器及时收到信息为止。
半同步复制模式在主服务器和从服务器同时启用否则主服务器默认使用异步复制模式
三、部署MySQL主从异步复制
1在主服务器的配置文件中添加内容并重启 2在主服务器中创建Replication用户
grant replication slave on*.* to hy192.168.73.% identified by123456; 3获得Master DB的相关信息show master status; 4在主服务器上创建个简单的表格并备份 5将备份的数据传输到从服务器上并导入
导入 6从库连接主库进行测试如果连接成功说明主库配置成功
mysql -uhy -p123456 /root/databases.sql 修改从的配置文件 修改完后重启数据库 7在Slave服务器授权启动从库进行主从库数据同步 这些参数是可以在主服务器中用show master status查看的
参数说明
CHANGE MASTER TO
MASTER_HOSTmaster_host_name, #主服务器的IP地址
MASTER_USERreplication_user_name, #主服务器授权的用户
MASTER_PASSWORDreplication_password, #主服务器授权的密码
MASTER_LOG_FILErecorded_log_file_name, #主服务器二进制日志的文件名
MASTER_LOG_POSrecorded_log_position; #日志文件的开始位置
8查看从状态show slave status如图所示这样说明配置成功 之后我们以相同的方式配置另一台从
9验证主从服务器
在主服务器的表格中插入内容后去从查看 从服务器查看 在从写入内容 在主查看发现看不到 总结
在本操作中可能会遇到Slave_IO_Running: NO Slave_SQL_Running: NO的问题
可能得原因是Slave_IO_Running: NO1.在操作过程中配置文件出现错误 解决方法使用 find / -iname auto.cnf 命令查找你数据库的auto.cnf 配置文件并删除随后重启mysql在mysql中stop slave再start slave可以解决
2. Slave_SQL_Running: NO可能是日志回滚出现问题出或者是在设置从时pos点不对可尝试
mysql stop slave ;
mysql set GLOBAL SQL_SLAVE_SKIP_COUNTER1;
mysql start slave ;
来解决。