当前位置:首页>编程日记>正文

Mysql 主从复制(AB复制)

本站寻求有缘人接手,详细了解请联系站长QQ1493399855

Mysql 主从复制(AB复制)

 

  Mysql的主从复制又叫做AB复制,主要作用就是将主服务器上的数据及时复制到从服务器上,来实现数据的同步,这样做的好处有,在进行数据备份时,可以减轻主服务器的运行压力,另外即使主服务器宕机了,也能从从服务器上取得主服务器的数据,从而保证数据不会丢失。这对于一个企业来说是至关重要的。一般在实际生产环境中,由单台mysql作为独立的数据库是完全不能满足实际需要的,无论在安全性,高可用性以及高并发等方面,一般是通过主从复制(Master-Slave)的方式来同步数据,再通过keepalived组件或者pacemaker来解决单点故障,实现高可用性,最后通过读写分离(Mysql-Proxy)来提升数据库的并发负载能力。

Mysql 主从复制(AB复制) 配图01

  

  今天我们就来实现主从复制,并且是采用两种版本的数据库,第一个主从复制实验采用的是mysql-5.1.71-1.el6 ,第二个主从复制实验采用的是mysql-5.7.11-1.el6版本。好了,话不多说,直接上步骤。

注意:一般作主从复制时一定要使得从机的mysql版本要和主服务器mysql版本一直,甚至高于主服务器才行。如果主服务器的mysql之前里面有数据因该进行数据备份,再将数据拷贝到从数据库中,保证数据库初态一致。

要求:新开两台虚拟机,一台主服务器,一台从服务器。均安装上数据库mysql

实验一:低版本的主从复制,直接通过yum源进行安装。

MASRER VM1        IP=172.25.45.15  hostname=mysql1

#yum  install  -y  mysql-server

#/etc/init.d/mysqld  start   #启动数据库

#mysql_secure_installation       #数据库安全初始化,设置密码等。

#mysql -pwestos         #登陆数据库

#vim   /etc/my.cnf     

7server-id=1     #数据库id号,为1时,表示为master,每个同步的服务器都必须设定一个唯一的编号,否则同步就不能正常运行。

          8log-bin=mysql-bin      #启用二进制日志

#/etc/init.d/mysqld    restart

#mysql -pwestos    :进入数据库,进行sql语句操作

>showmaster status;    

>grantreplication slave on *.* to min@'172.25.45.16' identified by 'westos';         #授权给从mysql数据库服务器172.25.45.16

Mysql 主从复制(AB复制) 配图02

此时需要在从数据库服务器上验证以下授权的用户及密码能否远程登陆到主服务器上。(#mysql -h 172.25.45.15  -umin  -pwestos

创建库和表,在备份机进行验证。

等操作。

 

SLAVE VM2   IP=172.25.45.16     hostname=mysql2

#yum install -y mysql-server

#vim /etc/my.cnf

7server-id=2     #添加数据库id号。

#/etc/init.d/mysqld   start

#mysql_secure_installation     #和上面类似,

#mysql -pwestos     #进入数据库,sql语句操作,配置SLAVE机:

>show  slave status;        #显示从数据库状态。

>change masterto master_host='172.25.10.30',master_user='liumin',master_password='westos',master_log_file='mysql-bin.000001',master_log_pos=106;       #执行同步SQL语句,启动slave同步进程

>start slave;          #启动slave

>show slavestatusG;    #显示从数据库状态,检查主从同步。

其中Slave_IO_running:yes Slave_SQL_Runningyes的值都必须为yes才表示状态正常。其中Slave_IO_running线程主要负责到Master上复制二进制日志文件的,而Slave_SQL_Running线程主要是将复制的文件在slave上执行一遍。

Mysql 主从复制(AB复制) 配图03

Mysql 主从复制(AB复制) 配图04

验证主从复制的效果:

MASTER上登陆数据库,创建数据库和表,并插入相关的值,再在SLAVE机上的数据库中进行验证。

MASTER 

#Mysql -pwestos

>create databasewestos;

>use westos;

>create  table  usertb (

          -> username  varchar(50)  not null,

        -> password  varchar(50)  not null);

>desc  usertb;

>insert  into  usertb value  ('user1','westos');

>select  *  fromusertb;

>delete  from  usertb where  username='user1';

>select  *  from  usertb;

SLAVE机:

#mysql -p

>showdatabases;

检测slave是否已经达到数据库的AB主从复制。

 

注:使用 mysqlbinlog 命令查看MASTER的二进制文件mysql-bin.000001 以及SLAVE的中继日志:mysqld-relay-bin.000001内容。

补充:ABC复制:A---> B ---> C

再开一台虚拟机CVM3

本次操作相当于把B机当作MASTERC机当作SLAVE,不过B机的配置文件要进行相应的修改。必须额外添加一行:log-slave-updates.

B机配置且进行授权:

#vim  /etc/my.cnf

server-id=2

Log-bin=mysql-bin

log-slave-updates

#/etc/init.d/mysqld restart

#mysql-pwestos

#grant replicationslave on *.* to minmin@'172.25.45.17' identified by 'westos';       #授权给从mysql数据库服务器172.25.45.17

C机:VM3  IP=172.25.45.17  Hostname=mysql3

#yum  install  -y  mysql-server

#vim   /etc/my.cnf

 server-id=4

#/etc/init.d/mysqld  start

#mysql_secure_installation 

#mysql -pwestos

>change master to    master_host='172.25.45.17',master_user='minmin', master_password='westos', mastr_log_file='mysql-bin.000001',master_log_pos=106;    #执行同步SQL语句,启动slave同步进程。

#start  slave

#show slave  statusG;  #查看slave状态。验证同上。

此时A创建的数据库及表都会同步到B并且也会同时同步到C上。这就是ABC主从复制。

实验二:使用高版本的数据库mysql-5.1.71-1.el6,作主从复制。

得先把之前的低版本mysql卸载干净。

#/etc/init.d/mysqld   stop

#cd   /var/log/mysql  ---> # rm   -fr  *

# cd /root   ---> #rm -fr   *

# rpm-qa | grep mysql      查询mysql软件,然后进行卸载。

#rpm -e`rpm -qa | grep mysql`  --nodeps

lftp -->  mysql-5.7.11-1.el6.x86_64.rpm-bundle.tar

   #获得mysql-5.1.71-1.el6软件,可以从官网下载。

#tar -xf  mysql-5.7.11-1.el6.x86_64.rpm-bundle.tar   :解压tar包。

#yum  install  -y  mysql-community-common-5.7.11-1.el6.x86_64.rpmmysql-community-libs-5.7.11-1.el6.x86_64.rpm mysql-community-client-5.7.11-1.el6.x86_64.rpm mysql-community-server-5.7.11-1.el6.x86_64.rpm

#安装这四个rpm包。

#scp mysql-community-common-5.7.11-1.el6.x86_64.rpmmysql-community-libs-5.7.11-1.el6.x86_64.rpmmysql-community-client-5.7.11-1.el6.x86_64.rpm mysql-community-server-5.7.11-1.el6.x86_64.rpm  root@172.25.45.16:

#MASTER上的rpm包传送到SLAVE机上。

B机上也要把mysql卸载干净。#rpm -qa | grep mysql

# rpm-qa | grep mysql

然后在进行安装nysql数据库。

MASTER VM1 IP=172.25.45.15    HOSTNAME=mysql1

#/etc/init.d/mysqld   start

#less   /var/log/mysqld.log        #查找原始密码;

#mysql_secure_installation-->输入原始密码,进行初始化并进行改密。

此密码要求8位以上,并且要求大小写字母以及包含特殊字符,和数字。

接下来做数据库的A --- B热备份,和上午的做法完全一致。但是下午采用的mysql-5.7的版本,所以可以采用多线程并行复制,同时采用GTID可以保证数据一致性。这是mysql5.7版本以后才具备的功能。GTID;主要用于保持数据的一致性。

#vim   /etc/my.cnf    #主备份机都要在最后添加这两行;

Server-id=1

log-bin=mysql-bin

gtid-mode=on

enforce-gtid-consistency=on

#/etc/init.d/mysqld   restart    #进行mysql服务重起,

#mysql  -p   #登陆mysql进行授权;

>grant replication slave on *.* tomin@'172.25.45.16' identified by 'westos';

> show master status;

SLAVE:   VM2  IP=172.25.45.16   hostname=mysql2

#vim   /etc/my.cnf

server-id=2

#/etc/init.d/mysqld   restart    #进行mysql服务重起

#mysql -p   

>stop  slave;          #首先停止slave

>change master to    master_host='172.25.10.30',master_user='minmin',master_password='HELLOmin+1234',master_auto_position=1;

#执行同步SQL语句,采用GTID方式实现多线程并行复制

>start slave;

>show slave statusG;     查看slave状态。

Mysql 主从复制(AB复制) 配图05

Mysql 主从复制(AB复制) 配图06

SLAVE上的mysql主配置文件中添加并行模式:数据备份延迟时间能减少到最小,因为是多线程进行操作,性能能够提升80%左右。

编辑备机mysql主配置文件,添加并行模块;

#vim  /etc/my.cnf

slave-parallel-type=LOGICAL_CLOCK

slave-parallel-workers=16    

master_info_repository=TABLE

relay_log_info_repository=TABLE   

#/etc/init.d/mysqld   restart;

#mysql -p

  >show processlist;   查看数据库线程数;

Mysql 主从复制(AB复制) 配图07

最后进行验证主从复制:再MASTER上进行数据库的创建以及相应的表的创建。这在前面都有所阐述,具体参看前面的内容。

测试使用程序add.sql进行,产生一千万条数据。然后在将数据进行备份,比较传统的mysqldumpmysqlpump备份速度的差异。

Maseter:

#mysql  -pHELLO+1234 westos  <  add.sql

> call test1; 正在产生一千万条数据。

同时也可以在备份机上查看主从备份数据的延时情况,比较单进程和多线程复制数据的速度。将刚才产生的一千万条数据使用以下三种方法进行备份,同时比较备份最短的时间。从中可以看出mysqldump的优势。

在主机master上:

# time  mysqldump -pHELLO+1234  westos  > westos.sql

#time  mysqlpump -pHELLO+1234  westos   > westos.sql

#time  mysqldumper -pHELLO+1234  westos  > westos.sql

Mysqldump,mysqlpump,mysqldumper比较这三者之间备份数据的速度.

 

Lock HA切换数据一致性)   半同步(给回执才给用户发session   数据库(延迟时间0 log-bin=mysql-bin

server-id=1  pos号数据一致性)   

原子操作:保证数据一直操作结束,不中断。



http://www.coolblog.cn/news/e0f2875a5a3199ac.html

相关文章:

  • asp多表查询并显示_SpringBoot系列(五):SpringBoot整合Mybatis实现多表关联查询
  • s7day2学习记录
  • 【求锤得锤的故事】Redis锁从面试连环炮聊到神仙打架。
  • 矿Spring入门Demo
  • 拼音怎么写_老师:不会写的字用圈代替,看到孩子试卷,网友:人才
  • Linux 实时流量监测(iptraf中文图解)
  • Win10 + Python + GPU版MXNet + VS2015 + RTools + R配置
  • 美颜
  • shell访问php文件夹,Shell获取某目录下所有文件夹的名称
  • 如何优雅的实现 Spring Boot 接口参数加密解密?
  • LeCun亲授的深度学习入门课:从飞行器的发明到卷积神经网络
  • Mac原生Terminal快速登录ssh
  • 法拉利虚拟学院2010 服务器,法拉利虚拟学院2010
  • 支撑微博千亿调用的轻量级RPC框架:Motan
  • mysql commit 机制_1024MySQL事物提交机制
  • java受保护的数据与_Javascript类定义语法,私有成员、受保护成员、静态成员等介绍...
  • 2019-9
  • jquery 使用小技巧
  • vscode pylint 错误_将实际未错误的py库添加到pylint白名单
  • 科学计算工具NumPy(3):ndarray的元素处理
  • 工程师在工作电脑存 64G 不雅文件,被公司开除后索赔 41 万,结果…
  • linux批量创建用户和密码
  • js常用阻止冒泡事件
  • 气泡图在开源监控工具中的应用效果
  • newinsets用法java_Java XYPlot.setInsets方法代碼示例
  • 各类型土地利用图例_划重点!国土空间总体规划——土地利用
  • php 启动服务器监听
  • dubbo简单示例
  • Ubuntu13.10:[3]如何开启SSH SERVER服务
  • [iptables]Redhat 7.2下使用iptables实现NAT
  • Django View(视图系统)
  • 【设计模式】 模式PK:策略模式VS状态模式
  • CSS小技巧——CSS滚动条美化
  • JS实现-页面数据无限加载
  • 最新DOS大全
  • 阿里巴巴分布式服务框架 Dubbo
  • 阿里大鱼.net core 发送短信
  • Sorenson Capital:值得投资的 5 种 AI 技术
  • 程序员入错行怎么办?
  • Arm芯片的新革命在缓缓上演
  • 两张超级大表join优化
  • 第九天函数
  • Linux软件安装-----apache安装
  • HDU 5988 最小费用流
  • 《看透springmvc源码分析与实践》读书笔记一
  • 通过Spark进行ALS离线和Stream实时推荐
  • nagios自写插件—check_file
  • python3 错误 Max retries exceeded with url 解决方法
  • 正式开课!如何学习相机模型与标定?(单目+双目+鱼眼+深度相机)
  • 行为模式之Template Method模式