1.前提准备
# 创建主从数据库文件夹
主库:172.11.32.*
mkdir -p /test/mysql/master1/conf
mkdir -p /test/mysql/master1/data
mkdir -p /test/mysql/slave1/conf
mkdir -p /test/mysql/slave1/data
# 初始化主数据库配置文件
cd /test/mysql/master1/conf
touch my.cnf
vi my.cnf
[mysqld]
datadir = /test/mysql/master1/data
character-set-server = utf8
lower-case-table-names = 1
# 主从复制-主机配置
# 主服务器唯一ID
server-id = 1
# 启用二进制日志
log-bin=mysql-bin
# 设置logbin格式
binlog_format = STATEMENT
# 初始化从数据库配置文件
cd /test/mysql/slave1/conf
touch my.cnf
vi my.cnf
# 粘贴以下内容
[mysqld]
datadir = /test/mysql/slave1/data
character-set-server = utf8
lower-case-table-names = 1
# 主从复制-从机配置
# 从服务器唯一ID
server-id = 2
# 启用中继日志
relay-log = mysql-relay
# 文件夹授权
chmod -R 777 /test/mysql
2.Docker部署Mysql8.0.20
# 拉取镜像
docker pull mysql:8.0.20
# 查看镜像
docker images
# 构建主数据库容器
docker run --name=mysql-master-1 --privileged=true -p 3306:3306 -v /test/mysql/master1/data/:/var/lib/mysql -v /test/mysql/master1/conf/my.cnf:/etc/mysql/my.cnf -v /test/mysql/master1/mysql-files/:/var/lib/mysql-files/ -e MYSQL_ROOT_PASSWORD=123456 -d mysql:8.0.20 --lower_case_table_names=1
# 查询是否启动成功
docker ps
# 验证是否可以登录
# 交互式进入容器
docker exec -it mysql-master-1 /bin/bash
# 登录(使用构建时指定的密码:123456)
mysql -uroot -p
# 退出
quit
exit
# 构建从数据库容器
docker run --name=mysql-slave-1 --privileged=true -p 3306:3306 -v /test/mysql/slave1/data/:/var/lib/mysql -v /test/mysql/slave1/conf/my.cnf:/etc/mysql/my.cnf -v /test/mysql/slave1/mysql-files/:/var/lib/mysql-files/ -e MYSQL_ROOT_PASSWORD=123456 -d mysql:8.0.20 --lower_case_table_names=1
# 查询是否启动成功
docker ps
# 验证是否可以登录
# 交互式进入容器
docker exec -it mysql-slave-1 /bin/bash
# 登录(使用构建时指定的密码:123456)
mysql -uroot -p
# 退出
quit
exit
# 关闭防火墙
# 查看防火墙状态
systemctl status firewalld
# 关闭防火墙
systemctl stop firewalld
4. 配置主从复制#
Copy
# 进入主数据库
mysql -uroot -p -h192.168.10.234 -P3306
- 主数据库创建用户slave并授权
# 创建用户
create user 'slave'@'%' identified with mysql_native_password by '123456';
# 授权
grant replication slave on *.* to 'slave'@'%';
# 刷新权限
flush privileges;
# 查询server_id值
show variables like 'server_id';
# 也可临时(重启后失效)指定server_id的值(主从数据库的server_id不能相同)
set global server_id = 1;
# 查询Master状态,并记录File和Position的值
show master status;
# 注意:执行完此步骤后退出主数据库,防止再次操作导致File和Position的值发生变化
+---------------+-----------+
| File | Position |
+---------------+-----------+
| binlog.000004 | 135858146 |
+---------------+-----------+
# 验证slave用户是否可用
mysql -uslave -p -h172.11.32.51 -P3306
# 进入从数据库
mysql -uroot -p -h172.11.32.51 -P3307
# 查询server_id值
show variables like 'server_id';
# 也可临时(重启后失效)指定server_id的值(主从数据库的server_id不能相同)
set global server_id = 2;
# 若之前设置过同步,请先重置
stop slave;
reset slave;
# 设置主数据库
change master to master_host='172.11.32.51',
master_port=3306,
master_user='slave',
master_password='123456',
master_log_file='mysql-bin.000004',
master_log_pos=135858146,
MASTER_CONNECT_RETRY=10;
# 开始同步
start slave;
# 若出现错误,则停止同步,重置后再次启动
stop slave;
reset slave all;
change master to ;
start slave;
# 查询Slave状态
show slave status\G
# 查看是否配置成功
# 查看参数 Slave_IO_Running 和 Slave_SQL_Running 是否都为yes,则证明配置成功。若为no,则需要查看对应的 Last_IO_Error 或 Last_SQL_Error 的异常值。
5. 测试#
通过工具连接主从数据库或者在服务器连接
3.测试主从同步数据
4.部署harbor私有仓库,将mysql保存进仓库
#1.下载harbor安装包
cd /opt
wget https://github.com/goharbor/harbor/releases/download/v2.3.0/harbor-offline-installer-v2.3.0.tgz
tar xf harbor-offline-installer-v2.3.0.tgz
#2.安装私有仓库
cd harbor/
cp harbor.yml.tmpl harbor.yml
vim harbor.yml
hostname: 172.11.32.xx
port: 80 #将443端口全部注销掉
harbor_admin_password: 123456
yum install -y docker-compose #安装docker-compose
./install.sh #初始化
#3.推送镜像到私有仓库
docker login 172.11.32.xx
docker tag mysql:8.0.20 172.11.32.xx/library/mysql:latest
docker push 172.11.32.xx/library/mysql:latest