amoba读写分离

原文出自 http://www.abcdocker.com/abcdocker/81


1.AMOEBA是什么

Amoeba(变形虫)项目,该开源框架于2008年 开始发布一款 Amoeba for Mysql软件。这个软件致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQL的 时候充当SQL路由功能,专注于分布式数据库代理层(Database Proxy)开发。座落与 Client、DB Server(s)之间,对客户端透明。具有负载均衡、高可用性、SQL 过滤、读写分离、可路由相关的到目标数据库、可并发请求多台数据库合并结果。 通过Amoeba你能够完成多数据源的高可用、负载均衡、数据切片的功能,目前Amoeba已在很多 企业的生产线上面使用。

2.AMOBA不能做什么

  •目前还不支持事务
  •暂时不支持存储过程(近期会支持)
  •不适合从amoeba导数据的场景或者对大数据量查询的query并不合适(比如一次请求返回10w以上甚至更多数据的场合)
  •暂时不支持分库分表,amoeba目前只做到分数据库实例,每个被切分的节点需要保持库表结构一致

3.安装AMOBA

安装JDK

  1. [root@db01 ~]# tar -xf jdk-8u91-linux-i586.tar.gz -C /usr/lib/
  2. [root@db01 ~]# ln -s /usr/lib/jdk1.8.0_91/ /usr/lib/java
  3. [root@db01 ~]# cat >> /etc/profile <<EOF
  4. [root@db01 ~]# echo '
  5. export JAVA_HOME=/usr/lib/java
  6. export JRE_HOME=${JAVA_HOME}/jre
  7. export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
  8. export PATH=${JAVA_HOME}/bin:$PATH' >> /etc/profileEOF
  9. [root@db01 ~]# source /etc/profile
  10. [root@db01 ~]# java -version
  11. java version "1.8.0_91"
  12. Java(TM) SE Runtime Environment (build 1.8.0_91-b14)
  13. Java HotSpot(TM) Client VM (build 25.91-b14, mixed mode)

安装amoeba

  1. [root@db01 ~]# wget http://ncu.dl.sourceforge.net/project/amoeba/Amoeba%20for%20mysql/2.x/amoeba-mysql-binary-2.1.0-RC5.tar.gz
  2. [root@db01 ~]# mkdir -p /application/amoeba-2.1.0-rc5
  3. [root@db01 ~]# tar -xf amoeba-mysql-binary-2.1.0-RC5.tar.gz /application/amoeba-2.1.0-rc5/
  4. [root@db01 ~]# ln -s /application/amoeba-2.1.0-rc5/ /application/amoeba
  5. [root@db01 ~]# echo 'PATH=/application/amoeba/bin/:$PATH' >> /etc/profile
  6. [root@db01 ~]# source /etc/profile

4.AMOEBA基础配置介绍

Amoeba主要配置文件
  1. dbServers.xml #主机IP,端口,Amoeba的用户名密码
  2. rule.xml         #切分规则相关
  3. functionMap.xml #描述了函数名和函数处理的关系
  4. ruleFunctionMap.xml #自定义函数
  5. access_list.conf #可以访问和拒绝访问的列表
  6. log4j.xml         #日志文件相关配置

5.配置AMOEBA对一个数据库实例进行操作

测试mysql是否可以正常连接
  1. [root@db01 ~]# mysql -uroot -poldboy123 -S /data/3306/mysql.sock 
  2. Welcome to the MySQL monitor.  Commands end with ; or \g.
  3. Your MySQL connection id is 5
  4. Server version: 5.5.49-log Source distribution
  5. Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved.
  6. Oracle is a registered trademark of Oracle Corporation and/or its
  7. affiliates. Other names may be trademarks of their respective
  8. owners.
  9. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  10. mysql>

 配置一个DB节点

  1. <?xml version="1.0" encoding="gbk"?>
  2. <!DOCTYPE amoeba:dbServers SYSTEM "dbserver.dtd">
  3. <amoeba:dbServers xmlns:amoeba="http://amoeba.meidusa.com/">
  4.                 <!-- 
  5.                         Each dbServer needs to be configured into a Pool,
  6.                         If you need to configure multiple dbServer with load balancing that can be simplified by the following configuration:
  7.                          add attribute with name virtual = "true" in dbServer, but the configuration does not allow the element with name factoryConfig
  8.                          such as 'multiPool' dbServer   
  9.                 -->
  10.         <dbServer name="abstractServer" abstractive="true">
  11.                 <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory">
  12.                         <property name="manager">${defaultManager}</property>
  13.                         <property name="sendBufferSize">64</property>
  14.                         <property name="receiveBufferSize">128</property>
  15.                         <!-- mysql port -->
  16.                         <property name="port">3306</property>
  17.                         <!-- mysql schema -->
  18.                         <property name="schema">test</property>
  19.                         <!-- mysql user -->
  20.                         <property name="user">oldboy</property>
  21.                         <!--  mysql password -->
  22.                         <property name="password">123456</property>
  23.                 </factoryConfig>
  24.                 <poolConfig class="com.meidusa.amoeba.net.poolable.PoolableObjectPool">
  25.                         <property name="maxActive">500</property>
  26.                         <property name="maxIdle">500</property>
  27.                         <property name="minIdle">10</property>
  28.                         <property name="minEvictableIdleTimeMillis">600000</property>
  29.                         <property name="timeBetweenEvictionRunsMillis">600000</property>
  30.                         <property name="testOnBorrow">true</property>
  31.                         <property name="testWhileIdle">true</property>
  32.                 </poolConfig>
  33.         </dbServer>
  34.         <dbServer name="server1"  parent="abstractServer">
  35.                 <factoryConfig>
  36.                         <!-- mysql ip -->
  37.                         <property name="ipAddress">127.0.0.1</property>
  38.                 </factoryConfig>
  39.         </dbServer>
  40.         <dbServer name="multiPool" virtual="true">
  41.                 <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool">
  42.                         <!-- Load balancing strategy: 1=ROUNDROBIN , 2=WEIGHTBASED , 3=H
  43. A-->
  44.                         <property name="loadbalance">1</property>
  45.                         <!-- Separated by commas,such as: server1,server2,server1 -->
  46.                         <property name="poolNames">server1</property>
  47.                 </poolConfig>
  48.         </dbServer>
  49. </amoeba:dbServers>

6.AMOEBA读写分离

  1. 创建授权用户bzjxs
  2. GRANT ALL ON *.* TO 'bzjxs'@'172.16.1.%' IDENTIFIED BY '123456'
  3. 配置dbServer.xml
  4. <?xml version="1.0" encoding="gbk"?>
  5. <!DOCTYPE amoeba:dbServers SYSTEM "dbserver.dtd">
  6. <amoeba:dbServers xmlns:amoeba="http://amoeba.meidusa.com/">
  7. ...
  8.  <dbServer name="Master"  parent="abstractServer">
  9.   <factoryConfig>
  10.    <!-- mysql ip -->
  11.    <property name="ipAddress">192.168.0.1</property>
  12.   </factoryConfig>
  13.  </dbServer>
  14. <--配置mysql节点master-->
  15.  
  16.  <dbServer name="Slave1"  parent="abstractServer">
  17.   <factoryConfig>
  18.    <!-- mysql ip -->
  19.    <property name="ipAddress">192.168.0.2</property>
  20.   </factoryConfig>
  21.  </dbServer>
  22. <--配置mysql节点slave1-->
  23.  <dbServer name="Slave2"  parent="abstractServer">
  24.   <factoryConfig>
  25.    <!-- mysql ip -->
  26.    <property name="ipAddress">192.168.0.3</property>
  27.   </factoryConfig>
  28.  </dbServer>
  29. <--配置mysql节点slave2-->
  30.   
  31.  <dbServer name="virtualSlave" virtual="true">
  32. <--配置mysql节点池-->
  33.   <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool">
  34.    <!-- Load balancing strategy: 1=ROUNDROBIN , 2=WEIGHTBASED , 3=HA-->
  35.    <property name="loadbalance">1</property>
  36. <--1代表轮询-->
  37.    
  38.    <!-- Separated by commas,such as: server1,server2,server1 -->
  39.    <property name="poolNames">Slave1,Slave1,Slave2</property>
  40. <--配置权重 代表轮询两次Slave1,轮询1Slave2-->
  41.   </poolConfig>
  42.  </dbServer>
  43. ...
  44. </amoeba:dbServers>

配置amoeba.xml直接配置读写分离

  1. <?xml version="1.0" encoding="gbk"?>
  2. <!DOCTYPE amoeba:configuration SYSTEM "amoeba.dtd">
  3. <amoeba:configuration xmlns:amoeba="http://amoeba.meidusa.com/">
  4. ...
  5. <queryRouter class=”com.meidusa.amoeba.mysql.parser.MysqlQueryRouter”>  
  6.    <property name="LRUMapSize">1500</property>
  7. <--amoeba缓存的语句的条数-->
  8.    <property name="defaultPool">Master</property> 
  9. <--默认访问的mysql节点 一些除了SELECT\UPDATE\INSERT\DELETE的语句都会在defaultPool执行-->
  10.    <property name="writePool">Master</property>
  11. <--写入的服务器-->
  12.    <property name="readPool">virtualSlave</property>
  13. <--读取的服务器可以是节点名也可以是节点池名-->
  14.    <property name="needParse">true</property>  
  15. </queryRouter>  
  16. ...
  17. </amoeba:configuration>
AMOEBA官方文档
http://docs.hexnova.com/amoeba/rw-splitting.html
本文转载老男孩28期李佳豪同学分享
喜欢本作者请关注我们的博客!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/576006.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL事务及字符集介绍

原文 http://www.abcdocker.com/abcdocker/77 事务介绍 简单来说&#xff0c;事务就是指逻辑上的一组SQL语句操作&#xff0c;组成这组操作的各个SQL语句&#xff0c;执行时要么全成功要么全失败。 MySQL5.5支持事务的引擎&#xff1a;Innodb/ndb事务四大特性&#xff08;ACID&…

为了IT人的荣耀,请大力支持《中国人的紧箍咒》!理由如下——

博友们请注意——老孙又出新书了&#xff01; 先前&#xff0c;老孙从技术跨界到管理&#xff0c;出了一本《知道力》&#xff1b;如今又从管理跨界到文化&#xff0c;新出一本文化书《中国人的紧箍咒》。 作为登陆文化新战场的IT第一人&#xff0c;老孙正在诺曼底滩头独自奋战…

MyCat介绍与配置(精)

Mycat 前生今世如果我有一个32核心的服务器&#xff0c;我就可以实现1个亿的数据分片&#xff0c;我有32核心的服务器么&#xff1f;没有&#xff0c;所以我至今无法实现1个亿的数据库分片。---Mycats Plan Mycat 简介Mycat是什么&#xff1f; 从定义和分类来看&#xff0c;它是…

mysql-mmm 集群高可用软件介绍

mysql-mmm 集群高可用软件介绍 MMM即Master-Master Replication Manager for MySQL&#xff08;mysql主主复制管理器&#xff09;关于mysql主主复制配置的监控、故障转移和管理的一套可伸缩的脚本套件&#xff08;在任何时候只有一个节点可以被写入&#xff09;&#xff0c;这个…

高可用MySQL MHA介绍

MySQL MHA介绍 MHA简介 MHA是一位日本MySQL大牛用Perl写一套MySQL故障切换方案&#xff0c;来保证数据库系统的高可用&#xff0c;在宕机的事件内&#xff08;通常10-30秒&#xff09;&#xff0c;完成故障转意&#xff0c;部署MHA&#xff0c;可避免主从一致性问题&#xff0c…

Xtrabackup安装以及应用

Xtrabackup是一个对InnoDB做数据备份的工具&#xff0c;支持在线热备份&#xff08;备份时不影响数据读写&#xff09;&#xff0c;是商业备份工具InnoDB Hotbackup的一个很好的替代品。 xtrabackup官方网址&#xff1a;https://www.percona.com/downloads/XtraBackup/MySQL Ba…

MySQL双主配置

双机热备的概念简单说一下&#xff0c;就是要保持两个数据库的状态自动同步。对任何一个数据库的操作都自动应用到另外一个数据库&#xff0c;始终保持两个数据库数据一致。 这样做的好处多。 1. 可以做灾备&#xff0c;其中一个坏了可以切换到另一个。 2. 可以做负载均衡&…

DSPBuilder笔记

一、位宽设置 在DSPBuilder中&#xff0c;数据在内部采用二进制定点数表示方法&#xff0c;数据可以设置成无符号整数、有符号整数和有符号小数等&#xff0c;其中有符号数由符号位、整数位和小数位组成&#xff08;有符号整数的小数位为0&#xff09;&#xff0c;位宽根据需求…

MySQL主从复制原理、半同步操作步骤及原理

1.1 企业Linux运维场景数据同步方案 1.1.1 文件级别的异机同步方案 1、scp/sftp/nc 命令可以实现远程数据同步。2、搭建ftp/http/svn/nfs 服务器&#xff0c;然后在客户端上也可以把数据同步到服务器。3、搭建samba文件共享服务&#xff0c;然后在客户端上也可以把数据同步到服…

基于.Net 写我自己的Ajax后台框架AjaxFramework

小小目录: 为什么要写自己的Ajax后台框架 框架的简单设计说明 框架如何使用 框架使用效果图 框架的优缺点 框架源码下载1、为什么要写自己的Ajax后台框架 现在Ajax在web应用方面已经用的稀巴烂了&#xff0c;如果你做一个网站没有用到ajax都不好意思拿出手&…

MySQL备份恢复与日志

MySQL 数据库的备份与恢复 1.1 备份数据的意义 第一是保护公司的数据&#xff0c;第二是网站7*24小时提供服务1.2 备份单个数据库参数使用 MySQL数据库自带了一个很好用的备份命令&#xff0c;就是mysqldump&#xff0c;它的基本使用如下&#xff1b;语法&#xff1a;mysqldum…

MySQL入门介绍

数据库介绍 1.1 什么是数据库&#xff1f; 简单的说&#xff0c;数据库&#xff08;英文Dtabase&#xff09;就是一个存放数据的仓库&#xff0c;这个仓库是按照一定的数据结果&#xff08;数据结构是指数据的组织形式或数据之间的联系&#xff09;来组织、存储的、我们可以通…

zoj 2526(一道很好的最短路应用题)

题目链接&#xff1a;http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId1538 题意&#xff1a;最短路问题&#xff0c;但是要求出最短路的条数&#xff0c;同时要求出所有可能的最短路选择中javabean最多的情况。 思路&#xff1a;求到终点的最短路径用Dijkstra&am…

MySQL常用命令大全

登录MySQL方法 单实例MySQL登录的方法 mysql #刚装完系统无密码情况登录方式&#xff0c;不需要密码 mysql -u root #刚装完系统无密码的情况登录 mysql -uroot -p #这里标准的dba命令行登录 mysql -uroot -poldboy #非脚本里一般不这样用&#xff0c;密码明文会泄露密码…

服务器安全之iptables iptables

服务器安全之iptables 感谢老男孩老师为我们讲解iptables 优化之路 iptables防火墙简介 Netfilter/Iptables&#xff08;以下简称Iptables&#xff09;是unix/linux自带的一款优秀且开放源代码的安全自由的**基于包过滤的防火墙工具**&#xff0c;它的功能十分强大&#xff0…

MC新手入门(三十)------ 逻辑运算符和表达式

游戏设计中提供了三种逻辑运算符&#xff1a; 1&#xff09;&& 与运算 2&#xff09;|| 或运算 3&#xff09; &#xff01;非运算 游戏设计中我们常常要用到上面的逻辑运算&#xff0c;例如&#xff1a;当在双人游戏中都要实现两人同时存活才能过关&#xff0c;…

Nagios 配置及监控

Nagios 监控 在互联网日益发展的今天&#xff0c;监控的重要性已经不言而喻。可能打开一个URL要经过6-7层的处理&#xff0c;如果出了问题而没有监控将很难定位到问题所在。那哪些内容需要监控呢&#xff1f; 1.本地资源 (1) 负载&#xff1a;uptime&#xff1b; (2) CPU&…

SSH 配置

SSH 批量管理 SSH介绍 SSH是Secure Shell Protocol的简写&#xff0c;由IETF网络工作小组&#xff08;Network working Group&#xff09;指定&#xff1b;在进行数据传输之前&#xff0c;SSH先对联机数据包通过加密技术进行加密处理&#xff0c;加密后在进行数据传输。确保了传…

服务器重启导致无法启动MySQL

今天服务器受到DDOS攻击&#xff0c;笔者脑残重启了一下服务器。结果造成MySQL服务器无法启动mysql日志见下图。160803 17:43:47 mysqld_safe Starting mysqld daemon with databases from /application/mysql/data160803 17:43:47 [Note] /application/mysql/bin/mysqld (mysq…

架构师之DNS实战

架构师 DNS实战 老男孩教育 DNS简介 1. DNS的出现及演化 网络出现的早起是使用IP地址通讯的&#xff0c;那是就几台主机通讯。但是随着接入网络主机的增多&#xff0c;这种数字标识的地址非常不便于记忆&#xff0c;UNIX上就出现了建立一个叫做hosts的文件&#xff08;Linux和W…