Mysql主从复制,读写分离(mysql-proxy)

下面介绍MySQL主从复制,读写分离,双主结构完整构建过程,不涉及过多理论,只有实验和配置的过程。 
Mysql主从复制(转载请注明出处,博文地址:) 
原理是master将改变记录到二进制日志(binary log),slave将master的binary log拷贝到中继日志(relay log),slave通过中继日志同步master的操作。 
1,实验环境,实验有2台Ubutu server 14都安装了mysql服务器,在相同的IP段 
172.16.34.212(主), 
172.16.34.156(从).

2,将这两台IP授权,允许其它IP通过账号密码进行访问(如添加个euht账号允许所有外部IP以密码123456访问),分别登录进两台机子的mysql执行如下语句 
Grant all privileges on . to ‘euht’@’%’ identified by ‘123456’ with grant option; 
Flush privileges; 

注: 
①上述代码的意思是创建一个euht用户,host=%,允许所有IP通过用户名euht进行访问。添加完刷新权限。 
②此时两台机子的mysql应该是可以相互访问的,如果不可以,导致的原因有很多,最常见的是防火墙没关,mysql服务器绑定了本地地址。通过如下方法一般可解决问题 
关闭防火墙,或开放3306端口 
 
更改my.cnf文件,把bind-address注释掉 
vi /etc/mysql/my.cnf 
 
3,找到主服务器172.16.34.212MySQL安装文件夹修改my.cnf(etc/mysql/my.cnf)文件,在[mysqld]下面增加下面几行代码 
server-id=1 
log-bin=master-bin 
log-bin-index=master-bin.index 
保存后重启mysql(service mysql restart;) 
注:如果只需要同步特定的库,如上添加代码,binlog-do-db =euht ,用于master-slave的具体数据库 
4,进入mysql后,查看主服务器mysql master状态,日志File为master-bin.000001,Position为107(记下这两个值,后面进行从服务器操作的时候需要用到) 
 
5,配置从服务器(172.16.34.156) 
同样配置从服务器允许外部IP访问(参考第2点)

配置日志文件

找到从服务器172.16.34.156MySQL安装文件夹修改my.cnf(etc/mysql/my.cnf)文件,在[mysqld]下面增加下面几行代码(server-id跟主服务器不要相同了) 
server-id=10 
log-bin=master-bin 
log-bin-index=master-bin.index

6,连接到主服务器(连接上156的mysql执行以下语句,更改相应的内容) 
change master to 
master_host=’172.16.34.212’, 
master_user=’euht’, 
master_password=’123456’, 
master_log_file=’master-bin.000001’, 
master_log_pos=107;

7,启动slave 
mysql> start slave;

8,查看slave状态 
mysql> show slave status\G 
其中Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。 
 
以上已经可以实现172.16.34.162主服务器的库的所有变化同步到从服务器172.16.34.156

测试如下: 
1,如图两台服务器都没自定义数据库 

2,创建一个数据库到主库(172.16.34.212),然后刷新从库观察情况(172.16.34.156) 

观察得出212的所有操作都同步到从156从库了。至此主从复制完成。 
注意以下几点: 
1,做主从复制时,首先确定两台服务器的mysql没任何自定义库(否则只可以配置完后之前的东西没法同步,或者两个库都有完全相同的库应该也是可以同步)
2,server_id必须配置不一样 
3,防火墙不能把mysql服务端口给拦截了(默认3306) 
4,确保两台mysql可以相互访问(即需要第二步操作) 
5,重置master,slave。Reset master;reset slave;开启关闭slave,start slave;stop slave; 
Mysql读写分离

以上工作做完后可以开始搭建读写分离,读写分离目前主要的几种方式: 
1,MySQL Proxy(中间件) 
2,Amoeba for MySQL(中间件) 
3,Mycat(中间件) 
4,应用层实现 
下面介绍用MySQL Proxy实现读写分离。Mysql Proxy一般安装到单独的一台服务器来进行读写调度,以下添加一台IP来安装mysql-proxy调度器,IP为172.16.34.236 
1,首先安装mysql-proxy 
apt-get install mysql-proxy

2,实现读写分离是有lua脚本实现的,现在mysql-proxy里面已经集成,无需再安装。 
3,配置连接数达到多少才读写分离,此处改为1,1个连接就开始读写分离 
vim /usr/share/mysql-proxy/rw-splitting.lua

4,启动mysql-proxy,主库用于写172.16.34.212,从库用于读172.16.34.156 
sudo mysql-proxy –proxy-read-only-backend-addresses=172.16.34.156:3306 –proxy-backend-addresses=172.16.34.212:3306 –proxy-lua-script=/usr/share/mysql-proxy/rw-splitting.lua –admin-username=euht 
–admin-password=123456 
–admin-lua-script=/usr/share/mysql-proxy/admin.lua 
5,启动后默认占用端口4040和4041。4040用于SQL转发,4041用于管理mysql-proxy。(netstat -tupln|grep mysql-proxy) 

6,测试读写分离 
用主库172.16.34.212的用户euht在这台mysql-proxy服务器登录进去(也可以单独为这个代理创建一个用户) 
现在从这台代理登录进主mysql服务器插入一条数据到testtb,结果为主从两台服务器都有数据了。 

为了测试读写是否真的分离了,我们把这两台服服务器的数据差异化

先登录mysql-proxy代理(-P指定端口号,必须指定否则登录进去的将是本地3306端口的那个,当然由于这台219服务器我没配置让外部机子可以访问,所以执行下面的语句缺少端口号直接报错。) 
mysql -ueuht -p -h172.16.34.219 -P4040 
登录进去我们为了看到读写分离是否生效,先到从服务器156把slave给停掉。(stop slave;)然后在代理服务器219的mysql-proxy执行插入数据。先看原本的数据情况 

插入数据和查看数据 

发现插入数据成功,再select出来居然没有刚才插入的数据。这时我们分别到两台服务器去查看数据。 
172.16..34.156从服务器的数据还是原来的 
 
再看212的数据 

看到这里就看到效果了。主服务器已经有了刚才插入的数据,从服务器没有。这是因为从服务器的主从复制已经关闭,所以从mysql-proxy代理端插入数据(实际上是用了主服务器212去插入)没有复制到从服务器。从mysql-proxy读取没看到新插入的数据是因为代理端是去从服务器156读取数据的。 
至此,mysql的主从复制和读写分离就结束了。下面简单说一下双主结构。

Mysql双主结构

通过上面的介绍很容易看出,双主结构其实就是两台服务器相互数据复制。那么做到双主结构只需要把212主服务器变成156的从服务器即可。

在212服务器上执行(先到156查看日志位置,改对相应的东西即可show master status;) 
change master to 
master_host=’172.16.34.212’, 
master_user=’euht’, 
master_password=’123456’, 
master_log_file=’master-bin.000001’, 
master_log_pos=294;

开启主从 
mysql> start slave;

156,212都start slave,而且配置互为slave,这就是双主结构。

测试,212插入数据156会同步,156插入数据212会同步。经测试全部通过。(记得查看运行状态,Slave_IO_Running 与 Slave_SQL_Running 的值都必须为YES,才表明状态正常。Show slave status\G)

Mysql主从复制,读写分离(mysql-proxy)的更多相关文章

  1. mysql主从复制-读写分离

    mysql主从复制+读写分离 环境:mysql主:193.168.1.1mysql从:193.168.1.2amoeba代理:193.168.1.3########################## ...

  2. MySQL 主从复制&读写分离 简介

    1. 读写分离&读写分离 简介 主从同步延迟 分配机制 解决单点故障 总结 2. 主从复制&读写分离 搭建 搭建主从复制(双主) 搭建读写分离 1. 读写分离&读写分离 简介 ...

  3. mysql主从复制-读写分离-原理

    Mysql主从复制和读写分离 在实际的生产环境中,如果对mysql数据库的读和写都在一台数据库服务器中操作,无论是在安全性.高可用性,还是高并发等各个方面都是不能满足实际需求的.因此,一般通过主从复制 ...

  4. Mycat+MySql 主从复制-读写分离 看这一篇就够了

    ​ 通过mycat和mysql的主从复制配合搭建数据库的读写分离,可以实现mysql的高可用性,下面我们来搭建mysql的读写分离. 1.一主一从 1.在node01上修改/etc/my.cnf的文件 ...

  5. MySQL主从复制&读写分离&分库分表

    MySQL主从复制 MySQL的主从复制只能保证主机对外提供服务,从机是不提供服务的,只是在后台为主机进行备份数据 首先我们说说主从复制的原理,这个是必须要理解的玩意儿: 理解: MySQL之间的数据 ...

  6. mysql主从复制+读写分离 菜鸟入门

    MYsql主从复制 1.mysql主从复制原理: Master将数据变化记录到二进制日志中[binary log] Slave将master的二进制日志[binary log]拷贝到自己的中继日志[r ...

  7. MYSQL 主从复制,读写分离(8)

    Mysql 数据库的主从复制方案,是其自带的功能,并且主从复制并不是复制磁盘上的数据文件,而是通过binlog日志复制到需要同步的服务器上. 一 主从复制的原理实现 原理图解说: 数据库更改 生成数据 ...

  8. Mycat实现mysql主从复制(读写分离)

    数据库性能瓶颈主要原因: 随着用户数的增多,带来的是数据库连接的大幅度增长 随着业务体量的增长,表数据量(空间存储的问题)的大幅增长,其中涉及到索引的优化,mysql默认的索引是硬盘级别的,BTREE ...

  9. Mysql主从复制读写分离

    一.前言:为什么MySQL要做主从复制(读写分离)?通俗来讲,如果对数据库的读和写都在同一个数据库服务器中操作,业务系统性能会降低.为了提升业务系统性能,优化用户体验,可以通过做主从复制(读写分离)来 ...

  10. MySQL主从复制读写分离如何提高从库性能-实战

    在做主从读写分离时候,需要注意主从的一些不同参数设置,来提高从库的性能,提高应用读取数据的速度,这样做很有必要的. 做读写分离复制主从参数不同设置如下(需要根据自己应用实际情况来设置): parmet ...

随机推荐

  1. [Preact] Use State and Props in the Component Render Function

    Preact offers, in addition to the regular component API from React, the ability to access both props ...

  2. 中小研发团队架构实践之RabbitMQ快速入门及应用

    原文:中小研发团队架构实践之RabbitMQ快速入门及应用 使用过分布式中间件的人都知道,程序员使用起来并不复杂,常用的客户端API就那么几个,比我们日常编写程序时用到的API要少得多.但是分布式中间 ...

  3. Python 标准库和第三方库的安装位置、Python 第三方库安装的各种问题及解决

    首先使用 sys 下的 path 变量查看所有的 python 路径: import sys sys.path 标准库 lib 目录下(home 目录/pythonXX.XX/lib) 第三方库 在 ...

  4. [TypeScript] Simplify asynchronous callback functions using async/await

    Learn how to write a promise based delay function and then use it in async await to see how much it ...

  5. React Native 开发环境安装和配置使用报错: -bash: react-native: command not found

    [React  Native 开发环境安装和配置:-bash: react-native: command not found 报错: 前提是安装homebrew,node.js ,npm ,watc ...

  6. 移动端UI界面设计:APP字体排版设计的七个原则

    移动端UI界面设计:APP字体排版设计的七个原则 发布于: 2015 年 2 月 9 日 by admin 再来谈移动端APP字体排版设计,也许有人会说,这个还有什么好说的呢?但是真正能够运用好APP ...

  7. js把其他类型转化成字符串

    js把其他类型转化成字符串 一.总结 一句话总结:类型转换中的强制类型转换分为类型转换函数和类型名强制.js后一种和其它语言不同,是类型类的构造方法.String() 二.js把其他类型转化成字符串 ...

  8. Linux非图形界面安装程序

    安装Linux程序的时候一般不会调取图形界面,这样输错内容,返回上一步时需要使用命令 previous ,相应的exit 与 next..在中文操作的时候,不会提示,所以要记住 在安装过程中,我们可能 ...

  9. iOS 9和xcode7设置

    升级了Xcode7各种问题来了,折腾两天 一.Xcode7  http适配设置 1.大部分社交平台接口不支持https协议. 2.大部分社交平台SDK不支持bitcode. 3.添加Scheme白名单 ...

  10. NOIP模拟 Game - 简单博弈,dp

    题意: 有n个带权球,A和B两个人,A先手拿球,一开始可以拿1个或2个,如果前一个人拿了k个,那么当前的这个人只能那k或k+1个,如果当前剩余的球不足,那么剩下的球都作废,游戏结束.假设两个人都是聪明 ...