本文主要是介绍docker安装mysql和mysql的主从复制的搭建(采坑记录)可用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
为了在docker搭建mysql的主从复制,踩了很多坑,特此记录一下。
一、安装环境:
1.1.mac:MacBook Pro
1.2.docker安装的是Docker Desktop,附链接:https://www.docker.com/products/docker-desktop
1.3已经安装好了docker
二、安装mysql
1.docker安装mysql
docker pull mysql:latest
2.进入容器
docker exec -it a0f6a6b6b89d /bin/bash或者这样启动mysqldocker start mysql-master
3.登录mysql
mysql -h localhost -u root -p
4 设置用户权限
必须添加这个,否则Navicat链接不上去
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
三、mysql主从复制搭建
1.docker搭建mysql主从数据库
1.1 参考文章: Docker 安装MySQL 主从复制 、Redis 、nginx 、安装maven,和java 配置开发环境-云栖社区-阿里云
1.2 参考文章: 基于Docker的Mysql主从复制
2.主数据库的启动命令:
docker run -p 3341:3306 --name mysql-master -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest
编辑mysql文件
Master对外映射的端口是3341,Slave对外映射的端口是3342。因为docker容器是相互独立的,每个容器有其独立的ip,所以不同容器使用相同的端口并不会冲突。这里我们应该尽量使用mysql默认的3306端口,否则可能会出现无法通过ip连接docker容器内mysql的问题。
使用docker ps命令查看正在运行的容器:
3.从数据库的启动命令
docker run -p 3342:3306 --name mysql-s1 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest
4.主数据的配置
## 登录mysql$mysql -h localhost -u root -p## 设置用户权限必须添加这个,否则Navicat链接不上去ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';##安装vim:
$apt-get update然后再次执行,安装vim
$apt-get install vimcd /etc/mysql切换到/etc/mysql目录下vim my.cnf对my.cnf进行编辑
在my.cnf中添加如下配置:
[mysqld]
---## 同一局域网内注意要唯一server-id=1001
## 开启二进制日志功能,可以随便取(关键)log-bin=mysql-bin---重启mysql服务,使用命令: docker restart 容器名称或者id (1b4671904bfa)
$docker restart mysql-master## 查询ip$docker inspect --format='{{.NetworkSettings.IPAddress}}' mysql-master
172.17.0.2
##或者用,找到下面{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}里面的IPAddress$docker inspect mysql-master## 查询mysql的master的状态
mysql> show master status;mysql> show master status;---+---------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+---------------+----------+--------------+------------------+-------------------+
| binlog.000002 | 438 | | | |
+---------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)---##创建slave-role复制到用户名
mysql> CREATE USER 'slave-role'@'%' IDENTIFIED BY 'slave-role';### 在Master数据库创建数据同步用户,授予用户 slave REPLICATION SLAVE权限和REPLICATION CLIENT权限,用于在主从库之间同步数据。
mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave-role'@'%';##刷新权限
mysql> FLUSH PRIVILEGES;## 查看master的mysql现在有哪些用户
mysql>select user,host from mysql.user;
5.配置mysql从数据库
进入docker
登录mysql
$mysql -h localhost -u root -p
设置用户权限必须添加这个,否则Navicat链接不上去
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
安装vim:
$apt-get update
然后再次执行,安装vim
$apt-get install vim
切换到/etc/mysql目录下
$cd /etc/mysql
vim my.cnf对my.cnf进行编辑
在my.cnf中添加如下配置:
[mysqld]
server-id=101
## 开启二进制日志功能
log-bin=mysql-slave-bin
## relay_log配置中继日志
relay_log=edu-mysql-relay-bin
重启mysql服务,使用命令: docker restart 容器名称或者id
$docker restart mysql-s1
6.配置从服务器
在主服务器执行,找到如下数据:
查询mysql的master的状态
mysql> show master status;
查询ip
$docker inspect --format='{{.NetworkSettings.IPAddress}}' mysql-master
从mysql执行:
mysql>change master to master_host='172.17.0.2',master_user='slave-role',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=156,master_port=3306;
参数解释
master_host :Master的地址,指的是容器的独立ip,
master_port:Master的端口号,指的是容器的端口号
master_user:用于数据同步的用户
master_password:用于同步的用户的密码
masterlogfile:指定 Slave 从哪个日志文件开始复制数据
masterlogpos:从哪个 Position 开始读,
masterconnectretry:如果连接失败,重试的时间间隔,单位是秒,默认是60秒
显示主从同步的状态
$show slave status \G;
启动主从复制。
$ start slave ;
这篇关于docker安装mysql和mysql的主从复制的搭建(采坑记录)可用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!