1、創建文件夾
/tmp/mysql/mysql-master/log
/tmp/mysql/mysql-master/data
/tmp/mysql/mysql-master/conf
/tmp/mysql/mysql-master/mysql-files
/tmp/mysql/mysql-master/mysql-files mysql8.0 之后必須創建
2、新建master服務器容器
docker run -it --privileged=true -p 3307:3306 --name mysql-master \
-v /tmp/mysql/mysql-master/log:/var/log/mysql \
-v /tmp/mysql/mysql-master/data:/var/lib/mysql \
-v /tmp/mysql/mysql-master/conf:/etc/mysql \
-v /tmp/mysql/mysql-master/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:8.0.29
3、新建slave服務器容器
docker run -it --privileged=true -p 3308:3306 --name mysql-slave \
-v /tmp/mysql/mysql-slave/log:/var/log/mysql \
-v /tmp/mysql/mysql-slave/data:/var/lib/mysql \
-v /tmp/mysql/mysql-slave/conf:/etc/mysql \
-v /tmp/mysql/mysql-slave/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:8.0.29
4、配置master /tmp/mysql/mysql-master/conf/my.cnf
[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
5、創建數據同步賬戶
docker exec -it mysql-master /bin/bash
mysql -uroot -p
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';
// 備用
ALTER USER 'slave'@'%' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
FLUSH PRIVILEGES;
mysql> show master status \G;
*************************** 1. row ***************************
File: mall-mysql-bin.000003
Position: 390
Binlog_Do_DB:
Binlog_Ignore_DB: mysql
Executed_Gtid_Set:
1 row in set (0.00 sec)
ERROR:
No query specified
6、配置slave /tmp/mysql/mysql-slave/conf/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、配置從mysql
docker exec -it mysql-slave /bin/bash
mysql -uroot -proot
change master to master_host='10.0.115.140', master_user='slave', master_password='123456', master_port=3307, master_log_file='mall-mysql-bin.000001', master_log_pos=714, master_connect_retry=30;
mysql> show slave status \G;
*************************** 1. row ***************************
Slave_IO_State:
Master_Host: 10.0.115.140
Master_User: slave
Master_Port: 3307
Connect_Retry: 30
Master_Log_File: mall-mysql-bin.000001
Read_Master_Log_Pos: 714
Relay_Log_File: mall-mysql-relay-bin.000001
Relay_Log_Pos: 4
Relay_Master_Log_File: mall-mysql-bin.000001
Slave_IO_Running: No
Slave_SQL_Running: No
7、mysql遠程登錄
mysql> stop slave;
mysql> reset slave;
mysql> start slave;
mysql> show slave status \G;
mysql 主從
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
推薦閱讀更多精彩內容
- 面試題 你們有沒有做 MySQL 讀寫分離?如何實現 MySQL 的讀寫分離?MySQL 主從復制原理的是啥?如何...
- 面試官心理分析 高并發這個階段,肯定是需要做讀寫分離的,啥意思?因為實際上大部分的互聯網公司,一些網站,或者是 a...
- 面試題 你有沒有做 MySQL 讀寫分離?如何實現 MySQL 的讀寫分離?MySQL 主從復制原理的是啥?如何解...
- 主庫 地址:192.168.0.1 數據庫用戶:root 數據庫密碼 ******從庫 地址:192.1...
- 目錄 一、MySQL主從介紹二、準備工作三、配置主四、配置從五、測試主從同步 一、MySQL主從介紹 MySQL主...