广告
返回顶部
首页 > 资讯 > 数据库 >MySQL数据库之读写分离
  • 681
分享到

MySQL数据库之读写分离

2024-04-02 19:04:59 681人浏览 八月长安
摘要

一、概述:    Mysql数据库主从结构配置以后,正常情况下数据库的所有读写操作全部都在主数据库上面,从数据库仅仅作为数据备份使用,显然无法有效的使用服务器资源,那

一、概述:

    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)修改配置文件:

      [root@100 ~]# 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 scalemon@"%" identified by "123456";
   mysql > grant select on mysql.* to maxscale@"%" identified by "123456";

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

  (1)启动服务:

        [root@100 ~]# maxscale --config=/etc/maxscale.cnf

  (2)检查状态

        [root@100 ~]# 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)上面。        

您可能感兴趣的文档:

--结束END--

本文标题: MySQL数据库之读写分离

本文链接: https://www.lsjlt.com/news/50102.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL数据库之读写分离
    一、概述:    MySQL数据库主从结构配置以后,正常情况下数据库的所有读写操作全部都在主数据库上面,从数据库仅仅作为数据备份使用,显然无法有效的使用服务器资源,那...
    99+
    2022-10-18
  • Mysql数据库读写分离
    (先对数据库操作进行读写分离,使得具有master角色的主服务器主要用于执行写操作,这样就能大大减少主服务器由于读操作而产生的负载过大的问题。读交给slave。对于多台读服务器,还要把读操作的压力分摊到不同...
    99+
    2022-10-18
  • MySQL-数据库读写分离(中)
    ♥️作者:小刘在C站 ♥️个人主页: 小刘主页  ♥️努力不一定有回报,但一定会有收获加油!一起努力,共赴美好人生! ♥️学习两年总结出的运维经验,以及思科模拟器全套网络实验教程。专栏:云计算技术 ♥️小刘私信可以随便问,只要会...
    99+
    2023-08-31
    数据库 mysql sql
  • 关系型数据库之mysql-proxy实现读写分离
    简要:  mysql-proxy作为mysql测试项目,可以实现读写分离架构,具有开发能力的公司通过二次开发的方式去完善bug应用在生产环境中,下面我们通过案例使用mysql-proxy实现读写分...
    99+
    2022-10-18
  • 数据库---mysql主从复制读写分离
    http://m.open-open.com/m/lib/view/1413274853450.html 原理及架构分析部署前准备下载好源码包存放位置要与脚本中对应  mysql-5.5...
    99+
    2022-10-18
  • Mysql数据库读写分离简单配置
    环境:Master:192.168.71.128      mysql-sql-node1Slave:192.168.71.140 &n...
    99+
    2022-10-18
  • 使用Atles实现MySQL数据库读写分离
    本文主要给大家简单讲讲使用Atles实现MySQL数据库读写分离,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望使用Atles实现MySQL数据库读写分离这篇...
    99+
    2022-10-18
  • MySQL数据库主从复制与读写分离
    目录一.主从复制主从复制三线程主从复制的过程:主从复制的策略:主从复制高延迟二.读写分离读写分离概念读写分离原因与场景总结一.主从复制        主从复制:在实际的生产中,为了解...
    99+
    2022-11-12
  • mysql系列之8------读写分离
    一、前言:读写分离的基本原理       mysql的读写分离的基本原理是:让master(主数据库)来响应事务性操作,让slave(从数据库)来响应select非事...
    99+
    2022-10-18
  • Amoeba实现数据库读写分离
    一 环境以及软件版本:系统:CentOS Linux release 7.2.1511 (Core)mysql:Server version: 5.6.33Amoeba:amoeba-mysql-3.0.5...
    99+
    2022-10-18
  • 怎么做数据库读写分离
    这篇文章主要讲解了“怎么做数据库读写分离”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么做数据库读写分离”吧!实现方式对于读写分离的使用,主要分为两种方式...
    99+
    2022-10-18
  • 数据库学习之十四:读写分离 Atlas架构
    十四、读写分离 Atlas架构 1、安装软件 rpm -ivh Atlas-2.2.1.el6.x86_64.rpm 2、修改配置 cd /usr/local/mysql-proxy/ vim /usr/local/mys...
    99+
    2017-08-23
    数据库学习之十四:读写分离 Atlas架构
  • mysql数据库多种备份及读写分离搭建
    数据库的版本1.社区版2.企业版3.集群版数据库的安装1.     专用软件包管理器(二进制)deb 、rpm等mysql   &nbs...
    99+
    2022-10-18
  • 如何利用mycat实现mysql数据库读写分离
    这篇文章主要介绍了如何利用mycat实现mysql数据库读写分离,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。什么是MyCAT一个彻底开源的...
    99+
    2022-10-18
  • MySQL-mycat读写分离
    Mycat 需要安装JDK 1.7 或者以上版本第一步:下载jdk-8u131-linux-x64.tar.gz文件 http://haixi.sfkcn.com:8080/201704/tools/jdk-linux-x64.tar.gz...
    99+
    2021-04-03
    MySQL-mycat读写分离 数据库入门 数据库基础教程 数据库 mysql
  • mysql+amoeba读写分离
    mysql+amoeba读写分离一 简介:Amoeba是一个以MySQL为底层数据存储,并对应用提供MySQL协议接口的proxy。它集中地响应应用的请求,依据用户事先设置的规则,将SQL请求发送到特定的数...
    99+
    2022-10-18
  • 利用amoeba(变形虫)实现mysql数据库读写分离
    前期准备工作: 1.两个数据库,一主一从,主从同步; master: 172.22.10.237:3306 ;主库负责写入操作; slave: 10.4.66.58:3306 ; 从库负责读取操作; amoeba: 172.22.10.23...
    99+
    2015-09-22
    利用amoeba(变形虫)实现mysql数据库读写分离
  • MySQL数据库的主从同步配置与读写分离
    使用mysql主从复制的好处有: 1、采用主从服务器这种架构,稳定性得以提升。如果主服务器发生故障,我们可以使用从服务器来提供服务。 2、在主从服务器上分开处理用户的请求,可以提升数据处理效率。 3、将主服...
    99+
    2022-10-18
  • 利用amoeba实现mysql数据库读写分离的案例
    小编给大家分享一下利用amoeba实现mysql数据库读写分离的案例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!关于mysql的读写分离架构有很多,百度的话几乎都是用mysql_prox...
    99+
    2022-10-18
  • ProxySQL中怎么利用MySQL实现数据库读写分离
    ProxySQL中怎么利用MySQL实现数据库读写分离,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。ProxySQL介绍1、连接池,而且是mu...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作