zoukankan      html  css  js  c++  java
  • MySQL读写分离-架构

    MySQL读写分离-架构

    简介

    对于很多大型网站(pv值百万、千万)来说,在所处理的业务中,其中有70%的业务是查询(select)相关的业务操作(新闻网站,插入一条新闻。查询操作),剩下的则是写(insert、update、delete,只要能对MySQL的数据造成更改的操作都叫写操作)操作。在使用负载均衡集群之后,可以很大程度的提升网站的整体性能,但是最终的数据处理的压力还是会落到MySQL数据库上,所有很有必要使用一些技术来提升MySQL的负载能力。(读写分离)

    写专门交给写服务器处理(一般网站来说写是比较少的 读写比 4:1) 那么需要把读的任务分配多台服务器来完成的架构,就叫做读写分离。

    实现方式

    第一种:php程序上自己做逻辑判断,写php代码的时候,自己在程序上做逻辑判读写匹配。select,insert、update、delete做正则匹配,根据结果选择写服务器(主服务器)。如果是select操作则选择读服务器(从服务器器) mysql_connect('读写的区分')

    第二种:MySQL- Proxy是实现"读写分离(Read/Write Splitting)"的一个软件(MySQL官方提供 ,也叫中间件),基本的原理是让主数据库处理写操作(insert、update、delete),而从数据库处理查询操作(select)。而数据库的一致性则通过主从复制来实现。所以说主从复制是读写分离的基础

    注意:MySQL-proxy它能实现读写语句的区分主要依靠的是内部一个lua脚本(能实现读写语句的判断)。

    注意:如果只在主服务器(写服务器)上完成数据的写操作话;这个时候从服务器上没有执行写操作,是没有数据的。这个时候需要使用另外一个技术来实现主从服务器的数据一致性,这个技术叫做 主从复制技术。所以说主从复制是读写分离的基础。

     

    也可以从官方下载。

    下载地址:http://mirrors.sohu.com/mysql/MySQL-Proxy/

     

    如何查看Linux下c库的版本?

    注意通用二进制包需要c库版本一致,或者操作系统的c库比安装包高

    # uname -a (unix name --all)

    拓扑结构-架构图

    一主两从

     

    MySQL-proxy 负载均衡的软件(读写分离实现)

     

    使用三台服务器搭建环境

    1. 一台主(写)服务器
      1. 192.168.57.92
      2. 这台主服务器还运行一个读写分离的软件 mysql-proxy
    2. 二台从(读)服务器
      1. 192.168.57.26
      2. 192.168.57.37

       

      注意事项

    3. 防火墙的关闭

       

    4. selinux关闭

      selinux永久关闭

    5. root账户必须有远程登录的权限

    6. MySQL的版本需要为 5.5 及以上

      主从复制搭建

    7. 先配置主服务器
    8. 然后在配置从服务器

       

      主服务操作

      1. 主服务上的配置

    9. 在主服务上添加一个授权的账户,使得到时候从服务器可以使用该账号来完成数据的获取

      # GRANT REPLICATION SLAVE ON *.* TO repuser@"192.168.%.%" IDENTIFIED BY 'admin88';

      添加了一个 repuser的用户,密码为admin88 可以在 192.168.这个网段完成数据的复制。

      查看

       

    10. 在主服务器上使用 show master status 查看主服务上现在正在使用的bin日志文件和记录的位置。(bin日志文件默认在MySQL的data目录)

       

       

      从服务器的配置

    11. 修改从服务器的配置文件

    12. 使用在主服务器上的授权账号去连接主服务器,等待主服务器的数据的写入后,通知获取

      # CHANGE MASTER TO

      MASTER_HOST='192.168.57.92', MASTER_USER='repuser',

      MASTER_PASSWORD='admin88',

      MASTER_LOG_FILE='master-bin.000002',

      MASTER_LOG_POS=107;

      使用上面的语句连接主服务器后,使用

      # show slave statusG

    13. 开启从服务器

      命令:

    14. stop slave 可以停止 从服务器
    15. reset slave 清空从服务器的规则
    16. start slave 启动从服务器
    17. show slave status 查看从服务器状态
    18. show master status 查看主服务器状态

       

       

      读写分离搭建

      mac的前世今生

      https://yunpan.cn/cY4gQ6sXWaTXd 访问密码 7a0b

       

      下载mysql-proxy

      http://mirrors.sohu.com/mysql/MySQL-Proxy/

       

    19. mysql-proxy上传

    20. 解压操作

      #tar -zxvf mysql-proxy-0.8.4-linux-rhel5-x86-32bit.tar.gz -C /usr/local/

    21. 为mysql-proxy创建一个符号链接

       

    22. 添加一个mysql-proxy用户

      # useradd mysql-proxy

       

    23. 命令查看

       

      6. 在下面路径创建一个admin.lua脚本

      参照

       

      7. 服务启动

      #

      ./mysql-proxy --daemon --log-level=debug

      --log-file=/var/log/mysql-proxy.log

      --plugins='proxy'

      读写分离脚本

      --proxy-lua-script='/usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua'

      写服务器

      --proxy-backend-addresses='192.168.57.92:3306'

      读服务器

      --proxy-read-only-backend-addresses='192.168.57.29:3306'

      --proxy-read-only-backend-addresses='192.168.57.37:3306'

      --plugins='admin'

      --admin-username='admin'

      --admin-password='admin88' --admin-lua-script='/usr/local/mysql-proxy/share/doc/mysql-proxy/admin.lua'

       

      相关参数

      MySQL读写分离的监控

      mysql-proxy提供一个端口用来监控MySQL读写的实现

      使用的默认端口是 4041

      1. 使用下面的命令连接mysql-proxy的4041端口

      # mysql -uadmin -padmin88 -h 192.168.57.92 --port 4041

    24. 使用下面的命令查看读写服务器的状态

      # select * from backends;

    25. 如果效果不明显,可以修改下面的文件参数

       

       

  • 相关阅读:
    sql当前行数据和之前行数据相加减循环处理
    Sql 查询库、表、列名的语句
    sql 特殊字符替换
    pandas 篇
    JAVA学习--面向对象的特征二:继承性
    JAVA学习--super使用
    JAVA学习--方法的参数传递
    JAVA学习--可变个数的形参的方法
    JAVA学习--面向对象思想的落地法则
    JAVA学习--方法的重载
  • 原文地址:https://www.cnblogs.com/nyxd/p/5382482.html
Copyright © 2011-2022 走看看