IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> 基于docker容器的myql主从复制 -> 正文阅读

[系统运维]基于docker容器的myql主从复制

基于docker容器的myql主从复制
1.拉取mysql镜像
docker pull mysql:5.7

2.查看mysql镜像
docker images

3.根目录/data/mysql_3306下新建文件夹

cd /data/mysql_3306
mkdir cnf
mkdir data
mkdir logs

4.启动mysql容器实例,映射主机3306端口

docker run --name mysql_3306 -v /data/mysql_3306/logs:/logs -v /data/mysql_3306/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d -i -p 3306:3306 mysql:5.7

5.查看mysql实例状态
docker ps -a

6.将mysql容器/etc/mysql/my.cnf复制到指定目录

docker cp 容器id:/etc/mysql/my.cnf /data/mysql_3306/cnf/

在[mysqld]最后加入以下参数

#实例id,唯一
server-id=100
#binlog,名称随便起
log-bin=mysql-bin
max_connections=500
character-set-server=utf8

复制my.cnf到mysql容器中

docker cp /data/mysql_3306/cnf/my.cnf 容器id:/etc/mysql/

重启容器
docker restart 容器id

7.启动mysql容器实例,映射主机3307端口

docker run --name mysql_3307 -v /data/mysql_3307/logs:/logs -v /data/mysql_3307/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d -i -p 3307:3306 mysql:5.7

8.将mysql容器/etc/mysql/my.cnf复制到指定目录
在[mysqld]最后加入以下参数

#实例id,唯一
server-id=101
#binlog,名称随便起
log-bin=mysql-bin
max_connections=500
character-set-server=utf8

复制my.cnf到mysql容器中

docker cp /data/mysql_3307/cnf/my.cnf 容器id:/etc/mysql/

重启容器
docker restart 容器id
9.此时已经建好了主从两个mysql实例
切到主服务master,创建同步认证用户
CREATE USER ‘slave’@’%’ IDENTIFIED BY ‘123456’;
GRANT REPLICATION SLAVE, REPLICATION CLIENT ON . TO ‘slave’@’%’;
flush privileges;

10.切到从服务器slave0
查看主服务器master状态
show master status;

执行

change master to master_host='172.17.0.2', master_user='slave', master_password='123456', MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=1057;

master_host :Master库的地址,指的是容器的独立ip,可以通过 docker inspect --format=’{{.NetworkSettings.IPAddress}}’ 容器名称|容器id查询容器的ip 查询
master_port :Master的端口号,指的是容器的端口号(默认3306)
master_user :用于数据同步的用户
master_password :用于同步的用户的密码
master_log_file :指定 Slave 从哪个日志文件开始复制数据,即上文中提到的 File 字段的值
master_log_pos :从哪个 Position 开始读,即上文中提到的 Position 字段的值

启动从服务
start slave;

注意:如果mysql版本是8.0以上,新增用户验证方式发生改变,主节点中执行

ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-03-22 21:01:04  更:2022-03-22 21:05:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/16 0:00:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码