MySQL高可用主从复制新增slave
原文转自:https://www.cnblogs.com/itzgr/p/10233932.html
作者:木二
目录
- 一 基础环境
- 二 新增slave2方案
- 2.1 方案1:-复制主库
- 2.2 方案2:复制从库
- 2.3 方案对比
- 二 新增slave2
- 2.1 部署主从
- 2.2 slave-02安装MySQL
- 2.2 初始化MySQL
- 三 方案1形式
- 3.1 锁定主库
- 3.2 备份主库
- 3.3 解锁主库
- 3.4 传递备份文件至slave02
- 3.5 主库继续新建数据库
- 3.6 备库slave02开启主从复制
- 3.7 备库slave02恢复mysqltest
- 3.8 备库slave02开启主从复制
- 3.9 验证数据
- 四 方案2形式
- 4.1 停止slave01主从复制
- 4.2 备份slave01数据库
- 4.3 传递备份文件至slave02
- 4.4 主库继续新建数据库
- 4.5 备库slave02开启主从复制
- 4.6 备库slave02恢复mysqltest
- 4.7 备库slave02开启主从复制
- 4.9 验证数据
一 基础环境
主机名
|
系统版本
|
MySQL版本
|
主机IP
|
master
|
CentOS 6.8
|
MySQL 5.6
|
172.24.8.10
|
slave01
|
CentOS 6.8
|
MySQL 5.6
|
172.24.8.11
|
slave02
|
CentOS 6.8
|
MySQL 5.6
|
172.24.8.20
|
二 新增slave2方案
2.1 方案1:-复制主库
- 将内存中的数据同步到表中;
- 锁定表,不让出现新数据;
- 备份;
- 解锁;
- 将备份传送到slave02,在slave02上同步数据;
- slave2上设置相应的master_log_file和master-log_pos。
2.2 方案2:复制从库
- 停止从库slave01:mysql> stop slave;
- 看当前从库的状态,mysql> show slave status;记下 Relay_Master_Log_file 和 Exec_Master_Log_Pos;
- 备份从库数据
- 将备份传送到slave02,在slave2上同步数据;
- slave02上设置相应的master_log_file和master-log_pos。
2.3 方案对比
二 新增slave2
2.1 部署主从
2.2 slave-02安装MySQL

1 [root@Slave02 ~]# yum list installed | grep mysql #查看是否存在其他MySQL组件
2 [root@Slave02 ~]# yum -y remove mysql-libs.x86_64 #为避免冲突引发报错,卸载已存在的组件
3 [root@Slave02 ~]# wget http://mirrors.ustc.edu.cn/mysql-repo/mysql-community-release-el6-5.noarch.rpm
4 [root@Slave02 ~]# rpm -ivh mysql-community-release-el6-5.noarch.rpm
5 [root@Slave02 ~]# yum install mysql-community-server -y
6 [root@Slave02 ~]# chkconfig --list | grep mysqld #查看MySQL是否加入启动项
7 [root@Slave02 ~]# chkconfig mysqld on

2.2 初始化MySQL
1 [root@Master ~]# service mysqld start
2 [root@Master ~]# mysql_secure_installation
3 [root@Master ~]# service iptables stop
4 [root@Master ~]# chkconfig iptables off
三 方案1形式
3.1 锁定主库
1 [root@Master ~]# mysql -uroot -px120952576
2 mysql> flush tables with read lock; #锁定主库的表
3 mysql> show master status\G

3.2 备份主库
1 [root@Master ~]# mysqldump -R -u root -p mysqltest >/tmp/mysqltest.sql
2 Enter password:
3.3 解锁主库
1 [root@Master ~]# mysql -uroot -px120952576
2 mysql> unlock tables;
3.4 传递备份文件至slave02
1 [root@Master ~]# scp /tmp/mysqltest.sql root@172.24.8.20:/tmp
3.5 主库继续新建数据库

1 [root@Master ~]# mysql -uroot -p
2 Enter password:
3 mysql> create database mysqltest02;
4 mysql> use mysqltest02;
5 mysql> create table user02(id int(5),name char(10));
6 mysql> insert into user02 values (00002,'lisi');
7 mysql> grant replication slave on *.* to 'repl_user'@'172.24.8.%' identified by 'x12345678';

3.6 备库slave02开启主从复制

1 [root@Slave02 ~]# vi /etc/my.cnf
2 [mysqld]
3 server-id=3
4 log-bin=mysql-bin
5 relay_log=mysql-relay-bin
6 log_slave_updates=1
7 read_only=1
8 [root@Slave02 ~]# service mysqld restart

3.7 备库slave02恢复mysqltest

1 [root@Slave02 ~]# mysql -uroot -px120952576
2 mysql> create database mysqltest;
3 mysql> use mysqltest;
4 mysql> source /tmp/mysqltest.sql;
5 mysql> select * from mysqltest.user; #查看验证


3.8 备库slave02开启主从复制

1 [root@Slave02 ~]# mysql -uroot -px120952576
2 mysql> change master to master_host='172.24.8.10',
3 master_user='repl_user',
4 master_password='x12345678',
5 master_log_file='mysql-bin.000003',
6 master_log_pos=120;
7 mysql> start slave;


3.9 验证数据
1 [root@Slave ~]# mysql -uroot -px120952576
2 [root@Slave02 ~]# mysql -uroot -px120952576
3 mysql> select * from mysqltest02.user02;
4 #两台slave上均验证master第二次创建的测试库是否正常复制过来。

四 方案2形式
4.1 停止slave01主从复制
1 [root@Slave ~]# mysql -uroot -px120952576
2 mysql> stop slave;
3 mysql> show slave status\G
4.2 备份slave01数据库
1 [root@Slave01 ~]# mysqldump -R -u root -p mysqltest >/tmp/mysqltest.sql
2 Enter password:
4.3 传递备份文件至slave02
1 [root@Slave01 ~]# scp /tmp/mysqltest.sql root@172.24.8.20:/tmp
4.4 主库继续新建数据库

1 [root@Master ~]# mysql -uroot -p
2 Enter password:
3 mysql> create database mysqltest02;
4 mysql> use mysqltest02;
5 mysql> create table user02(id int(5),name char(10));
6 mysql> insert into user02 values (00002,'lisi');
7 mysql> grant replication slave on *.* to 'repl_user'@'172.24.8.%' identified by 'x12345678';

4.5 备库slave02开启主从复制
4.6 备库slave02恢复mysqltest
4.7 备库slave02开启主从复制

1 [root@Slave02 ~]# mysql -uroot -px120952576
2 mysql> change master to master_host='172.24.8.10',
3 master_user='repl_user',
4 master_password='x12345678',
5 master_log_file='mysql-bin.000003',
6 master_log_pos=932;
7 mysql> start slave;

4.9 验证数据
MySQL高可用主从复制新增slave的更多相关文章
- 003.MySQL高可用主从复制新增slave
一 基础环境 主机名 系统版本 MySQL版本 主机IP master CentOS 6.8 MySQL 5.6 172.24.8.10 slave01 CentOS 6.8 MySQL 5.6 17 ...
- 002.MySQL高可用主从复制部署
一 基础环境 主机名 系统版本 MySQL版本 主机IP master CentOS 6.8 MySQL 5.6 172.24.8.10 slave01 CentOS 6.8 MySQL 5.6 17 ...
- 001.MySQL高可用主从复制简介
一 简介 1.1 概述 Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布在多个系统之上,这种分布的机制,是通过将Mysql的某一台主机的数据复制到其它主机(slaves ...
- MySQL高可用主从复制部署
原文转自:https://www.cnblogs.com/itzgr/p/10233932.html作者:木二 目录 一 基础环境 二 实际部署 2.1 安装MySQL 2.2 初始化MySQL 2. ...
- MySQL高可用主从复制简介
原文转自:https://www.cnblogs.com/itzgr/p/10233932.html作者:木二 目录 一 简介 1.1 概述 二 技术原理 2.1 支持的复制类型 2.2 技术特点 2 ...
- MySQL高可用方案MHA的部署和原理
MHA(Master High Availability)是一套相对成熟的MySQL高可用方案,能做到在0~30s内自动完成数据库的故障切换操作,在master服务器不宕机的情况下,基本能保证数据的一 ...
- 33.MySQL高可用架构
33.高可用架构33.1 MMM架构MMM(Master-Master replication manager for MySQL)是一套支持双主故障切换和双主日常管理的脚本程序(Perl).主要用来 ...
- MySQL高可用架构之MHA
简介: MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司)开发,是 ...
- [转载] MySQL高可用方案选型参考
原文: http://imysql.com/2015/09/14/solutions-of-mysql-ha.shtml?hmsr=toutiao.io&utm_medium=toutiao. ...
随机推荐
- XIN队算法
XIN队算法 注:名称由莫队算法改编而来 从luogu搬过来了... \(newly\;upd:2021.7.8\) \(newly\;upd:2021.6.6\) OI至高算法,只要XIN队算法打满 ...
- 虚拟机安装的kali操作系统实现共享文件夹
虚拟机共享文件夹设置. 1.[虚拟机]-->[设置] 2.先在本地新建一个共享文件夹,然后将此文件夹的路径添加到虚拟机 3.进入kali操作系统,运行命令sudo vmhgfs-fuse .ho ...
- 基于arduino UNO R3+ESP8266控制LED灯的开关(无USB转TTL工具实现)
最近由于项目要求,需要开发物联网云平台,而本人对硬件和通信技术一窍不通,故而选择arduino这一简单单片机来实现学习掌握基础的硬件和通信技术. 下面就是本人通过查阅大佬资料做的一个整合版本的通过手机 ...
- djinn靶机
仅供个人娱乐 靶机信息 https://download.vulnhub.com/djinn/djinn.ova 一.主机探测 二.漏洞的查找和利用 21端口ftp 匿名登录 7331端口 命令执行 ...
- OpenFaaS实战之四:模板操作(template)
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- SQL Server CPU 利用率毛刺的分析定位与解决
一.背景 1.1 问题描述 近期发现一台SQL Server的CPU利用率很不稳定,发现不定时的飙升到100%,更可怕的是在业务繁忙时,影响了业务调用,失败率明显增加,所以,减低CPU的利用率,是迫切 ...
- CentOS 7 安装虚拟机
1.本次安装centos7 安装使用的软件是VitrualBox 虚拟机软件 Oracle公司的虚拟机软件,免费商品(大家可以百度搜索去官网下载) 1:我这里使用的是阿里的centos7的镜像(大家可 ...
- 自学linux——11.shell入门
shell 基础 1.shell介绍(内置脚本) 程序开发的效率非常高,依赖于功能强大的命令可以迅速地完成开发任务(批处理) 语法简单,代码写起来比较轻松,简单易学 (1)什么是shell shell ...
- 对象转换工具 MapStruct 介绍
前言 在我们日常开发的分层结构的应用程序中,为了各层之间互相解耦,一般都会定义不同的对象用来在不同层之间传递数据,因此,就有了各种 XXXDTO.XXXVO.XXXBO 等基于数据库对象派生出来的对象 ...
- 时间-i春秋
记一道跑脚本的题 进入页面拿到一段代码. <?php header("content-type:text/html;charset=utf-8"); '天下武功唯快不破'; ...