近期將公司的MySQL架構(gòu)升級(jí)了,由原先的一主多從換成了DRBD+Heartbeat雙主多從,正好手上有一個(gè)電子商務(wù)網(wǎng)站新項(xiàng)目也要上線了,用的是DRBD+Heartbeat雙主一從,由于此過(guò)程還是有別于以前的MyISAM引擎的,所以這里也將其心得歸納總結(jié)了一下:
1)MySQL的replication過(guò)程是一個(gè)異步同步的過(guò)程,并非完全的主從同步,所以同步的過(guò)程中是有延遲的,如果做了讀寫(xiě)分離的業(yè)務(wù)的話,建議也要監(jiān)控此延遲時(shí)間;
2)MySQL的master與slave機(jī)器記得server-id要保持不一致,如果一樣的話,replication過(guò)程中會(huì)出現(xiàn)如下報(bào)錯(cuò):
Fatal error: The slave I/O thread stops because master and slavehave equal MySQL server ids; these ids must be different for replication to work(or the --replicate-same-server-id option must be used on slave but this doesnot always make sense; please check the manual before using it).
這個(gè)問(wèn)題很好處理,即將slave機(jī)的server-id修改成跟master機(jī)器不一致即可。
3)我以前的一個(gè)誤區(qū)就是,slave機(jī)器是用自己的二進(jìn)制日志來(lái)完成replication過(guò)程的,其實(shí)不是這樣的,根據(jù)復(fù)制的工作原理:slave服務(wù)器是copy主服務(wù)器的二進(jìn)制日志到自己的中繼日志,即relay-log日志(即centos3-relay-bin.000002這種名字的)中,然后再把更新應(yīng)用用到自己的數(shù)據(jù)庫(kù)上,所以slave機(jī)器是不需要開(kāi)啟二進(jìn)制日志的,這樣過(guò)程一樣會(huì)成功的;除非是準(zhǔn)備做主主架構(gòu),這才需要slave機(jī)器開(kāi)啟二進(jìn)制日志,這個(gè)問(wèn)題一直在導(dǎo)著我,我以一直以為slave機(jī)器搭建replication環(huán)境時(shí)是一定要開(kāi)啟二進(jìn)制的,
4)在master機(jī)器上授權(quán)時(shí),盡量只給某一個(gè)或某幾個(gè)固定機(jī)器權(quán)限,讓它們只有replication slav,replication client權(quán)限,盡量不要給grant權(quán)限;另外,雖然數(shù)據(jù)庫(kù)我們一般是通過(guò)內(nèi)網(wǎng)操作,但越是在在內(nèi)網(wǎng)對(duì)MySQL數(shù)據(jù)庫(kù)進(jìn)行授權(quán)操作,越是要注意安全;
5)replication搭建過(guò)程按照正常流程走的話,一般很容易實(shí)施成功,如果出錯(cuò)的話,多檢查下網(wǎng)絡(luò)環(huán)境、權(quán)限問(wèn)題,一般來(lái)說(shuō)整個(gè)搭建過(guò)程應(yīng)該還是會(huì)比較順利的。
在數(shù)據(jù)庫(kù)設(shè)計(jì)初期,我已經(jīng)將此電子商務(wù)的數(shù)據(jù)庫(kù)引擎定義為InnoDB,除了數(shù)據(jù)庫(kù)中原有的系統(tǒng)表之外,其它表全部由MyISAM轉(zhuǎn)成了InnoDB,原因有二:
1)電子商務(wù)業(yè)務(wù)會(huì)涉及到交易付款,在這種基本OLTP的應(yīng)用中,InnoDB應(yīng)該作為核心應(yīng)用表的首選存儲(chǔ)引擎;
2)DRBD系統(tǒng)重啟時(shí)的過(guò)程會(huì)比較緩慢,會(huì)頻繁的讀表,如果表引擎為MyISAM的話極有可能出現(xiàn)損壞情況,為了造成不必要的問(wèn)題,我將數(shù)據(jù)庫(kù)的表引擎由MyISAM均轉(zhuǎn)成了InnoDB引擎的表。
DRBD+Heartbeat+MySQL參考以前的工作文檔,搭建的比較順利,就是在搭建replication環(huán)境時(shí)遇到了1062報(bào)錯(cuò),詳細(xì)過(guò)程如下:
初期參考MySQL手冊(cè)操作,取master機(jī)器的快照備份,用的是--single-transaction選項(xiàng),然后同步過(guò)程頻繁1062報(bào)錯(cuò),報(bào)錯(cuò)日志如下:
Last_SQL_Error: Error 'Duplicate entry 'd36ad91bff36308de540bbd9ae6f4279' for key 'PRIMARY'' on query. Default database: 'myproject'. Query: 'INSERT INTO `lee_sessions` (`session_id`, `ip_address`, `user_agent`, `last_activity`, `user_data`) VALUES ('d36ad91bff36308de540bbd9ae6f4279', '180.153.201.218', 'Mozilla/4.0', 1353394206, '')'
后來(lái)改變思路,用--master-data選項(xiàng)來(lái)取主master快照備份,命令如下所示:
mysqldump -uroot --quick --flush-logs --master-data=1 -p myproject > myproject.sql
InnoDB引擎數(shù)據(jù)庫(kù)主從復(fù)制同步更新的分享
2019-12-13 11:47MYSQL教程網(wǎng) Mysql
近期將公司的MySQL架構(gòu)升級(jí)了,由原先的一主多從換成了DRBD+Heartbeat雙主多從,所以這里也將其心得歸納總結(jié)了一下
延伸 · 閱讀
- 2022-03-10Mongodb數(shù)據(jù)庫(kù)轉(zhuǎn)換為表格文件的庫(kù)
- 2022-03-10C/C++ Qt 數(shù)據(jù)庫(kù)與TreeView組件綁定詳解
- 2022-03-09MySQL數(shù)據(jù)庫(kù)如何給表設(shè)置約束詳解
- 2022-03-09MySQL數(shù)據(jù)庫(kù)觸發(fā)器從小白到精通
- 2022-03-09Linux中無(wú)法遠(yuǎn)程連接數(shù)據(jù)庫(kù)問(wèn)題的解決方法
- 2022-03-09易語(yǔ)言的數(shù)據(jù)庫(kù)操作教程
- Mysql
MySQL 查詢速度慢與性能差的原因與解決方法
隨著網(wǎng)站數(shù)據(jù)量與訪問(wèn)量的增加,MySQL 查詢速度慢與性能差的問(wèn)題就日漸明顯,這里為大家分享一下解決方法,需要的朋友可以參考下...
- Mysql
MySQL鎖的知識(shí)點(diǎn)總結(jié)
在本篇文章里小編給大家整理了關(guān)于MySQL鎖的知識(shí)點(diǎn)總結(jié)以及實(shí)例內(nèi)容,需要的朋友們學(xué)習(xí)下。...
- Mysql
解決重置Mysql root用戶賬號(hào)密碼問(wèn)題
這篇文章主要介紹了解決重置Mysql root用戶賬號(hào)密碼問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下...
- Mysql
MySQL之Field‘***’doesn’t have a default value錯(cuò)誤解決辦法
這篇文章主要介紹了MySQL之Field‘***’doesn’t have a default value錯(cuò)誤解決辦法,需要的朋友可以參考下 ...
- Mysql
MySQL server has gone away錯(cuò)誤提示解決方法
今天遇到類似的情景,MySQL只是冷冷的說(shuō):MySQL server has gone away。 ...
- Mysql
MySQL全文索引、聯(lián)合索引、like查詢、json查詢速度哪個(gè)快
這篇文章主要介紹了MySQL全文索引、聯(lián)合索引、like查詢、json查詢速度大比拼,通過(guò)實(shí)例代碼截圖的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值...
- Mysql
幾種MySQL中的聯(lián)接查詢操作方法總結(jié)
這篇文章主要介紹了幾種MySQL中的聯(lián)接查詢操作方法總結(jié),文中包括一些代碼舉例講解,需要的朋友可以參考下 ...
- Mysql
Centos7下使用yum安裝mysql數(shù)據(jù)庫(kù)的詳細(xì)教程(增強(qiáng)版)
這篇文章主要介紹了Centos7下使用yum安裝mysql數(shù)據(jù)庫(kù)的詳細(xì)教程(增強(qiáng)版),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下 ...