基于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 命令查看是否成功
基于Docker的MySQL主从同步搭建_第1张图片
启动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信息

基于Docker的MySQL主从同步搭建_第2张图片
进入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;

基于Docker的MySQL主从同步搭建_第3张图片
这里是no, 正常, 执行以下命令开启slave主从同步

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

基于Docker的MySQL主从同步搭建_第4张图片
测试, 使用Navicat测试
基于Docker的MySQL主从同步搭建_第5张图片
基于Docker的MySQL主从同步搭建_第6张图片
基于Docker的MySQL主从同步搭建_第7张图片

基于Docker的MySQL主从同步搭建_第8张图片

你可能感兴趣的:(MySQL,docker,mysql,容器)