詳解MySQL主從復(fù)制讀寫分離搭建
MySQL主從設(shè)置
MySQL主從復(fù)制,讀寫分離的設(shè)置非常簡單:
修改配置my.cnf文件
master 和 slave設(shè)置的差不多:
[mysqld] log-bin=mysql-bin server-id=222
log-bin=mysql-bin
的意思是:啟用二進(jìn)制日志。
server-id=222
的意思是設(shè)置了服務(wù)器的唯一ID,默認(rèn)是1,一般取IP最后一段,可以寫成別的,只要不和其他mysql服務(wù)器重復(fù)就好。
這里,有的MySQL默認(rèn)的my.cnf
文件引用了/etc/mysql/conf.d
路徑下的所有cnf文件,因此,也可以在/etc/mysql/conf.d
目錄下添加一個(gè)cnf文件,添加上以上內(nèi)容
分別重啟master和slave機(jī)器的mysql
/etc/init.d/mysql restart
master上建立賬戶并授權(quán)slave,slave上也做好相關(guān)配置
用root用戶分別登錄master和slave機(jī)器:
mysql -uroot -p //輸入之后會(huì)讓你輸入root密碼,輸入root密碼就算登陸了
master機(jī)器上
建立賬戶并授權(quán)slave機(jī)器,注意用戶名和密碼,可以隨意設(shè)置,但是一定要記下來,因?yàn)楹竺鎠lave還需要用到
GRANT REPLICATION SLAVE ON *.* to 'ryugou'@'%' identified by 'ryugou';
一般不用root帳號(hào),@'%'表示所有客戶端都可能連,只要帳號(hào),密碼正確,此處可用具體客戶端IP代替,如192.168.145.226,加強(qiáng)安全。
slave機(jī)器上
查看master狀態(tài)
show master status;
在mysql終端輸入
change master to master_host='xxx.xxx.xxx.xxx',master_user='ryugou',master_password='ryugou',master_log_file='mysql-bin.000004',master_log_pos=120;
master_log_file就是master機(jī)器上的對(duì)應(yīng)的內(nèi)容,master_log_pos也是,注意查看master狀態(tài)上的內(nèi)容。
master_user和master_password就是master機(jī)器上授權(quán)時(shí)設(shè)置用戶名和密碼。
啟動(dòng)從服務(wù)器
start slave;
檢查從服務(wù)器復(fù)制功能狀態(tài)
show slave status\G;
會(huì)出現(xiàn)一個(gè)列表
主要看Slave_IO_Running和Slave_SQL_Running 這倆狀態(tài)必須都為Yes。
master創(chuàng)建數(shù)據(jù)庫,從服務(wù)器設(shè)置用戶訪問權(quán)限
在master上創(chuàng)建數(shù)據(jù)庫 test,會(huì)發(fā)現(xiàn)在slave上也創(chuàng)建了 test,現(xiàn)在想要讀寫分離,slave上的機(jī)器某用戶gou可以訪問它,但是只能讀
grant select on test.* to gou;
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持本站。
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。