博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL深入10-利用Ameoba实现读写分离
阅读量:7027 次
发布时间:2019-06-28

本文共 6442 字,大约阅读时间需要 21 分钟。

本篇博文主要介绍利用Ameoba实现MySQL的读写分离功能,而MySQL官方的mysql-proxy需要自己编写复杂的lua脚本才能实现同样的功能,故个人还是倾向使用amoeba哦;

===================================================================

1 简介

2 准备

   2.1 时间同步

   2.2 配置MySQL主从复制架构

3 ameoba安装配置

   3.1 安装配置JDK

   3.2 安装ameoba

   3.3 配置ameoba

   3.4 使用验证

   3.5 后期扩展

4 问题记录

===================================================================

1 简介

Amoeba(变形虫)项目是一个开源框架,于2008年开始发布一款 Amoeba for Mysql软件;

这个软件致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQL的时候充当SQL路由功能,专注于分布式数据库代理层(Database Proxy)开发;位于 Client、DB Server(s)之间,对客户端透明;

具有负载均衡、高可用性、SQL 过滤、读写分离、可路由相关的请求到目标数据库、可并发请求多台数据库并合并结果;

通过Amoeba你能够完成多数据源的高可用、负载均衡、数据切片的功能,目前Amoeba已在很多企业的生产线上面使用;

2 准备

2.1 时间同步

1
2
3
4
# crontab -e
# Dscrip: Time Sync
# CTime: 2014.03.23
*
/5 
* * * * 
/usr/sbin/ntpdate 
172.16.0.1 &>
/dev/null

2.2 配置MySQL主从复制架构

详见博文""


3 ameoba安装配置

3.1 安装配置JDK

1
2
3
4
chmod 
+x jdk-6u31-linux-x64-rpm.bin
vi 
/etc/profile
.d
/java
.sh 
# 采用bin文件安装jdk
    
export 
JAVA_HOME=
/usr/java/latest
    
export 
PATH=$JAVA_HOME
/bin
:$PATH

3.2 安装ameoba

1
2
3
4
5
6
mkdir 
/usr/local/amoeba
tar 
xf amoeba-mysql-binary-2.2.0.
tar
.gz -C 
/usr/local/amoeba 
# 使用二进制程序文件安装amoeba
cd 
/usr/local/amoeba
bin
/amoeba 
start 
# 前台运行
nohup 
/usr/local/amoeba/bin/amoeba 
start & 
# 后台运行
mysql -h127.0.0.1 -uroot -p -P8066 
# amoeba默认监听端口为8066

3.3 配置ameoba

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
cd 
/usr/local/amoeba/conf
vi 
ameoba.xml 
# 前端定义配置文件
# 修改ameoba前端监听端口
<service name=
"Amoeba for Mysql" 
class=
"com.meidusa.amoeba.net.ServerableConnectionManager"
>
    
<property name=
"port"
>3306<
/property
# 默认端口是8066,修改为3306,便于实现前端程序连接数据库的透明性
# 修改连接amoeba接口的认证信息
<property name=
"authenticator"
>
    
<bean class=
"com.meidusa.amoeba.mysql.server.MysqlClientAuthenticator"
>   
        
<property name=
"user"
>root<
/property
>   
        
<property name=
"password"
>mypass<
/property
# 添加登录密码
# 查询路由设置
<queryRouter class=
"com.meidusa.amoeba.mysql.parser.MysqlQueryRouter"
>
    
<property name=
"ruleLoader"
>       
        
<bean class=
"com.meidusa.amoeba.route.TableRuleFileLoader"
>
            
<property name=
"ruleFile"
>${amoeba.home}
/conf/rule
.xml<
/property
>
            
<property name=
"functionFile"
>${amoeba.home}
/conf/ruleFunctionMap
.xml<
/property
>
        
<
/bean
>
    
<
/property
>
    
<property name=
"sqlFunctionFile"
>${amoeba.home}
/conf/functionMap
.xml<
/property
>
    
<property name=
"LRUMapSize"
>1500<
/property
>
    
<property name=
"defaultPool"
>master<
/property
# 设定默认节点
    
<property name=
"writePool"
>master<
/property
>    
# 设定可写节点,节点定义见dbServers.xml文件
    
<property name=
"readPool"
>readservers<
/property
# 设定只读池,可配置多个slave节点
    
<property name=
"needParse"
>
true
<
/property
>
<
/queryRouter
>
vi 
dbServers.xml 
# 后端节点配置文件
# 定义抽象服务器,为每个后端MySQL服务器提供默认连接配置
<dbServer name=
"abstractServer" 
abstractive=
"true"
>
    
<factoryConfig class=
"com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory"
>
        
<property name=
"manager"
>${defaultManager}<
/property
>
        
<property name=
"sendBufferSize"
>64<
/property
>
        
<property name=
"receiveBufferSize"
>128<
/property
>
        
<property name=
"port"
>3406<
/property
>
        
<property name=
"schema"
>
test
<
/property
>
        
<property name=
"user"
>root<
/property
>
        
<property name=
"password"
>magedu<
/property
>
    
<
/factoryConfig
>
# 定义后端MySQL的IP地址,一个master,一个slave
<dbServer name=
"master"  
parent=
"abstractServer"
>
    
<factoryConfig>
        
<property name=
"ipAddress"
>192.168.0.45<
/property
>
    
<
/factoryConfig
>
<
/dbServer
>
<dbServer name=
"slave"  
parent=
"abstractServer"
>
    
<factoryConfig>
        
<property name=
"ipAddress"
>192.168.0.46<
/property
>
    
<
/factoryConfig
>
<
/dbServer
>
# 定义虚拟服务器组,即只读池readservers
<dbServer name=
"readservers" 
virtual=
"true"
>
    
<poolConfig class=
"com.meidusa.amoeba.server.MultipleServerPool"
>
        
<property name=
"loadbalance"
>1<
/property
>
        
<property name=
"poolNames"
>master,slave<
/property
>
    
<
/poolConfig
>
<
/dbServer
>

3.4 使用验证

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# 登录验证
[root@mysql conf]
# mysql -h127.0.0.1 -uroot -p -P3306
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MySQL connection 
id 
is 2097086015
Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distribution
Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others.
Type 
'help;' 
or 
'\h' 
for 
help. Type 
'\c' 
to 
clear 
the current input statement.
MySQL [(none)]> show master status;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000030 |      326 |              |                  |
+------------------+----------+--------------+------------------+
1 row 
in 
set 
(0.00 sec)
MySQL [(none)]>
# 读写验证
[root@mysql conf]
# mysql -h127.0.0.1 -uroot -p -P3306
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MySQL connection 
id 
is 2097086015
Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distribution
Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others.
Type 
'help;' 
or 
'\h' 
for 
help. Type 
'\c' 
to 
clear 
the current input statement.
MySQL [(none)]> create database amoeba_test;
Query OK, 1 row affected (0.04 sec)
MySQL [(none)]>
[root@mysql bin]
# mysql -h127.0.0.1 -uroot -p -P3406
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection 
id 
is 33
Server version: 10.0.10-MariaDB-log Source distribution
Copyright (c) 2000, 2014, Oracle, SkySQL Ab and others.
Type 
'help;' 
or 
'\h' 
for 
help. Type 
'\c' 
to 
clear 
the current input statement.
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| amoeba_test        |
| information_schema |
| mysql              |
| performance_schema |
test               
|
+--------------------+
9 rows 
in 
set 
(0.01 sec)
MariaDB [(none)]>
# 从amoeba接口登录创建数据库amoeba_test后,再从主库的接口中去查询数据库已创建,说明写入确实是落在了主库节点上;
# 若要验证ameoba对于读操作的调度,则需要暂时停止从库的复制操作,然后在主库上更新数据,这样从ameoba读取数据将出现不一致的情况;

3.5 后期扩展

利用MMM双主复制架构+Amoeba代理,可以实现对MySQL的高可用性和高性能;

关于MMM的内容参加博文""

4 问题记录

现象:使用mysql -uroot -p -P8066命令始终无法连接进入ameoba的配置接口,一直都是进入mysql数据库的配置接口

原因:在测试环境下,ameoba和mysql的主库都部署在同一台主机上,当启动ameoba服务后,即使指定-P8066连接,mysql客户端还是默认采用可被识别的socket文件(/tmp/mysql.sock)连接,同样指定-hlocalhost也是一样的;

当使用mysql命令连接mysqld时:

  • 连接主机为localhost或不指定时,mysql会采用Unix Socket的连接方式;

  • 连接主机为127.0.0.1时,mysql会采用TCP的方式连接;

解决方法:指定-h127.0.0.1连接即可,即mysql -h127.0.0.1 -uroot -p -P8066

本文转自 xxrenzhe11 51CTO博客,原文链接:http://blog.51cto.com/xxrenzhe/1413322,如需转载请自行联系原作者
你可能感兴趣的文章
淘宝API开发系列---阿里.聚石塔.开放平台的使用
查看>>
I.MX6 KEY_ROW4 can&#39;t as GPIO pin
查看>>
[大数据之Spark]——Actions算子操作入门实例
查看>>
5.4. package / compress and decompress
查看>>
Vuejs——(7)过渡(动画)
查看>>
(二十一)java字符串替换的问题
查看>>
面向服务编程
查看>>
Codeforces Round #309 (Div. 2) B. Ohana Cleans Up
查看>>
用简单的C语言实现多任务轮流切换(模拟操作系统线程机制)
查看>>
android Recyclerview仿京东,滚动屏幕标题栏渐变(启动页面动画)
查看>>
C语言之数值计算--级数算法
查看>>
C++之引用
查看>>
MFC学习笔记之三(粒子系统+怪物简单AI+碰撞检测)
查看>>
ios xmpp研究探索:发送文本消息
查看>>
费用流模板
查看>>
Makefile规则详解
查看>>
明星讲师心石闪耀ArchSummit大会 | 手机淘宝构架演化实践
查看>>
【Android开发】网路编程及Internet应用-从指定网站上下载文件
查看>>
PHP7源码笔记一
查看>>
扩展欧几里得算法求方程特解
查看>>