zoukankan      html  css  js  c++  java
  • mysql_proxy

    mysql_proxy中间件实现:读写分离、负载均衡。

    mysql_proxy中间件实现:读写分离、负载均衡。
    
    负载均衡:给多台数据库,看能不能均匀的分给不同的数据库。
    
    客户端连的是proxy,此时的proxy相当于一台虚拟的mysql,proxy来连接mysql。Proxy是一台代理。
    
    下载安装mysql_proxy:
    http://mysql.cdpa.nsysu.edu.tw/Downloads/MySQL-Proxy/mysql-proxy-0.8.3-linux-glibc2.3-x86-64bit.tar.gz
    
    解压后, 该目录包含已经编译好的二进制文件 .
    1: 利用mysql_proxy实现负载均衡
    执行mysql_proxy,告诉proxy连接的2台mysql,
    ./mysql-proxy-path/bin/mysql-proxy 
    ./bin/mysql_proxy  -P  4040  --proxy-backend-addresses=192.168.1.199:3306  --proxy-backend-addresses=192.168.1.200:3306
    
    
    2: 连接mysql_proxy,用mysql客户就可以,因为proxy是mysql的前端代理
    注意proxy的端口是4040
    Mysql  -h  “proxy的IP”  -P 4040 -u username -p password
    
    在连接上之后,做sql查询,却总是往某1台mysql server来发送------负载均衡没体现出来?
    答: 不是没体现出来.
    均衡不是体现在sql语句,一会请求mysqlA服,一会请求mysqlB服.
    均衡是体现”连接”的均衡上,又100个连接,则AB数据库每台50个连接,但具体的每一个连接,始终连某台服务器.
    
    
    mysql_proxy会把连接mysql服务器的tcp/IP连接缓存进连接池,只要拿到了某个连接就是一直连的是哪个mysql服务器。在缓存池里, 缓存的连接大致是平均分配在每台mysql服务器上。但具体的每一个连接,始终连某台服务器.
    2.读写分离:
    ./bin/mysql-proxy  
    --proxy-backend-addresses=192.168.1.199:3306       //写服务器
    --proxy-read-only-backend-addresses=192.168.1.200:3306     //readonly就是读服务器
    --proxy-lua-script=/usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua  //rw-splitting是读写分割的脚本
    
    简写:
    ./bin/mysql-proxy -b=192.168.0.199:3306 -r=192.168.0.200:3306 -s=/usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua  
    
    测试:停止一个slave,使他们成为主从,然后测试一边插入另一边能不能插入。
  • 相关阅读:
    HTML滚动时位置固定 PHP
    js判断验证码是否正确 PHP
    PNG渐变图生成工具 PHP
    C# 提醒小工具 PHP
    js 密码强度检测 PHP
    js辅助输入层 PHP
    不常用样式 PHP
    ASP.NET编程中的十大技巧
    WEB打印大全
    如何在ASP.NET中用OWC绘制图表
  • 原文地址:https://www.cnblogs.com/yaowen/p/8301799.html
Copyright © 2011-2022 走看看