MySQL 主从复制与读写分离

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL 主从复制与读写分离相关的知识,希望对你有一定的参考价值。

  • Mysql主从复制作用原理

1、在业务复杂的系统中,有这么一个情景,有一句sql语句需要锁表,导致暂时不能使用读的服务,那么就很影响运行中的业务,使用主从复制,让主库负责写,从库负责读,这样,即使主库出现了锁表的情景,通过读从库也可以保证业务的正常运作。
2、做数据的热备
3、架构的扩展。业务量越来越大,I/O访问频率过高,单机无法满足,此时做多库的存储,降低磁盘I/O访问的频率,提高单个机器的I/O性能。
mysql主从复制是一个异步的复制过程,主库发送更新事件到从库,从库读取更新记录,并执行更新记录,使得从库的内容与主库保持一致。

  • Msql读写分离

1:简单来说,读写分离就是只在主服务器上写,只在从服务器上读。因为Mysql在写入数据时会锁定表或者行,所有需要将读写分离开,实现写的同时也能读取数据。

2: Amoeba是一个以MySQL为底层数据存储,并对应用提供MySQL协议接口的proxy。它集中地响应应用的请求,依据用户事先设置的规则,将SQL请求发送到特定的数据库上执行。基于此可以实现负载均衡、读写分离、高可用性等需求。与MySQL官方的MySQL Proxy相比,作者强调的是amoeba配置的方便(基于XML的配置文件,用SQLJEP语法书写规则,比基于lua脚本的MySQL Proxy简单)。
3:Amoeba相当于一个SQL请求的路由器,目的是为负载均衡、读写分离、高可用性提供机制,而不是完全实现它们。用户需要结合使用MySQL的 Replication等机制来实现副本同步等功能。

  • 实验环境
主机 IP 主要软件
主服务器 192.168.126.129 mysql-5.7.17、 ntp 、boost_1_59_0.tar
从服务器1 192.168.126.130 mysql-5.7.17 、 ntp 、boost_1_59_0.tar
从服务器2 192.168.126.131 mysql-5.7.17 、 ntp 、boost_1_59_0.tar
Amoeba 192.168.126.132 amoeba-mysql-binary-2.2.0.tar、 jdk-6u14-linux-x64
客户端 192.168.126.133 mysql-5.7.17

技术分享图片

  • 搭建MySQL主从复制

Mysql主从复制详细配置:http://blog.51cto.com/13630803/2136766
在三台mysql上添加权限开放给amoeba访问:
mysql> grant all on . to [email protected]‘192.168.126.%‘ identified by ‘123.com‘;

  • 搭建MySQL读写分离

    # systemctl stop firewalld.service  //关闭防火墙
    # setenforce 0 
    # cp jdk-6u14-linux-x64.bin /usr/local/
    # cd /usr/local
    # ./jdk-6u14-linux-x64.bin    //按 “回车键” 输入“ yes“” 回车
    # mv jdk1.6.0_14/ /usr/local/jdk1.6

    .

    # vi /etc/profile      //添加环境变量  添加到末行
         export JAVA_HOME=/usr/local/jdk1.6
        export CLASSPATH=$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
        export PATH=$JAVA_HOME/lib:$JAVA_HOME/jre/bin/:$PATH:$HOME/bin
        export AMOEBA_HOME=/usr/local/amoeba
        export PATH=$PATH:$AMOEBA_HOME/bin
        # source /etc/profile   //刷新环境变量

.

        # mkdir /usr/local/amoeba
        # tar zxvf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba/
        # chmod -R 755 /usr/local/amoeba/
        #  /usr/local/amoeba/bin/amoeba
            (显示amoeba start|stop说明安装成功)
  • 配置amoeba服务

    # vim /usr/local/amoeba/conf/amoeba.xml
    --30行--
     <property name="user">amoeba</property>
     --32行-- 
     <property name="password">123456</property>
     --115行--
     <property name="defaultPool">master</property>
     --117-去掉注释-
     <property name="writePool">master</property>
     <property name="readPool">slaves</property>
    
    # vi conf/dbServers.xml
     -23行注释掉  作用:默认进入test库 以防mysql中没有test库时,会报错
     <!-- <property name="schema">test</property> -->
     --26--29--去掉注释--
     <property name="user">test</property>
     <property name="password">123.com</property>
     -----42-主服务器地址---
    <dbServer name="master"  parent="abstractServer">
    <property name="ipAddress">192.168.126.129</property>
    --52-从服务器主机名-
    <dbServer name="slave1"  parent="abstractServer">
    --55-从服务器1地址-
    <property name="ipAddress">192.168.126.130</property>
    --(这里上面6行复制)从服务器2地址
    <dbServer name="slave2"  parent="abstractServer">
    <property name="ipAddress">192.168.126.131</property>
    --64行--
    <dbServer name="slaves" virtual="true">
    --70行--
    <property name="poolNames">slave1,slave2</property>

    技术分享图片技术分享图片技术分享图片技术分享图片技术分享图片


  • 开启服务

    # /usr/local/amoeba/bin/amoeba start&
    # netstat -anpt | grep java   //查看端口
  • 测试读写分离
  • 客户机

    # systemctl stop firewalld.service  //关闭防火墙
    # setenforce 0
    # yum install -y mysql   //安装mysql客户端
    # mysql -u amoeba -p123456 -h 192.168.126.132 -P8066    //远程登录mysql
  • 主服务器

    # mysql -u root -p
    mysql> create database zhang;
    mysql> use zhang;
    mysql> create table zang (id int(10),name varchar(10),address varchar(20));
  • 两台从服务器

        mysql> stop slave;     //关闭同步
        mysql> use zhang;
        从服务器1
        mysql> insert into zang values(‘2‘,‘zhang‘,‘this_is_slave1‘);
        从服务器2
        mysq> insert into zang values(‘3‘,‘zhang‘,‘this_is_slave2‘);
  • 主服务器

    mysql> insert into zang values(‘1‘,‘zhang‘,‘this_is_master‘);
  • 客户机
  • 如图只能查看到 从服务器的数据

    mysql> use zhang;
    mysql> select * from zang;

技术分享图片

  • 客户机

    mysql> insert into zang values(‘5‘,‘zhang‘,‘write_test‘);

    技术分享图片
    技术分享图片

  • 两台从服务器

        mysql> start slave;      //开启同步

    技术分享图片

MySQL 主从复制与读写分离部署成功

以上是关于MySQL 主从复制与读写分离的主要内容,如果未能解决你的问题,请参考以下文章

MySQL主从复制与读写分离配置及实操

MySQL主从复制及读写分离实际部署与验证

MySQL主从复制及读写分离实际部署与验证

MySQL主从复制与读写分离

MySQL 主从复制与读写分离 部署

MySQL主从复制与读写分离