一、在业务复杂的系统中,有这么一个情景,有一句sql语句须要锁表,致使暂时不能使用读的服务,那么就很影响运行中的业务,使用主从复制,让主库负责写,从库负责读,这样,即便主库出现了锁表的情景,经过读从库也能够保证业务的正常运做。
二、作数据的热备
三、架构的扩展。业务量愈来愈大,I/O访问频率太高,单机没法知足,此时作多库的存储,下降磁盘I/O访问的频率,提升单个机器的I/O性能。
mysql主从复制是一个异步的复制过程,主库发送更新事件到从库,从库读取更新记录,并执行更新记录,使得从库的内容与主库保持一致。java
1:简单来讲,读写分离就是只在主服务器上写,只在从服务器上读。由于Mysql在写入数据时会锁定表或者行,因此须要将读写分离开,实现写的同时也能读取数据。mysql
2: Amoeba是一个以MySQL为底层数据存储,并对应用提供MySQL协议接口的proxy。它集中地响应应用的请求,依据用户事先设置的规则,将SQL请求发送到特定的数据库上执行。基于此能够实现负载均衡、读写分离、高可用性等需求。与MySQL官方的MySQL Proxy相比,做者强调的是amoeba配置的方便(基于XML的配置文件,用SQLJEP语法书写规则,比基于lua脚本的MySQL Proxy简单)。
3:Amoeba至关于一个SQL请求的路由器,目的是为负载均衡、读写分离、高可用性提供机制,而不是彻底实现它们。用户须要结合使用MySQL的 Replication等机制来实现副本同步等功能。linux
主机 | IP | 主要软件 |
---|---|---|
主服务器 | 192.168.126.129 | mysql-5.7.1七、 ntp 、boost_1_59_0.tar |
从服务器1 | 192.168.126.130 | mysql-5.7.17 、 ntp 、boost_1_59_0.tar |
从服务器2 | 192.168.126.131 | mysql-5.7.17 、 ntp 、boost_1_59_0.tar |
Amoeba | 192.168.126.132 | amoeba-mysql-binary-2.2.0.tar、 jdk-6u14-linux-x64 |
客户端 | 192.168.126.133 | mysql-5.7.17 |
Mysql主从复制详细配置:http://www.javashuo.com/article/p-qfmlmgtt-vc.html
在三台mysql上添加权限开放给amoeba访问:
mysql> grant all on . to test@'192.168.126.%' identified by '123.com';sql
搭建MySQL读写分离数据库
# systemctl stop firewalld.service //关闭防火墙 # setenforce 0 # cp jdk-6u14-linux-x64.bin /usr/local/ # cd /usr/local # ./jdk-6u14-linux-x64.bin //按 “回车键” 输入“ yes“” 回车 # mv jdk1.6.0_14/ /usr/local/jdk1.6
.vim
# vi /etc/profile //添加环境变量 添加到末行 export JAVA_HOME=/usr/local/jdk1.6 export CLASSPATH=$CLASSPATH:$JAVA_HOME/lib:$JAVA_HOME/jre/lib export PATH=$JAVA_HOME/lib:$JAVA_HOME/jre/bin/:$PATH:$HOME/bin export AMOEBA_HOME=/usr/local/amoeba export PATH=$PATH:$AMOEBA_HOME/bin # source /etc/profile //刷新环境变量
. 服务器
# mkdir /usr/local/amoeba # tar zxvf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba/ # chmod -R 755 /usr/local/amoeba/ # /usr/local/amoeba/bin/amoeba (显示amoeba start|stop说明安装成功)
配置amoeba服务架构
# vim /usr/local/amoeba/conf/amoeba.xml --30行-- <property name="user">amoeba</property> --32行-- <property name="password">123456</property> --115行-- <property name="defaultPool">master</property> --117-去掉注释- <property name="writePool">master</property> <property name="readPool">slaves</property> # vi conf/dbServers.xml -23行注释掉 做用:默认进入test库 以防mysql中没有test库时,会报错 <!-- <property name="schema">test</property> --> --26--29--去掉注释-- <property name="user">test</property> <property name="password">123.com</property> -----42-主服务器地址--- <dbServer name="master" parent="abstractServer"> <property name="ipAddress">192.168.126.129</property> --52-从服务器主机名- <dbServer name="slave1" parent="abstractServer"> --55-从服务器1地址- <property name="ipAddress">192.168.126.130</property> --(这里上面6行复制)从服务器2地址 <dbServer name="slave2" parent="abstractServer"> <property name="ipAddress">192.168.126.131</property> --64行-- <dbServer name="slaves" virtual="true"> --70行-- <property name="poolNames">slave1,slave2</property>
开启服务负载均衡
# /usr/local/amoeba/bin/amoeba start& # netstat -anpt | grep java //查看端口
客户机异步
# systemctl stop firewalld.service //关闭防火墙 # setenforce 0 # yum install -y mysql //安装mysql客户端 # mysql -u amoeba -p123456 -h 192.168.126.132 -P8066 //远程登陆mysql
主服务器
# mysql -u root -p mysql> create database zhang; mysql> use zhang; mysql> create table zang (id int(10),name varchar(10),address varchar(20));
两台从服务器
mysql> stop slave; //关闭同步 mysql> use zhang; 从服务器1 mysql> insert into zang values('2','zhang','this_is_slave1'); 从服务器2 mysq> insert into zang values('3','zhang','this_is_slave2');
主服务器
mysql> insert into zang values('1','zhang','this_is_master');
如图只能查看到 从服务器的数据
mysql> use zhang; mysql> select * from zang;
客户机
mysql> insert into zang values('5','zhang','write_test');
两台从服务器
mysql> start slave; //开启同步
MySQL 主从复制与读写分离部署成功