成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解MySQL集群下的復制(replicate)原理

數據庫 MySQL 數據庫運維
MySQL集群與復制是本文的重要內容,在這種模式下,既有主從的實時備份,又有基于集群的負載均衡。希望對大家有所幫助。

7. 集群下的復制

7.1. 簡述

從MySQL 5.1 開始,就支持集群+復制了,這對于想要構建一個高可用方案的用戶來說,無疑是個驚喜。在這種模式下,既有主從的實時備份,又有基于集群的負載均衡,不足指出在于,從我的測試結果來看,這種方案下的性能還不是太高,仍有待改進。

集群+復制的配置其實很簡單,就是配置好2個獨立的集群后,把其中一個的SQL節點作為另一個集群SQL節點的slave即可。甚至可以使用下面幾種架構:

3個集群,6個SQL節點,形成一個3個點環形的復制。

3個集群,6個SQL節點,形成一個6個點環形的復制,把另一個SQL節點也利用起來。

7.2. 開始配置

7.2.1. master上的配置

由于集群下的復制是基于row-based復制的,因此需要設置logbin-format的格式為:ROW 或者 MIXED。
相對于普通的mysqld服務器配置,只需要增加類似如下2行:

  1. server-id = 1  
  2. binlog_format = "ROW" #or MIXED 

7.2.2. slave上的配置

新版本的MySQL已經不再通過 my.cnf 來指定master相關的信息了,而是通過 CHANGE MASTER 指令來管理。因此,slave上只需簡單增加類似如下幾行:

  1. server-id = 2 
  2. relay-log-purge=1 
  3. skip-slave-start  
  4. replicate-ignore-db=mysql 

7.3. 啟動slave

先按照正常的方式啟動master和slave上的mysqld后,執行SHOW PROCESSLIST 可以看到2個mysqld都只有2個進程:

  1. mysql> SHOW PROCESSLIST;  
  2. +----+-------------+-----------+------+---------+------+-----------------------------------+------------------+  
  3. | Id | User        | Host      | db   | Command | Time | State                             | Info             |  
  4. +----+-------------+-----------+------+---------+------+-----------------------------------+------------------+  
  5. |  1 | system user |           |      | Daemon  |    0 | Waiting for event from ndbcluster | NULL             |  
  6. |  2 | root        | localhost | NULL | Query   |    0 | NULL                              | show processlist |  
  7. +----+-------------+-----------+------+---------+------+-----------------------------------+------------------+  
  8. 2 rows in set (0.00 sec) 

在slave上執行 SHOW SLAVE STATUS 再看看:

  1. mysql> show slave status\G  
  2. Empty set (0.00 sec) 

可以看到,現在還沒有任何復制相關的配置。因此,我們需要先在master上添加一個賬戶用于復制:

  1. mysql> GRANT REPLICATION SLAVE, GRANT REPLICATION CLIENT ON *.* TO rep@’192.168.1.2’ IDENTIFIED BY ‘rep’;  
  2. Query OK, 0 rows affected (0.00 sec) 

然后,我們用 CHANGE MASTER 指令來指定一下 master 相關的參數:

  1. mysql> CHANGE MASTER TO MASTER_HOST='192.168.0.2'MASTER_USER='rep'MASTER_PASSWORD='rep';   
  2. Query OK, 0 rows affected (0.01 sec)  
  3.  
  4. mysql> SHOW SLAVE STATUS\G  
  5. *************************** 1. row ***************************  
  6.                Slave_IO_State:   
  7.                   Master_Host: 192.168.0.2  
  8.                   Master_User: rep  
  9.                   Master_Port: 3306  
  10.                 Connect_Retry: 60  
  11.               Master_Log_File:   
  12.           Read_Master_Log_Pos: 4  
  13.                Relay_Log_File: slave-relay-bin.000001  
  14.                 Relay_Log_Pos: 4  
  15.         Relay_Master_Log_File:   
  16.              Slave_IO_Running: No  
  17.             Slave_SQL_Running: No  
  18.               Replicate_Do_DB:   
  19.           Replicate_Ignore_DB: mysql  
  20.            Replicate_Do_Table:   
  21.        Replicate_Ignore_Table:   
  22.       Replicate_Wild_Do_Table:   
  23.   Replicate_Wild_Ignore_Table:   
  24.                    Last_Errno: 0  
  25.                    Last_Error:   
  26.                  Skip_Counter: 0  
  27.           Exec_Master_Log_Pos: 0  
  28.               Relay_Log_Space: 106  
  29.               Until_Condition: None  
  30.                Until_Log_File:   
  31.                 Until_Log_Pos: 0  
  32.            Master_SSL_Allowed: No  
  33.            Master_SSL_CA_File:   
  34.            Master_SSL_CA_Path:   
  35.               Master_SSL_Cert:   
  36.             Master_SSL_Cipher:   
  37.                Master_SSL_Key:   
  38.         Seconds_Behind_Master: NULL  
  39. Master_SSL_Verify_Server_Cert: No  
  40.                 Last_IO_Errno: 0  
  41.                 Last_IO_Error:   
  42.                Last_SQL_Errno: 0  
  43.                Last_SQL_Error:   
  44. 1 row in set (0.00 sec) 

執行 START SLAVE 來啟動它。

  1. mysql> start slave;  
  2. Query OK, 0 rows affected (0.00 sec) 

再來看看:

  1. mysql> SHOW SLAVE STATUS\G  
  2. *************************** 1. row ***************************  
  3.                Slave_IO_State: Waiting for master to send event  
  4.                   Master_Host: 192.168.0.2  
  5.                   Master_User: rep  
  6.                   Master_Port: 3306  
  7.                 Connect_Retry: 60  
  8.               Master_Log_File: binlog.000001  
  9.           Read_Master_Log_Pos: 256  
  10.                Relay_Log_File: slave-relay-bin.000002  
  11.                 Relay_Log_Pos: 398  
  12.         Relay_Master_Log_File: binlog.000001  
  13.              Slave_IO_Running: Yes  
  14.             Slave_SQL_Running: Yes  
  15.               Replicate_Do_DB:   
  16.           Replicate_Ignore_DB: mysql  
  17.            Replicate_Do_Table:   
  18.        Replicate_Ignore_Table:   
  19.       Replicate_Wild_Do_Table:   
  20.   Replicate_Wild_Ignore_Table:   
  21.                    Last_Errno: 0  
  22.                    Last_Error:   
  23.                  Skip_Counter: 0  
  24.           Exec_Master_Log_Pos: 256  
  25.               Relay_Log_Space: 557  
  26.               Until_Condition: None  
  27.                Until_Log_File:   
  28.                 Until_Log_Pos: 0  
  29.            Master_SSL_Allowed: No  
  30.            Master_SSL_CA_File:   
  31.            Master_SSL_CA_Path:   
  32.               Master_SSL_Cert:   
  33.             Master_SSL_Cipher:   
  34.                Master_SSL_Key:   
  35.         Seconds_Behind_Master: 0  
  36. Master_SSL_Verify_Server_Cert: No  
  37.                 Last_IO_Errno: 0  
  38.                 Last_IO_Error:   
  39.                Last_SQL_Errno: 0  
  40.                Last_SQL_Error:   
  41. 1 row in set (0.00 sec) 

7.4. 簡單測試

這個留給讀者自己按照常規的測試去完成吧。

 

【編輯推薦】

  1. MySQL數據庫集群進行正確配置步驟
  2. MySQL 集群在Server1與Server2上如何安裝MySQL
  3. MySQL集群配置
  4. MySQL集群自動安裝腳本
  5. MySQL觸發器如何正確使用

 

 

責任編輯:彭凡 來源: MySQL中文網
相關推薦

2020-06-01 16:05:17

MongoDB復制集數據庫

2024-07-04 08:00:24

2020-12-22 10:11:13

MySQL數據庫復制原理

2015-05-06 13:34:14

MySQL集群搭建

2024-05-27 00:04:00

2023-12-29 13:45:00

2024-02-21 16:42:00

2019-09-16 16:05:13

Redis集群模式

2017-07-07 10:40:24

MySQL備份原理

2017-09-05 16:00:49

MySQL主從復制備份

2025-01-15 15:47:36

2024-03-01 18:33:59

MySQL節點數據

2021-06-08 07:48:27

MySQL主從配置

2021-01-12 09:03:17

MySQL復制半同步

2020-04-14 16:26:22

MySQL線程同步

2017-06-23 11:17:24

MySQL搭建配置

2010-10-19 16:32:46

MySQL

2010-08-12 13:15:26

MySQL集群

2020-04-14 21:12:42

Redis集群Linux

2010-03-11 16:49:55

Linux CPU利用
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美理论片在线 | 美女天天操 | 亚洲国产精品日韩av不卡在线 | www.亚洲成人网 | av黄色在线观看 | 国产一区二区成人 | 在线免费观看a级片 | 亚洲国产精品久久久久 | 国产色网 | 亚洲国产精品suv | 亚洲精品一区二 | 国产精品成人一区二区 | 日本中文在线视频 | 欧美一级久久 | 午夜精品久久 | 丝袜 亚洲 另类 欧美 综合 | 日韩精品一二三区 | 亚洲国产aⅴ成人精品无吗 综合国产在线 | 国产精品地址 | 国产精品一区二区av | 亚洲国产一区在线 | 精品久久久久久久久久久久久久 | 一级aaaaaa毛片免费同男同女 | 久久99久久久久 | 日韩中文字幕一区 | 黑人一级黄色大片 | 国产精品视频一 | 一级大黄| 久久精品亚洲欧美日韩久久 | 日韩在线免费 | 夜夜撸av | 久久99深爱久久99精品 | 国产精品一区二区三区久久 | 欧美精品乱码久久久久久按摩 | 麻豆av在线免费观看 | 国产一区二区三区 | 亚洲一区二区三区免费 | 国产精品久久久久一区二区三区 | 欧美在线视频观看 | 国产精品特级片 | 日日操日日干 |