黃聰:Mysql主從配置,實現讀寫分離

大型網站爲了軟解大量的併發訪問,除了在網站實現分佈式負載均衡,遠遠不夠。到了數據業務層、數據訪問層,若是仍是傳統的數據結構,或者只是單單靠一臺服務器扛,如此多的數據庫鏈接操做,數據庫必然會崩潰,數據丟失的話,後果更是 不堪設想。這時候,咱們會考慮如何減小數據庫的聯接,一方面採用優秀的代碼框架,進行代碼的優化,採用優秀的數據緩存技術如:memcached,若是資金豐厚的話,必然會想到假設服務器羣,來分擔主數據庫的壓力。Ok切入今天微博主題,利用MySQL主從配置,實現讀寫分離,減輕數據庫壓力。這種方式,在現在不少網站裏都有使用,也不是什麼新鮮事情,今天總結一下,方便你們學習參考一下。mysql

概述:搭設一臺Master服務器(win8.1系統,Ip:192.168.0.104),搭設兩臺Slave服務器(虛擬機——一臺Ubuntu,一臺 Windows Server 2003)linux

原理:主服務器(Master)負責網站NonQuery操做,從服務器負責Query操做,用戶能夠根據網站功能模特性塊固定訪問Slave服務器,或者本身寫個池或隊列,自由爲請求分配從服務器鏈接。主從服務器利用MySQL的二進制日誌文件,實現數據同步。二進制日誌由主服務器產生,從服務器響應獲取同步數據庫。sql

具體實現:數據庫

一、在主從服務器上都裝上MySQL數據庫,windows系統鄙人安裝的是mysql_5.5.25.msi版本,Ubuntu安裝的是mysql-5.6.22-linux-glibc2.5-i686.tarvim

windows安裝mysql就不談了,通常地球人都應該會。鄙人稍微說一下Ubuntu的MySQL安裝,我建議不要在線下載安裝,仍是離線安裝的好。你們能夠參考  http://www.linuxidc.com/Linux/2013-01/78716.htm 這位不知道大哥仍是姐妹,寫的挺好按照這個就能裝上。在安裝的時候可能會出現幾種現象,你們能夠參考解決一下:windows

(1)若是您不是使用root用戶登陸,建議 su - root 切換到Root用戶安裝,那就不用總是 sudo 了。緩存

(2)存放解壓的mysql 文件夾,文件夾名字最好改爲mysql服務器

(3)在./support-files/mysql.server start 啓動MySQL的時候,可能會出現一個警告,中文意思是啓動服務運行讀文件時,忽略了my.cnf文件,那是由於my.cnf的文件權限有問題,mysql會認爲該文件有危險不會執行。可是mysql還會啓動成功,但若是下面配置從服務器參數修改my.cnf文件的時候,你會發現文件改過了,可是重啓服務時,修改事後的配置沒有執行,並且您 list一下mysql的文件夾下會發現不少.my.cnf.swp等中間文件。這都是由於MySQL啓動時沒有讀取my.cnf的緣由。這時只要將my.cnf的文件權限改爲my_new.cnf的權限同樣就Ok,命令:chmod 644 my.cnf就Ok數據結構

(4)Ubuntu中修改文檔內容沒有Vim,最好把Vim 裝上,apt-get install vim,否則估計會抓狂。併發

這時候我相信MySQL應該安裝上去了。

二、配置Master主服務器

(1)在Master MySQL上建立一個用戶‘repl’,並容許其餘Slave服務器能夠經過遠程訪問Master,經過該用戶讀取二進制日誌,實現數據同步。

1 mysql>create user repl; //建立新用戶
2 //repl用戶必須具備REPLICATION SLAVE權限,除此以外沒有必要添加沒必要要的權限,密碼爲mysql。說明一下192.168.0.%,這個配置是指明repl用戶所在服務器,這裏%是通配符,表示192.168.0.0-192.168.0.255的Server均可以以repl用戶登錄主服務器。固然你也能夠指定固定Ip。
3 mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.0.%' IDENTIFIED BY 'mysql';

(2)找到MySQL安裝文件夾修改my.Ini文件。mysql中有好幾種日誌方式,這不是今天的重點。咱們只要啓動二進制日誌log-bin就ok。

 在[mysqld]下面增長下面幾行代碼

1 server-id=1   //給數據庫服務的惟一標識,通常爲你們設置服務器Ip的末尾號
2 log-bin=master-bin
3 log-bin-index=master-bin.index

(3)查看日誌

mysql> SHOW MASTER STATUS;
+-------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+------------------+
| master-bin.000001 | 1285 | | |
+-------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

重啓MySQL服務

三、配置Slave從服務器(windows)

(1)找到MySQL安裝文件夾修改my.ini文件,在[mysqld]下面增長下面幾行代碼

1 [mysqld]
2 server-id=2
3 relay-log-index=slave-relay-bin.index
4 relay-log=slave-relay-bin 

重啓MySQL服務

(2)鏈接Master

change master to master_host='192.168.0.104', //Master 服務器Ip
master_port=3306,
master_user='repl',
master_password='mysql', 
master_log_file='master-bin.000001',//Master服務器產生的日誌
master_log_pos=0;

(3)啓動Slave

start slave;

四、Slave從服務器(Ubuntu)

(1)找到MySQL安裝文件夾修改my.cnf文件,vim my.cnf

 s

 

(2) ./support-files/myql.server restart 重啓MySQL服務  ,  ./bin/mysql 進入MySQL命令窗口 

(3)鏈接Master

change master to master_host='192.168.0.104', //Master 服務器Ip
master_port=3306,
master_user='repl',
master_password='mysql', 
master_log_file='master-bin.000001',//Master服務器產生的日誌
master_log_pos=0;

(4)啓動Slave

start slave;

OK全部配置都完成了,這時候你們能夠在Master Mysql 中進行測試了,由於咱們監視的時Master mysql  全部操做日誌,因此,你的任何改變主服務器數據庫的操做,都會同步到從服務器上。建立個數據庫,表試試吧。。。

相關文章
相關標籤/搜索