基于Docker的MySQL主从同步搭建

环境: Debian9.9, mysql5.7

docker安装如下

1.软件源更新到最新
    apt-get update
2.添加相关依赖
    apt-get install apt-transport-https ca-certificates curl software-properties-common gnupg2
3.存储密钥
    curl -fsSL https://download.docker.com/linux/debian/gpg | apt-key add -
4.添加软件源
    add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/debian $(lsb_release -cs) stable"
5.更新软件包
    apt-get update
6.安装docker
    apt-get install docker-ce

docker安装成功之后输入: docker version 命令查看是否成功
请添加图片描述
启动mysql主从服务

1.docker拉取MySQL5.7镜像
	docker pull mysql:5.7
2.启动MySQL主服务容器
	docker run -p 3339:3306 --name mysql-master -e MYSQL_ROOT_PASSWORD=123456 -d -v /etc/mysql-master/:/etc/mysql/ mysql:5.7
3.启动MySQL从服务容器
	docker run -p 3338:3306 --name mysql-slave -e MYSQL_ROOT_PASSWORD=123456 -d -v /etc/mysql-slave/:/etc/mysql/ mysql:5.7

	启动容器 -p 3339是宿主机上的端口, 映射到docker内部3306端口
	--name 是docker容器名称
	MYSQL_ROOT_PASSWORD: mysql密码
	-v  宿主机映射地址 : 容器内部地址
	mysql:5.7 镜像名称:版本号

通过docker images 和docker ps来查看镜像拉取和创建容器是否成功
在这里插入图片描述
mysql配置文件

1.创建MySQL配置文件
	touch /etc/mysql-master/my.cnf
	touch /etc/mysql-slave/my.cnf
2.为mysql-master添加配置
	vi /etc/mysql-master/my.cnf
	具体配置如下:
        [mysqld]
        user=mysql
        character-set-server=utf8
        default_authentication_plugin=mysql_native_password
        [client]
        default-character-set=utf8
        [mysql]
        default-character-set=utf8
        [mysqld]
        log-bin=mysql-bin
        server-id=100
3.为mysql-slave添加配置
	vi /etc/mysql-slave/my.cnf
	具体配置如下:
        [mysqld]
        # 设置server_id,注意要唯一
        server-id=101  
        # 开启二进制日志功能,以备Slave作为其它Slave的Master时使用
        log-bin=mysql-slave-bin   
        # relay_log配置中继日志
        relay_log=edu-mysql-relay-bin 
4.重启容器
	docker restart mysql-master mysql-slave

在Master数据库创建数据同步用户,授予用户 slave REPLICATION SLAVE权限和REPLICATION CLIENT权限,用于在主从库之间同步数据

docker exec -it mysql-master /bin/bash
mysql -uroot -p
输入密码
mysql> CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

查看mysql-master服务器上binlog的信息

docker exec -it mysql-master /bin/bash
mysql -uroot -p
输入密码
mysql> show master status;
记下File和Position信息

请添加图片描述
进入mysql-slave执行命令进行主从同步

docker exec -it mysql-slave /bin/bash
mysql -uroot -p
输入密码
mysql >
	执行以下命令:
		CHANGE MASTER TO
	    MASTER_HOST='192.168.1.161',
	    master_port=3339,
	    MASTER_USER='slave',
	    MASTER_PASSWORD='123456',
	    MASTER_LOG_FILE='mysql-bin.000001',
	    MASTER_LOG_POS=617;

		命令说明: 
			master_host: master的地址
			master_port: master的端口号, 这里指的是容器的端口号
			master_user: 用于数据同步的用户, 这里指的是之前我们新建的slave用户
			master_log_file: 指定slave从哪个日志文件开始复制数据, 即上文提到的file字段
			master_log_pos: 从哪个Position开始读, 即上文提到的Position字段的值
			master_connect_retry: 如果连接失败, 重试的时间间隔, 单位是秒, 默认是60

输入命令查看主从同步状态

mysql> show slave status \G;

请添加图片描述
这里是no, 正常, 执行以下命令开启slave主从同步

mysql> start slave;
mysql> show slave status \G;

请添加图片描述
测试, 使用Navicat测试
在这里插入图片描述
在这里插入图片描述
连接成功

主库新增即成功

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker MySQL主从是一种数据库复制技术,通过在Docker容器中创建MySQL实例来实现主从同步。这种技术可以使数据在主数据库上的变化自动同步到从数据库上,确保数据的一致性和高可用性。 在创建Docker MySQL主从时,首先需要关闭防火墙并重启Docker以确保后续安装的MySQL可以正常启动。接下来,需要在Docker中创建并启动MySQL主服务器,通过端口映射将宿主机的端口与Docker容器内的MySQL服务器端口绑定。同时,还需要指定MySQL的配置文件和数据存储路径,并设置MySQL的root密码。 创建主服务器的命令示例为: 引用: ```bash docker run -d \ -p 3306:3306 \ -v /hitd/mysql/master/conf:/etc/mysql/conf.d \ -v /hitd/mysql/master/data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=123456 \ --name hitd-mysql-master \ mysql:8.0.29 ``` 引用: ```bash docker run -p 3307:3306 --name mysql-master \ -v /mydata/mysql-master/log:/var/log/mysql \ -v /mydata/mysql-master/data:/var/lib/mysql \ -v /mydata/mysql-master/conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORD=root \ -d mysql:5.7 ``` 然后,需要创建MySQL主服务器的配置文件,并配置日志、数据和配置文件的路径。 最后,可以通过进入从数据库容器并使用MySQL客户端工具查看主从同步状态。 引用: ```bash docker exec -it mysql-slave /bin/bash mysql -uroot -proot ``` 通过以上步骤,你可以成功创建Docker MySQL主从环境。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Docker搭建MySQL主从同步(全网最全保姆教程)](https://blog.csdn.net/qq_49619863/article/details/128047193)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【Docker 基础教程】Mysql主从环境搭建](https://blog.csdn.net/apple_51931783/article/details/126350430)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值