您好,欢迎访问一九零五行业门户网

使用Amoeba 实现MySQL DB 读写分离

amoeba(变形虫)项目是一个开源框架,于2008年开始发布一款 amoeba for mysql软件;这个软件致力于mysql的分布式数据库前端代理层
amoeba(变形虫)项目是一个开源框架,于2008年开始发布一款 amoeba for mysql软件;
这个软件致力于mysql的分布式数据库前端代理层,它主要在应用层访问mysql的时候充当sql路由功能,,专注于分布式数据库代理层(database proxy)开发;位于 client、db server(s)之间,对客户端透明;
用amoeba实现mysql的读写分离 
================================
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 时间同步
# crontab -e
# dscrip: time sync
# ctime: 2014.03.23
*/5 * * * * /usr/sbin/ntpdate 172.16.0.1 &>/dev/null
2.2 配置mysql主从复制架构
详见mariadb 主从复制
3 ameoba安装配置
3.1 安装配置jdk
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
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
cd /usr/local/amoeba/conf
vi ameoba.xml # 前端定义配置文件
# 修改ameoba前端监听端口
3306 # 默认端口是8066,修改为3306,便于实现前端程序连接数据库的透明性
# 修改连接amoeba接口的认证信息
root 
        mypass # 添加登录密码
# 查询路由设置
${amoeba.home}/conf/rule.xml
            ${amoeba.home}/conf/rulefunctionmap.xml
${amoeba.home}/conf/functionmap.xml
    1500
    master # 设定默认节点
    master    # 设定可写节点,节点定义见dbservers.xml文件
    readservers # 设定只读池,可配置多个slave节点
    true
vi dbservers.xml # 后端节点配置文件
# 定义抽象服务器,为每个后端mysql服务器提供默认连接配置
${defaultmanager}
        64
        128
        3406
        test
        root
        magedu
# 定义后端mysql的ip地址,一个master,一个slave
192.168.0.45
192.168.0.46
# 定义虚拟服务器组,即只读池readservers
1
        master,slave
3.4 使用验证
在主库上授权:
mariadb [(none)]> grant all on *.* identified by 'magedu';
query ok, 0 rows affected (0.00 sec)
mariadb [(none)]> grant all on *.* identified by 'magedu'; # 这里的密码应该与dbserver.xml中的数据库密码一致
query ok, 0 rows affected (0.00 sec)
mariadb [(none)]> flush privileges;
query ok, 0 rows affected (0.00 sec)
其它类似信息

推荐信息