主服务器mysql 配置:
vim /etc/my.cnf server-id = 1 log-bin=master-bin #添加,主服务器开启二进制日志 log-slave-updates=true #添加,允许从服务器更新二进制日志 systemctl restart mysqld mysql -u root -p GRANT REPLICATION SLAVE ON *.* TO 'myslave'@'20.0.0.%' IDENTIFIED BY 'abc123'; #给从服务器授权 FLUSH PRIVILEGES; show master status; #File 列显示日志名,Fosition 列显示偏移量
从服务器1,2的mysql 配置:(两台从服务器server-id 不要重复)
vim /etc/my.cnf server-id = 2 #修改,注意id与Master的不同,两个Slave的id也要不同 relay-log=relay-log-bin #添加,开启中继日志,从主服务器上同步日志文件记录到本地 relay-log-index=slave-relay-bin.index #添加,定义中继日志文件的位置和名称 systemctl restart mysqld mysql -u root -p change master to master_host='20.0.0.42' , master_user='myslave',master_password='abc123',master_log_file='master-bin.000002',master_log_pos=604; #配置同步,注意 master_log_file 和 master_log_pos 的值要与Master查询的一致,这里的是例子,每个人的都不一样 start slave; #启动同步,如有报错执行 reset slave; show slave status\G #查看 Slave 状态 //确保 IO 和 SQL 线程都是 Yes,代表同步正常。 Slave_IO_Running: Yes #负责与主机的io通信 Slave_SQL_Running: Yes #负责自己的slave mysql进程
一般 Slave_IO_Running: No 的可能性:
网络不通
my.cnf配置有问题
密码、file文件名、pos偏移量不对
防火墙没有关闭
切记2台从服务器都要配置,server-id 不能重复 配置完该重启的重启该启动的启动
验证主从复制:主服务器创建一个库,再去从服务器查看库:
打开从服务器1,2查看发现已经有了
搭建读写分离:
安装JAVA环境、amoeba 软件:
因为 Amoeba 基于是 jdk1.5 开发的,所以官方推荐使用 jdk1.5 或 1.6 版本,高版本不建议使用。 将jdk-6u14-linux-x64.bin 和 amoeba-mysql-binary-2.2.0.tar.gz.0 上传到/opt目录下。 cd /opt/ cp jdk-6u14-linux-x64.bin /usr/local/ cd /usr/local/ chmod +x jdk-6u14-linux-x64.bin ./jdk-6u14-linux-x64.bin 按空格到最后一行 按yes,按enter mv jdk1.6.0_14/ /usr/local/jdk1.6 vim /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 java -version ##安装 Amoeba软件## mkdir /usr/local/amoeba tar zxvf /opt/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读写分离,两个 Slave 读负载均衡:
先在主服务器从服务器1,2的mysql上开放权限给 Amoeba 访问
grant all on *.* to test@'20.0.0.%' identified by '123.com';
amoeba服务器配置amoeba服务:
cd /usr/local/amoeba/conf/ cp amoeba.xml amoeba.xml.bak vim amoeba.xml
30修改
<property name="user">amoeba</property>
32修改
<property name="password">abc123</property>
115修改
<property name="defaultPool">master</property>
117去掉注释–
<property name="writePool">master</property> <property name="readPool">slaves</property>
cp dbServers.xml dbServers.xml.bak
vim dbServers.xml #修改数据库配置文件
23注释掉
作用:默认进入test库 以防mysql中没有test库时,会报错
<!-- mysql schema <property name="schema">test</property> --><em id="__mceDel"> </em>
26修改
<!-- mysql user --> <property name="user">test</property>
28去掉注释
<property name="password">123.com</property>
45修改,
<dbServer name="master" parent="abstractServer">
48修改,
<property name="ipAddress">20.0.0.42</property>
52修改,
<dbServer name="slave1" parent="abstractServer">
55修改,设置从服务器1的地址
<property name="ipAddress">20.0.0.41</property>
复制上面6行粘贴,设置从服务器2的名slave2和地址
<dbServer name="slave2" parent="abstractServer"> <property name="ipAddress">20.0.0.37</property>
65修改
<dbServer name="slaves" virtual="true">
71修改
<property name="poolNames">slave1,slave2</property>
/usr/local/amoeba/bin/amoeba start& #启动Amoeba软件,按ctrl+c 返回
netstat -napt | grep java
测试读写分离:
在客户端服务器上进行测试:
使用yum快速安装MySQL虚拟客户端
yum install -y mysql mysql-server mysql -u amoeba -pabc123 -h 20.0.0.31 -P8066
主服务器:
use db_test; create table test (id int(10),name varchar(10),address varchar(20));
从服务器1,2 :
amoeba 客户端服务器上:
use db_test; select * from test; //客户端会分别向slave1和slave2读取数据,显示的只有在两个从服务器上添加的数据,没有在主服务器上添加的数据 insert into test values('4','qianqi','this_is_client'); //只有主服务器上有此数据
再在两个从服务器上执行 start slave; 即可实现同步在主服务器上添加的数据
start slave;