准备

下载如下linux安装包

jdk-6u31-linux-x64-rpm.bin

amoeba-mysql-binary-2.2.0.tar.gz

# crontab -e  //同步时间

*/ * * * * /usr/sbin/ntpdate 172.16.0.1 &>/dev/null

# service iptables stop  //这几台服务器都要关闭防火墙

配置主从复制架构: 多主机 (ip和名称定义)

192.168.1.25  master

192.168.1.30  slave1

192.168.1.35  slave2

192.168.1.147  amoeba

正式开始...

1.java

安装java

# cp jdk-6u31-linux-x64-rpm.bin /usr/local/

# cd /usr/local

# chmod +x jdk-6u31-linux-x64-rpm.bin

# ./jdk-6u31-linux-x64-rpm.bin

加入环境变量

# vi /etc/profile.d/java.sh

export JAVA_HOME=/usr/java/latest

export PATH=$JAVA_HOME/bin:$PATH

验证jdk

# source /etc/profile //必须加上这句使java配置生效

# java -version

2.安装amoeba

# mkdir -p /usr/local/amoeba

# tar xf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba  //使用二进制安装

# cd /usr/local/amoeba

# bin/amoeba start  //前台运行

# nohup /usr/local/amoeba/bin/amoeba start &  //后台运行

3.配置amoeba

# cd /usr/local/amoeba/conf

# vi ameoba.xml  //前端配置文件, amoeba接口配置信息

<property name=</property>  <!-- amoeba被访问的端口 -->

<property name="user">root</property>  <!-- 用户名 -->

<property name="password"></property>  <!-- 密码 -->

<property name="defaultPool">wp</property>  <!-- 默认服务器池 -->

<property name="writePool">wp</property>  <!-- 写操作的虚拟服务器池 -->

<property name="readPool">rp</property>  <!-- 读操作的虚拟服务器池 -->

# vi dbServers.xml  //后端配置文件, amoeba访问mysql的配置信息

<property name=</property>  <!-- mysql被访问的端口 -->

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

<property name="user">root</property>  <!-- mysql用户名 -->

<property name="password"></property>  <!-- mysql密码 -->

<!-- 主服务器 -->

<dbServer name="master"  parent="abstractServer">

      <factoryConfig>

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

      </factoryConfig>

</dbServer>

<!-- 从服务器1 -->

<dbServer name="slave1"  parent="abstractServer">

      <factoryConfig>

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

      </factoryConfig>

</dbServer>

<!-- 从服务器2 -->

<dbServer name="slave2"  parent="abstractServer">

      <factoryConfig>

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

      </factoryConfig>

</dbServer>

<!-- 写池: master -->

<dbServer name="wp" virtual="true">

      <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool">

            <property name=</property>

            <property name="poolNames">master</property>

      </poolConfig>

</dbServer>

<!-- 读池: slave1,slave2 -->

<dbServer name="rp" virtual="true">

      <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool">

            <property name=</property>  <!-- 1表示轮询 -->

            <property name="poolNames">slave1,slave2</property>

      </poolConfig>

</dbServer>

4.测试:

从amoeba接口登录, 创建数据库db2后,再从主库的接口中去查询数据库是否已创建,如是则说明写入确实是落在了主库节点上

若要验证ameoba对于读操作的调度,则需要暂时停止从库的复制操作,然后在主库上更新数据,这样从ameoba接口登录来读取数据将出现不一致的情况

;

mysql系列之7.mysql读写分离的更多相关文章

  1. Mysql主从配置,实现读写分离

    大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...

  2. 分布式架构高可用架构篇_08_MyCat在MySQL主从复制基础上实现读写分离

    参考: 龙果学院http://www.roncoo.com/share.html?hamc=hLPG8QsaaWVOl2Z76wpJHp3JBbZZF%2Bywm5vEfPp9LbLkAjAnB%2B ...

  3. 黄聪:Mysql主从配置,实现读写分离

    大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...

  4. Mysql 之主从复制,mysql-proxy读写分离

    准备两台mysql服务器,master(192.168.43.64).slave(192.168.84.129) master配置: log-bin=mysql-bin binlog_format=m ...

  5. Mysql多实例安装+主从复制+读写分离 -学习笔记

    Mysql多实例安装+主从复制+读写分离 -学习笔记 .embody{ padding:10px 10px 10px; margin:0 -20px; border-bottom:solid 1px ...

  6. 高可用架构篇--MyCat在MySQL主从复制基础上实现读写分离

    实战操作可参考:http://www.roncoo.com/course/view/3117ffd4c74b4a51a998f9276740dcfb 一.环境 操作系统:CentOS-6.6-x86_ ...

  7. docker配置mysql主从与django实现读写分离

    一.搭建主从mysql环境 1 下载mysql镜像 docker pull mysql:5.7 2 运行刚下载的mysql镜像文件 # 运行该命令之前可以使用`docker images`是否下载成功 ...

  8. linux上使用amoeba实现MySql集群,以及读写分离,主从复制

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

  9. mysql主从复制 主主复制 读写分离

    首先是mysql的主从复制很简单 主主复制也就是互相主从最麻烦的最难的就是日志恢复,增量恢复什么的比较复杂 首先如果你不会安装mysql版本最好一样,或者往上的版本,因为mysql是向下兼容 请注意不 ...

  10. MySQL深入利用Ameoba实现读写分离

    3 ameoba安装配置   3.1 安装配置JDK [root@stu15 ~]# rpm -ivh jdk-7u67-linux-x64.rpm [root@stu15 ~]# cd /usr/j ...

随机推荐

  1. fauxbar.bak

    {"options": { "almostdone":"0", "backup_searchEngines":" ...

  2. 卸载django

    首先找到django安装路径 Python import sys; sys.path = sys.path[1:]; import django; print(django.__path__) 得到 ...

  3. Drools环境搭建

    Eclipse3.5安装Drools6.5.0.Final插件 到Drools下载页面(现在是http://www.jboss.org/drools/downloads.html) -下载并解压Dro ...

  4. js 展开&收缩 二种

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. 【React Native开发】React Native控件之DrawerLayoutAndroid抽屉导航切换组件解说(13)

    ),请不要反复加群! 欢迎各位大牛,React Native技术爱好者增加交流!同一时候博客左側欢迎微信扫描关注订阅号,移动技术干货,精彩文章技术推送! 该DrawerLayoutAndroid组件封 ...

  6. MySQL 函数笔记

    统计相关函数 COUNT和SUM函数使用小技巧 参考自: MySQL - Conditional COUNT with GROUP BY 在一个 SQL 中统计多个指标的个数: SELECT COUN ...

  7. .NET面试题汇总

    目录 本次给大家介绍的是我收集以及自己个人保存一些.NET面试题 简介 1.C# 值类型和引用类型的区别 2.如何使得一个类型可以在foreach 语句中使用 3.sealed修饰的类有什么特点 4. ...

  8. python中executemany的使用

    conn = MySQLdb.connect(host = “localhost”, user = “root”, passwd = “password”, db = “myDB”, charset= ...

  9. Redis主从同步分析

    一.Redis主从同步原理1.1 Redis主从同步的过程配置好slave服务器连接的master后,slave会建立和master的连接,然后发送sync命令.无论是第一次同步建立的连接还是连接断开 ...

  10. 浏览器前缀-----[译]Autoprefixer:一个以最好的方式处理浏览器前缀的后处理程序

    Autoprefixer解析CSS文件并且添加浏览器前缀到CSS规则里,使用Can I Use的数据来决定哪些前缀是需要的.   所有你需要做的就是把它添加到你的资源构建工具(例如 Grunt)并且可 ...