`
saybody
  • 浏览: 902498 次
  • 性别: Icon_minigender_2
  • 来自: 西安
文章分类
社区版块
存档分类
最新评论

MySQL Proxy 安装与读写分离体验

阅读更多
一直想等到BETA版出来再试验的,可还是经不住诱惑阿,下午终于有时间测试一下了。
(本文参考地址:http://blog.chinaunix.net/u/8111/showart.php?id=451420
一、必备软件:
1、LUA
可以去LUA的官方下载:www.lua.org
2、MySQL Proxy
这里有好多二进制版本。
http://mysql.cdpa.nsysu.edu.tw/Downloads/MySQL-Proxy/
或者去MYSQL官方下载源代码。
3、测试过程中取消了B和C的REPLICATION。这样SQL语句一下子就看出来从哪里来的。
如果是M-S(可以先在SLAVE上进行STOP SLAVE)
二、测试主机地址:
1、MySQL Proxy 安装地址:192.168.0.234(简称A)
2、MySQL 服务器地址:192.168.0.235(简称B)/236(简称C)
三、安装体验
如果是按照二进制包安装的,跳过这一步。
1、 LUA的安装
[root@localhost ~]#tar zxvf lua-5.1.2.tar.gz -C /usr/local
[root@localhost ~]# cd /usr/local/
[root@localhost local]# mv lua-5.1 lua
[root@localhost lua]# cd lua
[root@localhost lua]#make local;make install;
导出环境变量:
[root@localhost lua]#export LUA_CFLAGS="-I/usr/local/include" LUA_LIBS="-L/usr/local/lib -llua -ldl" LDFLAGS="-lm"
2、MySQL Proxy 安装
[root@localhost ~]#tar -zxvf mysql-proxy-0.6.1-linux-rhel4-x86-32bit.tar.gz -C /usr/local/mysql/
[root@localhost ~]#cd /usr/local/mysql
[root@localhost mysql]#mv mysql-proxy-0.6.1-linux-rhel4-x86-32bit/ mysql-proxy
[root@localhost sbin]# export PATH=$PATH:/usr/local/mysql/mysql-proxy/sbin/

四、使用MySQL Proxy
1、查看帮助选项
[root@localhost ~]# mysql-proxy --help-all
2、对MySQL 操作
MySQL服务器假设已经安装。(安装步骤这里就不写了)
两台机器上的表初始结构和数据都是一样的,而且都有t_girl_user这个用户。
mysql> desc t;

+-------+----------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| c_str | char(64) | NO | | | |
+-------+----------+------+-----+---------+----------------+
2 rows in set (0.00 sec)


2 rows in set (0.00 sec)
我在B上插入一条记录
mysql> insert into t(c_str) values('B');
Query OK, 1 row affected (0.00 sec)
在C上同样插入一条记录
mysql> insert into t(c_str) value('C');
Query OK, 1 row affected (0.00 sec)

mysql>
3、启动MySQL-Proxy(测试读写分离)
[root@localhostsbin]# mysql-proxy--proxy-read-only-backend-addresses=192.168.0.236:3306--proxy-backend-addresses=192.168.0.235:3306--proxy-lua-script=/usr/local/mysql/mysql-proxy/share/mysql-proxy/rw-splitting.lua&
[1] 32554
让MYSQL PROXY自动启动的简单脚本
#!/bin/sh
# export PATH=$PATH:/usr/local/mysql-proxy
cd /usr/local/mysql-proxy
./mysql-proxy--proxy-read-only-backend-addresses=192.168.0.236:3306--proxy-backend-addresses=192.168.0.235:3306--proxy-lua-script=rw-splitting.lua >> /tmp/log
~
这个例子中限制192.168.0.236为只读,192.168.0.235为可写。
4、下来我们来看试验结果。
我们用几台客户端开启4个连接。
[root@localhost ~]# /usr/local/mysql/bin/mysql -ut_girl_user -p123456 -P4040 -h192.168.0.234 -Dt_girl
我这边已经启动了好几个客户端,这里就不贴了,命令和上面的一样。
写数据。
mysql> insert into t(c_str) values ('wangwang');
Query OK, 1 row affected (0.01 sec)

mysql> show processlist;
+----+-------------+---------------------+--------+---------+------+-------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+-------------+---------------------+--------+---------+------+-------+------------------+
| 12 | t_girl_user | 192.168.0.234:44975 | t_girl | Sleep | 28 | | NULL |
| 13 | t_girl_user | 192.168.0.234:44976 | t_girl | Sleep | 15 | | NULL |
| 14 | t_girl_user | 192.168.0.234:44977 | t_girl | Sleep | 19 | | NULL |
| 15 | t_girl_user | 192.168.0.234:44978 | t_girl | Query | 0 | NULL | show processlist |
+----+-------------+---------------------+--------+---------+------+-------+------------------+
4 rows in set (0.00 sec)


4 rows in set (0.00 sec)
读数据(现在还是写和读都在B上)
mysql> select * from t;
+----+----------+
| id | c_str |
+----+----------+
| 1 | B |
| 2 | wangwang |
+----+----------+
2 rows in set (0.00 sec)

再增加一个客户端连接。

1 row in set (0.00 sec)

mysql> show processlist;
+----+-------------+---------------------+--------+---------+------+-----------------------------------------------------------------------+------------------+
|Id | User | Host | db | Command | Time |State |Info |
+----+-------------+---------------------+--------+---------+------+-----------------------------------------------------------------------+------------------+
|2 | system user | | NULL | Connect | 1842 | Hasread all relay log; waiting for the slave I/O thread to update it |NULL |
| 5 | root | localhost |t_girl | Query | 0 |NULL |show processlist |
| 12 | t_girl_user | 192.168.0.234:44975 |t_girl | Sleep | 446|| NULL |
| 13 | t_girl_user | 192.168.0.234:44976 |t_girl | Sleep | 188|| NULL |
| 14 | t_girl_user | 192.168.0.234:44977 |t_girl | Sleep | 206|| NULL |
| 15 | t_girl_user | 192.168.0.234:44978 |t_girl | Sleep | 203|| NULL |
| 16 | t_girl_user | 192.168.0.234:44979 |t_girl | Sleep | 164|| NULL |
| 17 | t_girl_user | 192.168.0.234:44980 |t_girl | Sleep | 210|| NULL |
+----+-------------+---------------------+--------+---------+------+-----------------------------------------------------------------------+------------------+
8 rows in set (0.00 sec)
现在我们来读数据。
mysql> select * from t;
+----+-------+
| id | c_str |
+----+-------+
| 1 | C |
+----+-------+
1 row in set (0.00 sec)
这个数据很明显是来自C的。
再插入一条记录
mysql> insert into t(c_str) values ('wangwei');
Query OK, 1 row affected (0.00 sec)

mysql> select * from t;
+----+-------+
| id | c_str |
+----+-------+
| 1 | C |
+----+-------+
1 row in set (0.00 sec)

C上的数据没有变。
还是没有数据。
现在跑到B上看看。

mysql> show processlist;
+----+-------------+---------------------+--------+---------+------+-----------------------------------------------------------------------+------------------+
|Id | User | Host | db | Command | Time |State |Info |
+----+-------------+---------------------+--------+---------+------+-----------------------------------------------------------------------+------------------+
|2 | system user | | NULL | Connect | 1842 | Hasread all relay log; waiting for the slave I/O thread to update it |NULL |
|5 | root | localhost | t_girl | Query | 0 |NULL |show processlist |
|12 | t_girl_user | 192.168.0.234:44975 | t_girl | Sleep | 446|| NULL |
|13 | t_girl_user | 192.168.0.234:44976 | t_girl | Sleep | 188|| NULL |
|14 | t_girl_user | 192.168.0.234:44977 | t_girl | Sleep | 206|| NULL |
|15 | t_girl_user | 192.168.0.234:44978 | t_girl | Sleep | 203|| NULL |
|16 | t_girl_user | 192.168.0.234:44979 | t_girl | Sleep | 164|| NULL |
|17 | t_girl_user | 192.168.0.234:44980 | t_girl | Sleep | 210|| NULL |
+----+-------------+---------------------+--------+---------+------+-----------------------------------------------------------------------+------------------+


8 rows in set (0.00 sec)

mysql> select * from t;
+----+----------+
| id | c_str |
+----+----------+
| 1 | B |
| 2 | wangwang |
| 3 | wangwei |
+----+----------+

3 rows in set (0.00 sec)
数据被成功插入到B

这个读写分离应该看得很清楚。其他的功能等我测试了再总结吧。

如果要知道为什么连接多了才会进行分离的话,看看
手册

论坛里面的讨论

还有其他我以前收藏的地址,可以参考以下。
http://www.infoq.com/news/2007/10/mysqlproxyrwsplitting;jsessionid=F9E0B91935E82033BAFAC067A326DC4B
http://blogs.mysql.com/kaj/2007/12/10/combining-mysql-proxy-with-mysql-cluster/
分享到:
评论

相关推荐

    使用mysql-proxy实现mysql读写分离

    ### 使用mysql-proxy实现MySQL读写分离 随着业务规模的不断扩大,数据库系统往往成为整个系统中的瓶颈之一。为了提高系统的响应速度以及数据处理能力,一种常用的技术手段就是采用**读写分离**的方式。读写分离的...

    mysql配置mysql-proxy读写分离1

    MySQL Proxy 是一个开源工具,它允许你在 MySQL 客户端和服务器之间设置一个代理层,以便实现诸如负载均衡、故障切换、读写分离等高级功能。在这个场景中,我们将讨论如何配置 MySQL Proxy 来实现读写分离,以提高...

    MySQL Proxy 快速实现读写分离以及负载均衡

    通过以上步骤,我们不仅成功安装了 MySQL Proxy 并配置了读写分离与负载均衡,还对 MySQL Proxy 的基本使用进行了简单的介绍。MySQL Proxy 作为一款强大的中间件工具,极大地简化了数据库集群的管理和维护工作。对于...

    Mysql Proxy 实现mysql读写分离.pdf

    MySQL Proxy 实现读写分离 MySQL Proxy 是一个处于 Client 端和 MySQL server 端之间的简单程序,它可以监测、分析或改变它们的通信。它使用灵活,没有限制,常见的用途包括:负载平衡,故障、查询分析,查询过滤和...

    MysqlProxy实现mysql读写分离[整理].pdf

    MySQL Proxy 是一种轻量级的中间件,用于在客户端应用程序和 MySQL 服务器之间提供透明的代理服务,尤其适用于实现数据库的读写分离和负载均衡。它允许你在客户端和服务器之间插入一个可编程的层,通过 Lua 脚本来...

    mysql-proxy实现读写分离1

    MySQL Proxy 是一个开源工具,主要用于实现数据库的读写分离,以优化MySQL服务器的负载。在本文中,我们将探讨如何利用MySQL Proxy实现一个简单的读写分离环境,并关注在配置过程中的一些关键点。 首先,读写分离是...

    MySQL-Proxy快速实现读写分离以及负载均衡

    MySQL Proxy是MySQL数据库系统中的一个轻量级工具,用于实现数据库的读写分离和负载均衡。它作为一个中间代理服务器,接收来自客户端的请求,然后根据配置策略将这些请求转发到合适的MySQL服务器实例上。在上述描述...

    MySQL搭建Amoeba_读写分离.docx

    Amoeba 是一个基于 MySQL 的 proxy,能够集中地响应应用的请求,并根据用户事先设置的规则,将 SQL 请求发送到特定的数据库上执行,从而实现负载均衡、读写分离、高可用性等需求。 一、Amoeba 简介 Amoeba 是一个...

    MYSQL数据库读写分离mysql-proxy 32bit包

    为了解决这个问题,MySQL提供了一个名为`mysql-proxy`的工具,这正是"MYSQL数据库读写分离mysql-proxy 32bit包"的主题。MySQL Proxy是一个轻量级的代理服务器,它可以坐在MySQL服务器和客户端应用程序之间,动态地...

    MySQL读写分离架构与实践--mysql-proxy

    MySQL主从复制(Master-Slave)的方式来同步数据,再通过读写分离(MySQL-Proxy/Amoeba)来提升数据库的并发负载能力 这样的方案来进行部署与实施的

    mysql-proxy读写分离.docx

    公司运维手册,mysql-proxy读写分离,废话不多说,上干货!

    mysql-proxy 安装配置

    MySQL Proxy 是一个开源工具,它允许用户在 MySQL 客户端和服务器之间插入一个代理层,从而实现诸如负载均衡、故障切换、读写分离等高级功能。以下是对MySQL Proxy安装配置及其相关知识点的详细说明: 1. **安装...

    Docker搭建MySQLl基于ShardingSphere-Proxy读写分离(docker-compose)

    docker_compose搭建shardingSphereProxyMysql主从读写分离

    mysql读写分离配置

    MySQL-Proxy的读写分离功能主要通过`rw-splitting.lua`脚本来实现,因此需要安装Lua语言。 1. **下载Lua源码包**: 可以从官网下载Lua的最新源码包或通过rpm包安装。 ```bash cd /opt/install wget ...

    MySQL双主多从读写分离自动化安装

    采用MySQL Replication+ MySQL Proxy+Heartbeat实现MySQL读写分离HA 双Master都安装MySQL Proxy和Heartbeat(也可以单独安装MySQL Proxy,Heartbeat跟MySQL Proxy装在一起),多个Slave跟每个Master进行多主单从...

    LAMP+Proxy+读写分离

    【LAMP架构与读写分离】 LAMP架构是Linux、Apache、MySQL和PHP的缩写,是一种常见的Web开发平台,广泛应用于企业级网站构建。在这个架构中,Linux作为操作系统,Apache作为Web服务器,MySQL作为关系型数据库管理系统...

    mysql 读写分离软件

    常见的MySQL读写分离软件有MySQL Proxy、MaxScale、HAProxy、AMQP等。每款软件都有其特点和适用场景,比如MySQL Proxy轻量级但功能相对简单,MaxScale是MySQL公司官方出品,功能强大且易于集成,HAProxy则常用于网络...

Global site tag (gtag.js) - Google Analytics