Docker容器技术--安装MySQL主从复制

Docker容器技术–安装MySQL主从复制

概念及原理

什么是主从复制

主从复制(Master-Slave Replication)是MySQL数据库提供的一种数据同步技术,它允许数据从一个MySQL数据库服务器(主服务器或Master)复制到一个或多个MySQL数据库服务器(从服务器或Slave)。这种复制功能通常用于备份、故障恢复、读取扩展以及数据分析等场景。

  • 主服务器
    1. 负责处理写操作(INSERT、UPDATE、DELETE等)。
    2. 当数据发生变化时,会将这些变化记录到二进制日志(Binary Log)中。
  • 从服务器
    1. 负责处理读操作,可以分担主服务器的读取负载。
    2. 通过I/O线程从主服务器读取二进制日志中的事件,并将这些事件写入到从服务器的中继日志(Relay Log)中。
    3. 从服务器的SQL线程读取中继日志中的事件,并执行这些事件,从而更新从服务器的数据。

主从复制的工作流程

  1. 主服务器上的写操作被记录到二进制日志中。
  2. 从服务器的I/O线程连接到主服务器,读取二进制日志中的事件,并将这些事件写入到中继日志中。
  3. 从服务器的SQL线程读取中继日志中的事件,并执行这些事件,更新从服务器的数据。

主从复制的优点

  • 数据备份:从服务器可以作为主服务器的备份,防止数据丢失。
  • 故障恢复:如果主服务器出现故障,可以迅速将其中一个从服务器提升为主服务器,继续提供服务。
  • 读取扩展:通过将从服务器用于读取操作,可以分担主服务器的读取负载,提高系统的吞吐量和响应速度。
  • 数据分析:可以在从服务器上运行数据分析任务,而不会影响到主服务器的性能。

注意事项

  • 主从复制是异步的,从服务器的数据可能会稍微落后于主服务器。
  • 主从复制不是完全的高可用性解决方案,还需要其他技术(如负载均衡、故障切换等)来确保服务的连续性。
  • 在配置和使用主从复制时,需要注意网络延迟、数据一致性、复制延迟等问题。

安装操作

  • 新建主服务器实例
    暴露端口3307
    	docker run -p 3307:3306 --name=mysql-master \
    	-v /root/mysql-master/log:/var/log/mysql \
    	-v /root/mysql-master/data:/var/lib/mysql \
    	-v /root/mysql-master/conf:/etc/mysql \
    	-e MYSQL_ROOT_PASSWORD=root \
    	-d mysql:5.7
    
  • 进入 /root/mysql-master/conf 目录下新建配置文件 my.cnf
    	vim my.cnf
    
    	[mysqld]
    	##设置server_id,同一局域网中需要唯一
    	server_id=101
    	##指定不需要同步的数据库名称
    	binlog-ignore-db=mysql
    	##开启二进制日志功能
    	log-bin=mall-mysql-bin
    	##设置二进制日志使用内存大小(事务)
    	binlog_cache_size=1M
    	##设置使用的二进制日志格式(mixed,statement,row)
    	binlog_format=mixed
    	##二进制日志过期清理时间。默认值为0,表示不自动清理。
    	expire_logs_days=7
    	##跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
    	##如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
    	slave_skip_errors=1062
    
  • 重启并进入mysql-master实例
    	docker restart mysql-master
    	docker exec -it mysql-master /bin/bash
    
  • 进入mysql-master实例内数据库,创建数据同步用户
    	mysql -uroot -proot
    	create user ‘slave’@’%’ identified by ‘123456’;
    	grant replication slave,replication client on *.* to 'slave'@'%';
    
  • 新建从服务器实例
    暴露端口3308
    	docker run -p 3308:3306 --name=mysql-slave \
    	-v /root/mysql-slave/log:/var/log/mysql \
    	-v /root/mysql-slave/data:/var/lib/mysql \
    	-v /root/mysql-slave/conf:/etc/mysql \
    	-e MYSQL_ROOT_PASSWORD=root \
    	-d mysql:5.7
    
  • 进入 /root/mysql-slave/conf 目录下新建配置文件 my.cnf
    	vim my.cnf
    
    	[mysqld]
    	##设置server_id,同一局域网中需要唯一
    	server_id=102
    	##指定不需要同步的数据库名称
    	binlog-ignore-db=mysql
    	##开启二进制日志功能,以备slave作为其他数据库实例的master时使用
    	log-bin=mall-mysql-bin
    	##设置二进制日志使用内存大小(事务)
    	binlog_cache_size=1M
    	##设置使用的二进制日志格式(mixed,statement,row)
    	binlog_format=mixed
    	##二进制日志过期清理时间。默认值为0,表示不自动清理。
    	expire_logs_days=7
    	##跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
    	##如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
    	slave_skip_errors=1062
    	##relay_log配置中继日志
    	relay_log=mall-mysql-relay-bin
    	##log_slave_updates表示slave将复制事件写进自己的二进制日志
    	log_slave_updates=1
    	##slave设置为只读(具有super权限的用户除外)
    	read_only=1
    
  • 重启mysql-slave实例
    	docker restart mysql-slave
    
  • 在主数据库中查看主从同步状态
    	shou master status;
    
    主从同步状态
  • 进入mysql-slave实例数据库
    	docker exec -it mysql-slave /bin/bash
    	mysql -uroot -proot
    
    配置主从复制
    	change master to master_host='192.168.1.8', master_user='slave', master_password='123456',master_port=3307,master_log_file='mall-mysql-bin.000001', master_log_pos=617, master_connect_retry=30;
    
  • 在从数据库中开启主从复制
    	start slave;
    
  • 在从数据库中查看主从同步状态
    	show slave status\G;
    
  • 16
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值