国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL數據庫InnoDB引擎主從復制同步經驗總結

2024-07-24 13:06:39
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了MySQL數據庫InnoDB引擎主從復制同步經驗總結,本文總結了設置主從復制時遇到的一些錯誤和解決方法,需要的朋友可以參考下
 

近期將公司的MySQL架構升級了,由原先的一主多從換成了DRBD+Heartbeat雙主多從,正好手上有一個電子商務網站新項目也要上線了,用的是DRBD+Heartbeat雙主一從,由于此過程還是有別于以前的MyISAM引擎的,所以這里也將其心得歸納總結了一下:

1)MySQL的replication過程是一個異步同步的過程,并非完全的主從同步,所以同步的過程中是有延遲的,如果做了讀寫分離的業務的話,建議也要監控此延遲時間;

2)MySQL的master與slave機器記得server-id要保持不一致,如果一樣的話,replication過程中會出現如下報錯:

 

復制代碼代碼如下:

Fatal error: The slave I/O threadstopsbecause master and slavehave equal MySQL server ids; these ids mustbedifferent for replication to work(or the --replicate-same-server-id optionmustbe used on slave but this doesnot always make sense; please check themanualbefore using it).

 

這個問題很好處理,即將slave機的server-id修改成跟master機器不一致即可。

3)我以前的一個誤區就是,slave機器是用自己的二進制日志來完成replication過程的,其實不是這樣的,根據復制的工作原理:slave服務器是copy主服務器的二進制日志到自己的中繼日志,即relay-log日志(即centos3-relay-bin.000002這種名字的)中,然后再把更新應用用到自己的數據庫上,所以slave機器是不需要開啟二進制日志的,這樣過程一樣會成功的;除非是準備做主主架構,這才需要slave機器開啟二進制日志,這個問題一直在導著我,我以一直以為slave機器搭建replication環境時是一定要開啟二進制的

4)在master機器上授權時,盡量只給某一個或某幾個固定機器權限,讓它們只有replication slav,replication client權限,盡量不要給grant權限;另外,雖然數據庫我們一般是通過內網操作,但越是在在內網對MySQL數據庫進行授權操作,越是要注意安全;

5)replication搭建過程按照正常流程走的話,一般很容易實施成功,如果出錯的話,多檢查下網絡環境、權限問題,一般來說整個搭建過程應該還是會比較順利的。

在數據庫設計初期,我已經將此電子商務的數據庫引擎定義為InnoDB,除了數據庫中原有的系統表之外,其它表全部由MyISAM轉成了InnoDB,原因有二:

1)電子商務業務會涉及到交易付款,在這種基本OLTP的應用中,InnoDB應該作為核心應用表的首選存儲引擎;
2)DRBD系統重啟時的過程會比較緩慢,會頻繁的讀表,如果表引擎為MyISAM的話極有可能出現損壞情況,為了造成不必要的問題,我將數據庫的表引擎由MyISAM均轉成了InnoDB引擎的表。

DRBD+Heartbeat+MySQL參考以前的工作文檔,搭建的比較順利,就是在搭建replication環境時遇到了1062報錯,詳細過程如下:
初期參考MySQL手冊操作,取master機器的快照備份,用的是--single-transaction選項,然后同步過程頻繁1062報錯,報錯日志如下:

復制代碼代碼如下:

Last_SQL_Error: Error 'Duplicate entry'd36ad91bff36308de540bbd9ae6f4279' for key 'PRIMARY'' on query. Defaultdatabase: '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, '')'

 

后來改變思路,用--master-data選項來取主master快照備份,命令如下所示:

復制代碼代碼如下:

mysqldump -uroot --quick--flush-logs--master-data=1 -p myproject > myproject.sql

 

附注:--master-data的用法為:通過此參數來備份SQL文件時會建議一個slavereplication,當其值為1時,SQL文件中會記錄change master語句;當其值為2時,change master會被寫成SQL注釋,--master-data在沒有使用--single-transaction選項的情況下會自動使用lock-all-tables選項(即這二代選項不要搭配使用)。如何查找SQL中的的LOG_FILE及LOG_POS呢?我們可以用如下命令(請注意change單詞要寫成大寫的),如下所示:

復制代碼代碼如下:

grep "CHANGE"myproject.sql

命令顯示結果如下:
復制代碼代碼如下:

CHANGE MASTER TOMASTER_LOG_FILE='mysql-bin.000008',MASTER_LOG_POS=106;

 

接下來的replication過程就不詳細說明了,同步完成后我們經過相當長時間的觀察,再也沒1062報錯了,如下所示:

 

復制代碼代碼如下:

mysql> show slave status /G;
*************************** 1.row***************************
               Slave_IO_State: Waitingformaster to send event
                  Master_Host: 192.168.11.174
                  Master_User: rep1
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000008
        Read_Master_Log_Pos: 27880
               Relay_Log_File:centos3-relay-bin.000002
                Relay_Log_Pos: 28025
      Relay_Master_Log_File: mysql-bin.000008
           Slave_IO_Running: Yes
          Slave_SQL_Running: Yes
              Replicate_Do_DB:
        Replicate_Ignore_DB:
         Replicate_Do_Table:
     Replicate_Ignore_Table:
    Replicate_Wild_Do_Table:
 Replicate_Wild_Ignore_Table:
                   Last_Errno: 0
                   Last_Error:
                 Skip_Counter: 0
        Exec_Master_Log_Pos: 27880
              Relay_Log_Space: 28182
              Until_Condition: None
               Until_Log_File:
                Until_Log_Pos: 0
         Master_SSL_Allowed: No
         Master_SSL_CA_File:
         Master_SSL_CA_Path:
              Master_SSL_Cert:
          Master_SSL_Cipher:
               Master_SSL_Key:
      Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error:
               Last_SQL_Errno: 0
               Last_SQL_Error:
1 row in set (0.00 sec)

 

工作中InnoDB引擎數據庫主從復制同步心得以前的項目也比較多的牽涉到InnoDB數據庫的備份及replication,較多的一個做法是停庫進行replication,雖然也是解決問題的一種思路,但畢竟屬于停機維護,在一些特殊應用場景中是不允許的,我們應該多嘗試采用mysqldump這種邏輯備份方式來取master主機快照。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 那坡县| 伊宁市| 新源县| 长丰县| 文山县| 高雄市| 三亚市| 舞阳县| 深州市| 永清县| 邛崃市| 犍为县| 开远市| 泰来县| 黑龙江省| 邳州市| 宜宾市| 陈巴尔虎旗| 潞西市| 重庆市| 莱西市| 海城市| 习水县| 建昌县| 金溪县| 图片| 榆社县| 咸丰县| 左贡县| 瑞丽市| 广元市| 正阳县| 惠东县| 古丈县| 扎兰屯市| 仙游县| 铜川市| 东城区| 普陀区| 如东县| 庆安县|