MySQL主從複製與讀寫分離

MySQL主從複製與讀寫分離
2016.3.16 by linuxfan.cn
環境介紹:
主服務器(master):192.168.100.155
從服務器(slave1,slave2):192.168.100.153-154
代理服務器(amoeba):192.168.100.156
應用客戶端(app):192.168.100.157

1.搭建時間服務器:
主節點上安裝ntp時間服務:192.168.100.155
yum -y install ntp
sed -i '/^server/s/^/#/g' /etc/ntp.conf
cat <<END >>/etc/ntp.conf
server 127.127.1.0
fudge 127.127.1.0 stratum 8
END
/etc/init.d/ntpd restart
netstat -utpln |grep ntp
從節點同步時間:192.168.100.153-154
yum -y install ntpdate
/usr/sbin/ntpdate 192.168.100.155

2.安裝mysql:192.168.100.153-155
wget ftp://ftp.linuxfan.cn/tools/lamp_install_publis-app-2015-07-16.tar.xz
tar Jxvf lamp_install_publis-app-2015-07-16.tar.xz
mysql_install.sh  
mysql_config.sh
reboot


提示:
[root@localhost ~]# cd bin/
[root@localhost bin]# cat mysql_install.sh
#!/bin/bash
##第一配置yum,安裝ncurses依賴包
yum -y install ncurses-*
#解壓cmake,安裝基礎環境
tar zxvf /root/cmake-2.8.6.tar.gz -C /usr/src/
cd /usr/src/cmake-2.8.6
#配置,編譯安裝cmake
./configure &&gmake &&gmake install
##解壓mysql
tar zxvf /root/mysql-5.5.22.tar.gz -C /usr/src/
cd /usr/src/mysql-5.5.22/
#cmake進行配置mysql
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql   #指定安裝目錄\
-DDEFAULT_CHARSET=utf8   #指定字符集爲utf8 \
-DDEFAULT_COLLATION=utf8_general_ci   ##指定字符校驗 \
-DWITH_EXTRA_CHARSETS=all   ##支持額外字符集\
-DSYSCONFDIR=/etc/  ##指定配置文件位置
make &&make install   #編譯安裝
if [ -e /usr/local/mysql ];then
echo "mysql install successfully."
fi
[root@localhost bin]#
[root@localhost bin]# cat mysql_config.sh
#!/bin/bash
#1.複製配置文件
cp /usr/src/mysql-5.5.22/support-files/my-medium.cnf /etc/my.cnf
#2.添加系統服務
cp /usr/src/mysql-5.5.22/support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
chkconfig --add mysqld
chkconfig mysqld  on
#3.優化PATH路徑,執行命令時方便,單引號雙引號都行
grep mysql /etc/profile
if [ $? -eq 0 ];then
echo "PATH is set."
else
echo "export PATH=$PATH:/usr/local/mysql/bin"  >>/etc/profile
source /etc/profile  ##執行文件
fi
#4.初始化mysql,創建用戶,賦權
useradd -M -s /sbin/nologin mysql
chown -R mysql:mysql /usr/local/mysql
/usr/local/mysql/scripts/mysql_install_db  \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data --user=mysql
#5.啓動mysql,並設置爲開機啓動
if [ -e /tmp/mysql.sock ];then
/etc/init.d/mysqld restart
else
/etc/init.d/mysqld start
fi
chkconfig mysqld on
#6.修改密碼,並提示密碼
mysqladmin -u root password '123123'  &&echo "mysql root password is 123123"

3.配置MySQL主從複製:
1)主服務器配置:192.168.100.155
sed -i 's/^log-bin=.*/log-bin=master-bin\nlog-slave-updates=ture/g' /etc/my.cnf
sed -i '/^server-id/s/1/11/g' /etc/my.cnf
/etc/init.d/mysqld restart
mysql -uroot -p123123
mysql> grant replication slave on *.* to 'myslave'@'192.168.100.%' identified by '123123';
mysql> flush privileges;
mysql> show master status;  ##記住File的及Position的值,此處爲master-bin.000001和337
mysql> create database db_test;  ##創建測試數據庫
mysql> quit
2)配置從服務器1:192.168.100.153
sed -i '/^server-id/s/1/22/g' /etc/my.cnf
sed -i '/^server-id/arelay-log=relay-log-bin\nrelay-log-index=slave-relay-bin.index' /etc/my.cnf
/etc/init.d/mysqld restart
mysql -uroot -p123123
mysql> change master to master_host='192.168.100.155',master_user='myslave',master_password='123123',master_log_file='master-bin.000001',master_log_pos=337;
mysql> start slave;
mysql> show slave status\G;  ##查看無error即可
mysql> show databases;  ##驗證數據庫是否同步
mysql> quit
3)配置從服務器2:192.168.100.154
sed -i '/^server-id/s/1/33/g' /etc/my.cnf
sed -i '/^server-id/arelay-log=relay-log-bin\nrelay-log-index=slave-relay-bin.index' /etc/my.cnf
/etc/init.d/mysqld restart
mysql -uroot -p123123
mysql> change master to master_host='192.168.100.155',master_user='myslave',master_password='123123',master_log_file='master-bin.000001',master_log_pos=337;
mysql> start slave;
mysql> show slave status\G;  ##查看無error即可
mysql> show databases;  ##驗證數據庫是否同步
mysql> quit

4.搭建MySQL讀寫分離:
1)安裝軟件:192.168.100.156
lftp ftp.linuxfan.cn
>cd tools/
>get amoeba-mysql-binary-2.2.0.tar.gz jdk-6u14-linux-x64.bin
>bye
yum -y remove java
chmod +x jdk-6u14-linux-x64.bin
./jdk-6u14-linux-x64.bin
mv jdk1.6.0_14/ /usr/local/jdk1.6
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
:wq
source /etc/profile
java -version
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  ##驗證
2)數據授權給amoeba讀寫權限:
mysql> grant all on *.* to linuxfan@'192.168.100.%' identified by '123123';   ##在192.168.100.155上完成
mysql> show grants for linuxfan@'192.168.100.%';   ##在192.168.100.153-154上查看是否同步了權限
3)修改配置文件:192.168.100.156
vim /usr/local/amoeba/conf/amoeba.xml
30                                         <property name="user">amoeba</property>
31
32                                         <property name="password">123456</property>
115                 <property name="defaultPool">master</property>
116
117                 <property name="writePool">master</property>   ##注意刪除<!--  -->的註釋
118                 <property name="readPool">slaves</property>
:set nu  ##顯示行號
:wq

vim /usr/local/amoeba/conf/dbServers.xml
25                         <!-- mysql user -->
26                         <property name="user">linuxfan</property>   ##該用戶必須是上一步授權的用戶
27                        
28                         <!--  mysql password -->   ##修改
29                         <property name="password">123123</property>  ##刪除下一行的“-->”
44         <dbServer name="master"  parent="abstractServer">   ##修改爲master
45                 <factoryConfig>
46                         <!-- mysql ip -->
47                         <property name="ipAddress">192.168.100.155</property>  ##指定正確的master的ip
51         <dbServer name="slave1"  parent="abstractServer">  ##修改爲slave1
52                 <factoryConfig>
53                         <!-- mysql ip -->
54                         <property name="ipAddress">192.168.100.153</property>  ##指定slave1的ip地址
55                 </factoryConfig>
56         </dbServer>
57         <dbServer name="slave2"  parent="abstractServer">  ##添加如下6行,指定slave2的ip
58                 <factoryConfig>
59                         <!-- mysql ip -->
60                         <property name="ipAddress">192.168.100.154</property>
61                 </factoryConfig>
62         </dbServer>
64         <dbServer name="slaves" virtual="true">  ##修改爲slaves
70                         <property name="poolNames">slave1,slave2</property>  ##修改集羣的成員名稱用逗號隔開
:wq
/usr/local/amoeba/bin/amoeba start&   ##啓動代理服務
netstat -utpln |grep 8066  ##驗證


5.測試讀寫分離
1)驗證主從複製:192.168.100.157
yum -y install mysql
mysql -uamoeba -p123456 -h 192.168.100.156 -P 8066   ##登錄db集羣192.168.100.157
mysql>show databases;
mysql> use db_test;
mysql> create table linuxfan(id int(10),name varchar(10),address varchar(20));
在192.168.100.153-155上查看結果:
mysql -uroot -p123123
mysql> use db_test;
mysql> show tables;   ##已然同步

2)關閉slave1,slave2的複製功能:192.168.100.153-154
mysql> stop slave;

3)分別在master,slave1,slave2上創建不同的數據:
master:
mysql> insert into linuxfan values(1,'hehe','this is master');
slave1:
mysql> insert into linuxfan values(2,'hehe','this is slave1');
slave2:
mysql> insert into linuxfan values(3,'hehe','this is slave2');

4)應用客戶端驗證讀:192.168.100.157
mysql> select * from linuxfan;  ##第一次查詢
+------+------+----------------+
| id   | name | address        |
+------+------+----------------+
|    2 | hehe | this is slave1 |
+------+------+----------------+
1 row in set (0.02 sec)

mysql> select * from linuxfan;   ##第二次查詢
+------+------+----------------+
| id   | name | address        |
+------+------+----------------+
|    3 | hehe | this is slave2 |
+------+------+----------------+
1 row in set (0.01 sec)
mysql> select * from linuxfan;   ##第三次查詢
+------+------+----------------+
| id   | name | address        |
+------+------+----------------+
|    2 | hehe | this is slave1 |
+------+------+----------------+
1 row in set (0.00 sec)

5)應用客戶端上驗證寫:
mysql> insert into linuxfan values(4,'hehe','app write test');  ##寫入數據
Query OK, 1 row affected (0.02 sec)

mysql> select * from linuxfan;   ##查不到剛寫入的數據
+------+------+----------------+
| id   | name | address        |
+------+------+----------------+
|    3 | hehe | this is slave2 |
+------+------+----------------+
1 row in set (0.01 sec)

master上驗證:
mysql> select * from linuxfan;   ##查到數據
+------+------+----------------+
| id   | name | address        |
+------+------+----------------+
|    1 | hehe | this is master |
|    4 | hehe | app write test |
+------+------+----------------+
2 rows in set (0.00 sec)

總結:
app寫入數據時,amoeba會將數據路由到master上進行存儲,app讀取數據時,amoeba會將讀的請求一輪詢的方式發給slaves組(slave1+slave2),實現讀寫分離。
master和slaves間配置了主從複製,保證了數據的一致性。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章