一、由于是MySql集群,所以就不可能只有一个MySql,需要多个MySql,具体安装步骤,可以参考http://www.cnblogs.com/ywzq/p/4882140.html这个地址进行安装配置和启动。

  二、现在MySql有了,开始安装Ameoba

    1.下载文件:amoeba-mysql-0.32.tar.gz

    2.创建文件amoeba

    mkdir amoeba

    cd amoeba

    3.解压文件(由于amoeba的作者打包时没太注意,所以你要先件个文件)

      tar amoeba-mysql-0.32.tar.gz

      cd conf/

        配置前端访问接口<server></server>如:     

            <server>
              <property name="port">8066</property>

              <property name="ipAddress">101.201.140.214</property>

              <property name="readThreadPoolSize">500</property>

              <property name="clientSideThreadPoolSize">500</property>

              <property name="serverSideThreadPoolSize">500</property>

              <property name="netBufferSize">200</property>

              <property name="tcpNoDelay">true</property>

              <property name="user">root</property>

              <property name="password">root</property>
            </server>

        配置监听:

            

            <connectionManagerList>
              <connectionManager name="defaultManager" class="com.meidusa.amoeba.net.AuthingableConnectionManager"/>
            </connectionManagerList>

     搭建主从复制,读写分离的架构

        配置多个数据<dbServerList></dbServerList>

            配置Master(主)MySql数据库:     

            <dbServer name="master">
              <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory">

              <property name="manager">defaultManager</property>

              <property name="port">4308</property>

              <property name="ipAddress">101.201.140.214</property>

              <property name="schema">test</property>

              <property name="user">root</property>

              <property name="password">root4308</property>

             </factoryConfig>

                <poolConfig class="com.meidusa.amoeba.net.poolable.PoolableObjectPool">
                <property name="maxActive">500</property>
                <property name="maxIdle">200</property>
                <property name="minIdle">10</property>
                <property name="minEvictableIdleTimeMillis">600000</property>
                <property name="timeBetweenEvictionRunsMillis">600000</property>
                <property name="testOnBorrow">true</property>
                <property name="testWhileIdle">true</property>
              </poolConfig>
            </dbServer>

            配置Slave(从>1)

            <dbServer name="slave1">
              <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory">
                <property name="manager">defaultManager</property>

                <property name="port">4306</property>

                <property name="ipAddress">101.201.140.214</property>
               <property name="schema">test</property>

                <property name="user">root</property>

                <property name="password">root4306</property>

              </factoryConfig>
                <poolConfig class="com.meidusa.amoeba.net.poolable.PoolableObjectPool">
                <property name="maxActive">500</property>
                <property name="maxIdle">200</property>
                <property name="minIdle">10</property>
                <property name="minEvictableIdleTimeMillis">600000</property>
                <property name="timeBetweenEvictionRunsMillis">600000</property>
                <property name="testOnBorrow">true</property>
                <property name="testWhileIdle">true</property>
              </poolConfig>
            </dbServer>

            配置Slave(从>1)

            <dbServer name="slave2">

              <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory">
                <property name="manager">defaultManager</property>

                <property name="port">4307</property>

                <property name="ipAddress">101.201.140.214</property>

                <property name="schema">test</property>

                <property name="user">root</property>

                <property name="password">root4307</property>

              </factoryConfig>
              <poolConfig class="com.meidusa.amoeba.net.poolable.PoolableObjectPool">
                <property name="maxActive">500</property>
                <property name="maxIdle">200</property>
                <property name="minIdle">10</property>
                <property name="minEvictableIdleTimeMillis">600000</property>
                <property name="timeBetweenEvictionRunsMillis">600000</property>
                <property name="testOnBorrow">true</property>
                <property name="testWhileIdle">true</property>
              </poolConfig>
            </dbServer>

            配置写入MySql

            <dbServer name="virtualSlave" virtual="true">
              <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool">
                <!-- 1=ROUNDROBIN , 2=WEIGHTBASED -->
                <property name="loadbalance">1</property>
                <property name="poolNames">slave1,slave2</property>
              </poolConfig>
            </dbServer>

            分配读写使用的数据库  

            <queryRouter class="com.meidusa.amoeba.mysql.parser.MysqlQueryRouter">
              <property name="ruleConfig">${amoeba.home}/conf/rule.xml</property>
              <property name="functionConfig">${amoeba.home}/conf/functionMap.xml</property>
              <property name="ruleFunctionConfig">${amoeba.home}/conf/ruleFunctionMap.xml</property>
              <property name="LRUMapSize">1500</property>
              <property name="defaultPool">master</property>
              <property name="writePool">master</property>
              <property name="readPool">virtualSlave</property>
              <property name="needParse">true</property>
            </queryRouter>

            修改权限文件

          <amoeba:rule xmlns:amoeba="http://amoeba.meidusa.com/"> 

            <tableRule name="test_horiz" schema="test" defaultPools="master">

              <rule name="rule1">
                <parameters>ID</parameters>
                <expression><![CDATA[ ID <= 1000000]]></expression>
                <defaultPools>master</defaultPools>
                <readPools>slave1</readPools>
                <writePools>master</writePools>
              </rule>

              <rule name="rule2">    

                ==========

                <expression><![CDATA[ ID between 1000001 and 2000000 ]]></expression>

                <defaultPools>master</defaultPools>

                <writePools>master2</writePools>

                <readPools>slave2</readPools>

              </rule>

              <rule name="rule3">

                ==========

                <expression><![CDATA[ ID > 20000000 ]]></expression>

                <defaultPools>master</defaultPools>

              </rule>  

            </tableRule>

          

            <tableRule name="master" schema="test" defaultPools="master"/>
            <tableRule name="slave1" schema="test" defaultPools="slave1"/>
            <tableRule name="slave2" schema="test" defaultPools="slave1"/>
            <tableRule name="master" schema="t" defaultPools="master"/>

          </amoeba:rule>

  三.主从复制

    1、修改MySql配置文件my.cnf

      mast(主库)配置文件:

        server-id = 4308
        log-bin = mysql-bin
        log-bin-index = mysql-bin.index
        binlog-do-db= ng_base
        binlog-do-db= ng_push
        binlog-ignore-db = test
        binlog-ignore-db = mysql
        binlog-ignore-db = information_schema

      slave(从库1)配置文件:

        server-id = 4307

        log-bin = mysql-bin
        log-bin-index = mysql-bin.index
        relay-log = slave-relay-bin
        relay-log-index = slave-relay-bin.index
        sync_master_info = 1
        sync_relay_log = 1
        sync_relay_log_info = 1

  二、配置主从复制  

    1、主库操作

      授权给从数据库服务器192.168.10.131
      mysql> GRANT REPLICATION slave ON *.* to 'rep1'@'192.168.10.131' identified by ‘root4308’;

      查询主数据库状态
      Mysql> show master status;

        | File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
        +------------------+----------+--------------+------------------+
        | mysql-bin.000005 | 261 | | |

 

    -- SLAVE STOP;

    2、 从库操作

    change master to
    master_host='101.201.140.214',
    master_user='slave',
    master_password='root4308',
    master_log_file='binlog.000005',
    master_log_pos=107;

    正确执行后启动Slave同步进程

    SLAVE START;

    可以使用show slave status\G检查

          

linux上使用amoeba实现MySql集群,以及读写分离,主从复制的更多相关文章

  1. 2.Mysql集群------Mycat读写分离

    前言: Mycat: 一个彻底开源的,面向企业应用开发的大数据库集群 支持事务.ACID.可以替代MySQL的加强版数据库 一个可以视为MySQL集群的企业级数据库,用来替代昂贵的Oracle集群 一 ...

  2. mycat+mysql集群:实现读写分离,分库分表

    1.mycat文档:https://github.com/MyCATApache/Mycat-doc       官方网站:http://www.mycat.org.cn/ 2.mycat的优点: 配 ...

  3. 在Linux上使用Nginx为Solr集群做负载均衡

    在Linux上使用Nginx为Solr集群做负载均衡 在Linux上搭建solr集群时需要用到负载均衡,但测试环境下没有F5 Big-IP负载均衡交换机可以用,于是先后试了weblogic的proxy ...

  4. atlas+mysql主主集群实现读写分离

     atlas+mysql主主集群实现读写分离 前言: 目前线上系统数据库采用的是主主架构.其中一台主仅在故障时切换使用,(仅单台服务器对外提供服务,当一台出现问题,切换至另一台).该结构很难支撑较大并 ...

  5. Mysql数据库优化一:集群(读写分离)之主从服务器的安装与配置

    Mysql数据库的集群(读写分离),说白了就是将读操作和写操作分开在不同的服务器上实现,以达到提高效率的目的. 大致原理如下: 数据库中的所有操作都是有日志记录的(前提是要打开这个日志记录功能) 1. ...

  6. Linux上搭建Hadoop2.6.3集群以及WIN7通过Eclipse开发MapReduce的demo

    近期为了分析国内航空旅游业常见安全漏洞,想到了用大数据来分析,其实数据也不大,只是生产项目没有使用Hadoop,因此这里实际使用一次. 先看一下通过hadoop分析后的结果吧,最终通过hadoop分析 ...

  7. mysql与mycat搭建实现集群与读写分离

    数据库性能优化普遍采用集群方式,oracle集群软硬件投入昂贵,今天花了一天时间搭建基于mysql的集群环境. 主要思路 简单说,实现mysql主备复制-->利用mycat实现负载均衡. 比较了 ...

  8. windowsxp下的mysql集群技术

    1.准备工作 a.系统环境为:Windows Xp系统 b.mysql版本为:MySQL Server 5.5 c.mysql cluster版本为:mysql-cluster-gpl-noinsta ...

  9. 170711、Linux下搭建MySQL集群

    一.MySQL集群简介 1.什么是MySQL集群 MySQL集群是一个无共享的(shared-nothing).分布式节点架构的存储方案,其目的是提供容错性和高性能. 数据更新使用读已提交隔离级别(r ...

随机推荐

  1. The first documents

    Mark~ 赶在2016年的年末,来开了一个blog. 想想以前开设的blog还是十多年前,时光飞逝~~ 开设这个blog的主要目的是用于自己平时一些知识的记录. 希望能在未来很长一段时间能坚持学习与 ...

  2. Linux MySQL源码安装缺少ncurses-devel包

    在Red Hat Enterprise Linux Server release 5.7 上用源码安装MySQL-5.6.23时,遇到了" remove CMakeCache.txt and ...

  3. UML- 模型图介绍

    第一类 用例图 第二类 静态图 类图  对象图  包图第三类 行为图 状态图  活动图第四类 交互图 序列图 协助图第五类 实现图  构件图 部署图 1 用例图:从用户角度描述系统功能,以及每个系统功 ...

  4. smarty练习:数据的增删改

    根据数据库中的三张表格:timu,xuanxiang,kemu来进行数据的增删改查,并且使用smarty模版将前端与后台分离开来 三张表格: 主页面后台 main.php: <?php //引入 ...

  5. AIDL原理解析

    首先为什么需要aidl? 下面是不需要aidl 的binder的IPC通讯过程,表面上结构很简单,但是有个困难就是,客户端和服务端进行通讯,你得先将你的通讯请求转换成序列化的数据,然后调用transa ...

  6. 「设计模式」JavaScript - 设计模式之单例模式与场景实践

    单例介绍 上次总结了设计模式中的module模式,可能没有真真正正的使用在场景中,发现效果并不好,想要使用起来却不那么得心应手, 所以这次我打算换一种方式~~从简单的场景中来看单例模式, 因为Java ...

  7. 1018关于MySQL复制搭建[异步复制和半同步复制]

    转自:http://www.cnblogs.com/ivictor/p/5735580.html 搭建MySQL数据库的主从架构,还是蛮简单的.重要的几个命令整理一下. 主从服务器上: SHOW VA ...

  8. selenium 常见面试题以及答案

    1.怎么 判断元素是否存在? 判断元素是否存在和是否出现不同, 判断是否存在意味着如果这个元素压根就不存在, 就会抛出NoSuchElementException 这样就可以使用try catch,如 ...

  9. 查询执行成本高(查询访问表数据行数多)而导致实例 CPU 使用率高是 MySQL 非常常见的问题

    MySQL CPU 使用率高的原因和解决方法_产品性能_常见问题_云数据库 RDS 版-阿里云 https://help.aliyun.com/knowledge_detail/51587.html ...

  10. Win10 注册IIs4.0的解决方案

    随着Win10的出现,越来越多的人装上了Win10,尤其是程序员,由于Win10是一个新的操作系统,但现有软件的兼容性等各方面都是未知,难免会存在很多坑,就拿IIS来说,我刚装完win10系统,然后装 ...