docker高级(mysql主从复制)

数据库密码需要设置成自己的!!!

1、创建容器master13307

powershell 复制代码
#docker pull

docker run -p 13307:3306 --name mysql-master \
--privileged=true \
-v /mysql/mysql-master/log:/var/log/mysql \
-v /mysql/mysql-master/data:/var/lib/mysql \
-v /mysql/mysql-master/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=root  \
-d mysql:5.7

2、进入/mysql/mysql-master/conf目录下新建my.cnf

复制下面,保存

bash 复制代码
[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=101 
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql  
## 开启二进制日志功能
log-bin=mall-mysql-bin  
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M  
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed  
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7  
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062

3、修改完配置后重启master实例

bash 复制代码
docker restart mysql-master

4、进入mysql-master容器

bash 复制代码
docker exec -it mysql-master /bin/bash

mysql -uroot -proot

#master容器实例内创建数据同步用户,slave,123456从库链接主表的账户密码,可以设置你自己的
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';

GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

5、在主数据库中查看主从同步状态

bash 复制代码
show master status;

6、新建从服务器容器实例mysql-slave 13308

bash 复制代码
docker run -p 13308:3306 --name mysql-slave \
-v /mysql/mysql-slave/log:/var/log/mysql \
-v /mysql/mysql-slave/data:/var/lib/mysql \
-v /mysql/mysql-slave/conf:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=root  \
-d mysql:5.7
bash 复制代码
#进入/mysql/mysql-slave/conf目录下新建my.cnf
vim my.cnf

#复制如下
[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=102
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql  
## 开启二进制日志功能,以备Slave作为其它数据库实例的Master时使用
log-bin=mall-mysql-slave1-bin  
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M  
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed  
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7  
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062  
## relay_log配置中继日志
relay_log=mall-mysql-relay-bin  
## log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates=1  
## slave设置为只读(具有super权限的用户除外)
read_only=1

7、重启slave

bash 复制代码
docker restart mysql-slave

#在主数据库中查看主从同步状态
show master status;

#进入mysql-slave容器
docker exec -it mysql-slave /bin/bash

mysql -uroot -proot

8、在从数据库slave中配置主从复制

bash 复制代码
change master to master_host='宿主机ip', master_user='slave', master_password='123456', master_port=13307, master_log_file='mall-mysql-bin.000001', master_log_pos=617, master_connect_retry=30;

#参数说明
master_host:主数据库的IP地址;
master_port:主数据库的运行端口;
master_user:在主数据库创建的用于同步数据的用户账号;
master_password:在主数据库创建的用于同步数据的用户密码;
show master status; 查看主机状态(需登录主机数据库查看)
master_log_file:指定从数据库要复制数据的日志文件,通过查看主数据的状态,获取File参数;
master_log_pos:指定从数据库从哪个位置开始复制数据,通过查看主数据的状态,获取Position参数;
master_connect_retry:连接失败重试的时间间隔,单位为秒。

#在从数据库中查看主从同步状态
show slave status \G;

#在从数据库中开启主从同步,登陆slave后台
start slave;

在主库创建表,查看从库数据情况!!!

解决mysql中文乱码

vim my.conf

bash 复制代码
[client]
default_character_set=utf8
[mysqld]
collation_server = utf8_general_ci
character_set_server = utf8
 character_set_filesystem = utf8
相关推荐
知初~2 小时前
出行项目案例
hive·hadoop·redis·sql·mysql·spark·database
c无序3 小时前
Docker-技术架构演进之路
docker
子非衣4 小时前
MySQL修改JSON格式数据示例
android·mysql·json
钊兵5 小时前
数据库驱动免费下载(Oracle、Mysql、达梦、Postgresql)
数据库·mysql·postgresql·oracle·达梦·驱动
隔壁老王1567 小时前
mysql实时同步到es
数据库·mysql·elasticsearch
努力的小T7 小时前
使用 Docker 部署 Apache Spark 集群教程
linux·运维·服务器·docker·容器·spark·云计算
东风微鸣8 小时前
TTRSS 迁移实战
docker·云原生·kubernetes·可观察性
Hanson Huang9 小时前
【存储中间件API】MySQL、Redis、MongoDB、ES常见api操作及性能比较
redis·mysql·mongodb·es
LUCIAZZZ9 小时前
EasyExcel快速入门
java·数据库·后端·mysql·spring·spring cloud·easyexcel