MySQL数据库之读写分离

一、概述:

MySQL数据库主从结构配置以后,正常情况下数据库的所有读写操作全部都在主数据库上面,从数据库仅仅作为数据备份使用,显然无法有效的使用服务器资源,那么实现读写分离的需求就不可避免。

二、拓扑图说明:

如上图所示,本文要实现的是读MySQL数据库的写入操作(增删改)等在Master服务器(192.168.4.10)上面实现,而对MySQL数据库的读取操作(查询)等在Slave服务器(192.168.4.20)上面完成。

如果在程序员编程时创建两个数据库连接Connection,在程序中对数据库的读取操作使用一个数据库Connection,而对数据库的写入操作使用另外一个数据库Connection,也可以实现对数据库的读写分离。但是显然这种实现方式不够灵活,因此一般不使用这种方式。

本文中将使用MaxScale软件来实现MySQL数据库的读写分离。MaxScale是由http://www.skysql.com/开发的一款MySQL数据库中间件,支持高可用,负载均衡,具有良好的可扩展性,高性能的基于事件驱动的同时具有代理和管理功能的中间件。该软件将部署在拓扑图中的MySQL代理服务器(192.168.4.100)上,客户机的访问请求指向MySQL代理服务器,该服务器将把对数据库的写入操作指向到192.168.4.10,对数据库的读取操作指向到192.168.4.20。

三、配置说明:

1、MaxScale配置

(1)修改配置文件:

[[email protected] ~]# vim /etc/maxscale.cnf

A、指定数据库服务器
             [server1]
                type=server
                address=192.168.4.10       
                port=3306
                protocol=MySQLBackend
 
             [server2]
                type=server
                address=192.168.4.20
                port=3306
                protocol=MySQLBackend

B、指定要监控的数据库服务器
             [MySQL Monitor]
               type=monitor
               module=mysqlmon
               servers=server1,server2
               user=scalemon                #代理服务器监控服务连接数据库服务器的用户名(需要在数据库服务器上面授权)
               passwd=123456                #代理服务器监控服务连接数据库服务器的密码

monitor_interval=10000        //活跃检查时间间隔,10000毫秒=10秒
          C、指定读写分离在哪些主机之间执行
             [Read-Write Service]
                 type=service
                 router=readwritesplit
                 servers=server1,server2
                 user=maxscale               #用于检查用户连接数据库时用的授权用户是否合法的用户名(需要对mysql数据库有select权限)
                 passwd=123456               #用于检查用户连接数据库时用的授权用户是否合法的用户名

max_slave_connections=100%
          D、定义管理服务和方式(不用改)
             [MaxAdmin Service]
                 type=service
                 router=cli
          E、只读服务器配置选项(不用,全部注释掉)
             [Read-Only Service]
                 #type=service
                 #router=readconnroute
                 #servers=server1
                 #user=myuser
                 #passwd=mypwd
                 #router_options=slave

#[Read-Only Listener]
                 #type=listener
                 #service=Read-Only Service
                 #protocol=MySQLClient
                 #port=4008
          F、读写分离的监听端口配置
             [Read-Write Listener]
                 type=listener
                 service=Read-Write Service
                 protocol=MySQLClient
                 port=4006                    //客户端读写分离服务访问端口
         G、管理服务的监听端口配置
            [MaxAdmin Listener]
                 type=listener
                 service=MaxAdmin Service
                 protocol=maxscaled
                 socket=default
                 port=4009                    //管理服务使用的端口

2、在主数据库服务器添加授权

mysql > grant replication slave,replication client on *.* to [email protected]"%" identified by "123456";
   mysql > grant select on mysql.* to [email protected]"%" identified by "123456";

3、在代理服务器上面启动服务并检查数据库服务器状态

(1)启动服务:

[[email protected] ~]# maxscale --config=/etc/maxscale.cnf

(2)检查状态

[[email protected] ~]# maxadmin -uadmin -pmariadb -P4009
            MaxScale> list servers
            -------------------+-----------------+-------+-------------+--------------------
            Server             | Address         | Port  | Connections | Status              
            -------------------+-----------------+-------+-------------+--------------------
            server1            | 192.168.4.11    |  3306 |           0 | Master, Running
            server2            | 192.168.4.12    |  3306 |           0 | Slave, Running
            -------------------+-----------------+-------+-------------+--------------------

4、验证测试

在192.168.4.120上使用授权用户连接代理服务器(192.168.4.100:4006),在从数据库服务器(192.168.4.20)上面Insert一些数据,在客户端可以读到,那么说明客户端读数据时是在从数据库(192.168.4.20);在192.168.4.120上使用授权用户连接代理服务器(192.168.4.100:4006),Insert一些数据成功,在主从数据库上面都可以看到,说明客户端写数据时是在主数据库服务器(192.168.4.10)上面。

原文地址:http://blog.51cto.com/13401027/2058683

时间: 2024-10-16 22:51:26

MySQL数据库之读写分离的相关文章

利用oneproxy部署mysql数据库的读写分离

实验系统:CentOS 6.6_x86_64 实验前提:防火墙和selinux都关闭 实验说明:本实验共有4台主机,IP分配如拓扑 实验软件:mariadb-10.0.20 oneproxy-rhel5-linux64-v5.6-ga 下载地址:http://pan.baidu.com/s/1jGpL2o2 实验拓扑: 注意:本实验是之前mysql-proxy实验的拓展,因此大部分环境及设定是相同的,其中一.二步这里不再重复,具体请参考:利用mysql-proxy进行mysql数据库的读写分离

mysql数据库的读写分离 amoeba

一 amoeba Amoeba是一个以MySQL为底层数据存储,并对应用提供MySQL协议接口的proxy.它集中地响应应用的请求,依据用户事先设置的规则,将SQL请求发送到特定的数据库上执行.基于此可以实现负载均衡.读写分离.高可用性等需求.与MySQL官方的MySQL Proxy相比,作者强调的是amoeba配置的方便(基于XML的配置文件,用SQLJEP语法书写规则,比基于lua脚本的MySQL Proxy简单). Amoeba优缺点 优点: 1.降低 数据切分带来的复杂多数据库结构 2.

基于amoeba实现mysql数据库的读写分离/负载均衡

一.Amoeba的简述:[来自百度百科] Amoeba是一个以MySQL为底层数据存储,并对应用提供MySQL协议接口的proxy.它集中地响应应用的请求,依据用户事先设置的规则,将SQL请求发送到特定的数据库上执行.基于此可以实现负载均衡.读写分离.高可用性等需求.与MySQL官方的MySQL Proxy相比,作者强调的是amoeba配置的方便(基于XML的配置文件,用SQLJEP语法书写规则,比基于lua脚本的MySQL Proxy简单). Amoeba相当于一个SQL请求的路由器,目的是为

利用mysql-proxy进行mysql数据库的读写分离

实验系统:CentOS 6.6_x86_64 实验前提:防火墙和selinux都关闭 实验说明:本实验共有4台主机,IP分配如拓扑 实验软件:mariadb-10.0.20 mysql-proxy-0.8.5-linux-el6-x86-64bit 下载地址:http://pan.baidu.com/s/1i3F5Pop 实验拓扑: 一.准备工作: 1.将主机名称改为如下所示: 2.将hosts文件添加如下内容: 3.master.slave1和slave2安装mariadb: tar xf m

mysql数据库的读写分离

一.      熟悉mysql读写分离及mysql存储引擎的区别. Ndb集群存储引擎.myisam.innodb Myisam为mysql安装后默认的存储引擎,不支持事务,行级锁和外键约束的功能:ndb为mysql集群存储引擎与innodb都支持事物,行级锁和外键约束.使用show engines;查看mysql支持的存储引擎. 读写分离: i.         环境: 应用程序client Database proxy Database集群(两台以上mysql机器) ii.         

docker-compose.yml样例(mysql主从+mycat读写分离)

Docker-compose.yml文件示例 1.mysql主从复制的docker-compose.yml文件 # cat docker-compose.yml version: '2' # 这个version是指dockerfile解析时用的版本,不是给我们自己定义版本号用的. services: m1: # master build: ./master # ./master文件下需要有Dockerfile文件,并且build属性和image属性不能一起使用 container_name: m

使用mysql proxy对数据库进行读写分离

服务器安排如下: 192.168.100.128 主 192.168.100.129 从 192.168.100.130 mysql-proxy 1.在100.130中下载安装mysql-proxy tar -zxvf mysql-proxy-0.8.5-linux-el6-x86-64bit.tar.gz cp mysql-proxy-0.8.5-linux-el6-x86-64bit /usr/local/mysql-proxy 2.配置环境变量 LUA_PATH="/usr/local/m

mysql主从复制与读写分离

MySQL主从复制与读写分离 MySQL主从复制(Master-Slave)与读写分离(MySQL-Proxy)实践 Mysql作为目前世界上使用最广泛的免费数据库,相信所有从事系统运维的工程师都一定接触过.但在实际的生产环境中,由单台Mysql作为独立的数据库是完全不能满足实际需求的,无论是在安全性,高可用性以及高并发等各个方面. 因此,一般来说都是通过 主从复制(Master-Slave)的方式来同步数据,再通过读写分离(MySQL-Proxy)来提升数据库的并发负载能力 这样的方案来进行部

MySQL主从复制、读写分离、高可用集群搭建

MySQL主从复制.读写分离.高可用集群搭建  一.服务介绍   1.1 Keepalived     Keepalived,见名知意,即保持存活,其目的是解决单点故障,当一台服务器宕机或者故障时自动切换到其他的服务器中.Keepalived是基于VRRP协议实现的.VRRP协议是用于实现路由器冗余的协议,VRRP协议将两台或多台路由器设备虚拟成虚拟设备,可以对外提供虚拟路由器IP(一个或多个),即漂移IP(VIP). 1.2 ProxySQL ProxySQL是一个高性能,高可用性的MySQL