环境: 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信息
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;
mysql> start slave;
mysql> show slave status \G;