003.MySQL高可用主从复制新增slave
一 基础环境
主机名
|
系统版本
|
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 验证数据
003.MySQL高可用主从复制新增slave的更多相关文章
- MySQL高可用主从复制新增slave
原文转自:https://www.cnblogs.com/itzgr/p/10233932.html作者:木二 目录 一 基础环境 二 新增slave2方案 2.1 方案1:-复制主库 2.2 方案2 ...
- 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. ...
随机推荐
- 【mongo】可以用localhost启动,无法用ip启动问题的解决
问题: mongo安装在a.b.c.d机器上,启动mongo服务后, mongo localhost:27017可以进入数据库, mongo 127.0.0.1:27017也可以进入数据库 mongo ...
- 伪Ap接入点
1.创建一个伪造的Ap接入点,必须购买一个无线网卡的设备,接受功率在300Mbps ,低于这个传输速率的值,效果很差,都达到用户可以连接验证的效果.其芯片必须支持kali linux 内核系统. 2. ...
- Nginx详解二十五:Nginx架构篇之Nginx常见的问题
Nginx常见的问题 1.相同server_name多个虚拟主机优先级访问,是按读取文件的优先级来排序 在/opt/app/下准备3个code文件夹,下面放入3个html文件,里面的内容分别是code ...
- 如何在地址栏(title标签里)和收藏夹里 加上网站的标志ICO、LOGO图片
第一步:首先你必须要制作一个看起来既清楚又容易辨识的.ico格式的小图片. 我们将图标的大小定义为16x16 像素.此外在制作图形文件的时候,你可能需要把色盘设定成只使用标准的 16 色 Window ...
- js 压缩上传的图片方法(默认上传的是file文件)
//压缩图片方法 function compressImg(file,callback){ var src; var fileSize = parseFloat(parseInt(file['size ...
- 2017-2018-2 20165206 实验三 《敏捷开发与XP实践》实验报告
2017-2018-2 20165206 实验三 <敏捷开发与XP实践>实验报告 一.实验报告封面 课程:Java程序设计 班级:1652班 姓名:韩啸 学号:20165206 指导教师: ...
- 我的第一个Java程序和Java简介
public calss HelloWorld{ public static void main(String[] args){ System.out.println("Hello Worl ...
- 八卦一下Starlark语言
八卦一下Starlark语言 编译移植TensorFlow时用到Bazel这一构建工具,Bazel用Starlark语法来编写WORKSPACE/BUILD文件,它们是类似于Make中的makeifl ...
- 使用python调用wps v9转换office文件到pdf
#!/usr/bin/python2.6 # -*- coding: utf-8 -*- # pip install timeout-decorator import os import win32c ...
- 【Socket】Java Socket编程基础及深入讲解
Socket是Java网络编程的基础,了解还是有好处的, 这篇文章主要讲解Socket的基础编程.Socket用在哪呢,主要用在进程间,网络间通信.本篇比较长,特别做了个目录: 一.Socket通信基 ...