docker安装mysql主从集群(一主一从)

1、安装docker

安装yum-utils:

yum install -y yum-utils device-mapper-persistent-data lvm2

为yum源添加docker仓库位置:

yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

安装docker:

yum install docker-ce

启动docker:

systemctl start docker

设置docker开机启动:

systemctl enable docker

2、MySql安装

下载MySQL5.7的docker镜像:

docker pull mysql:5.7

使用如下命令启动MySQL服务:

docker run -p 3306:3306 --name mysql \
-v /mydata/mysql/log:/var/log/mysql \
-v /mydata/mysql/data:/var/lib/mysql \
-v /mydata/mysql/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=123456  \
-d mysql:5.7

参数说明:
-p 3306:3306:将容器的3306端口映射到主机的3306端口
-v /mydata/mysql/conf:/etc/mysql:将配置文件夹挂在到主机
-v /mydata/mysql/log:/var/log/mysql:将日志文件夹挂载到主机
-v /mydata/mysql/data:/var/lib/mysql/:将数据文件夹挂载到主机
-e MYSQL_ROOT_PASSWORD=123456:初始化root用户的密码

进入运行MySQL的docker容器:

docker exec -it mysql /bin/bash

使用MySQL命令打开客户端:

mysql -uroot -proot --default-character-set=utf8

安装成功:
在这里插入图片描述

3、docker安装主从mysql架构

docker run --name mysql-master -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

docker run --name mysql-slave -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

Master对外映射的端口号是3307,Slave对外映射的端口号是3308。

查看docker容器
在这里插入图片描述
进入mysql-master容器:

docker exec -it mysql-master /bin/bash

修改/etc/mysql/my.cnf 配置文件:

vim /etc/mysql/my.cnf

vim命令没有找到 docker内部安装vim工具
在这里插入图片描述

输入下面两条命令安装 vim:

apt-get update
apt-get install vim

安装完成之后 修改my.cnf 配置文件:

vim /etc/mysql/my.cnf

[mysqld]
## 同一局域网内注意要唯一
server-id=100  
## 开启二进制日志功能,可以随便取(关键)
log-bin=master-bin
binlog-format=ROW     ## 二进制日志格式,有三种 row,statement,mixed

配置完重启MySQL,并重启容器:

service mysql restart

docker start mysql-master

创建数据库同步账户
进入mysql-master容器里面:

docker exec -it mysql-master /bin/bash

mysql -uroot -p123456

CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

在这里插入图片描述
此处,master配置完成。

Slave数据库器配置:
进入到slave容器:

docker exec -it mysql-slave /bin/bash

修改my.cnf配置文件,
并且要提前安装vim,命令是:

apt-get update
apt-get install vim

vim /etc/mysql/my.cnf

在my.cnf文件中添加:

[mysqld]
## 设置server_id,注意要唯一
server-id=101  
## 开启二进制日志功能,以备Slave作为其它SlaveMaster时使用
log-bin=mysql-slave-bin   
## relay_log配置中继日志
relay_log=mysql-relay-bin  
read_only=1  ## 设置为只读,该项如果不设置,表示slave可读可写

重启MySQL

service mysql restart

启动容器

docker start mysql-slave

开启Master-Slave主从复制:
首先打开两个终端分别进入master和slave容器 并进入MySQL
mysql-master操作:

docker exec -it mysql-master /bin/bash

mysql -uroot -p123456

show master status;

在这里插入图片描述
得到了binlog日志文件名后,开启slave数据库库服务器的同步设置:
登录slave,并将master_log_file=’’, master_log_pos= 改成自己在master机器上面查看的结果。

docker exec -it mysql-slave /bin/bash;

mysql -uroot -p123456;

stop slave;

change master to master_host='自己的IP地址', master_user='slave', master_password='123456', master_port=3307, master_log_file='master-bin.000001', master_log_pos=617;

start slave;

show slave status \G;

效果:
change master to master_host='1.117.23.7', master_user='slave', master_password='123456', master_port=3307, master_log_file='master-bin.000001', master_log_pos=617;
搭建成功!

4、测试效果:

在master数据库服务器新建一个数据库test1;
在这里插入图片描述
此时,刷新后,查看slave数据库服务器,发现新增一个数据库test1,说明,一主一从数据库集群搭建成功。
在这里插入图片描述

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值