MySQL半同步複製模式

來源:互聯網
上載者:User

Mysql複製預設是非同步完成的,半同步方式是google為mysql開發的一個補丁,在mysql5.5或者更高的版本中已經整合了這個功能。半同步的意思表示MASTER 只需要接收到其中一台SLAVE的返回資訊,就會commit;否則需等待直至達到逾時時間然後切換成非同步再提交。這個做可以使主從庫的資料的延遲較小,可以在損失很小的效能的前提下提高資料的安全性。

 半同步的開啟比較簡單,是需要在master和slave都安裝半同步外掛程式,並啟用就可以了。

查詢mysql複製有沒有使用半同步,

mysql> show variables like 'rpl%';

+-------------------+-------+

| Variable_name    | Value |

+-------------------+-------+

| rpl_recovery_rank | 0    |

+-------------------+-------+

1 row in set (0.00 sec)

或者使用show status like  'rpl%';

啟用半同步模式:

在master執行

mysql> install plugin rpl_semi_sync_master soname 'semisync_master.so';

Query OK, 0 rows affected (0.03 sec)

mysql> set global rpl_semi_sync_master_enabled=0;

Query OK, 0 rows affected (0.00 sec)

 

mysql> show variables like 'rpl%';

+------------------------------------+-------+

| Variable_name                      | Value |

+------------------------------------+-------+

| rpl_recovery_rank                  | 0    |

| rpl_semi_sync_master_enabled      | OFF  |

| rpl_semi_sync_master_timeout      | 10000 |

| rpl_semi_sync_master_trace_level  | 32    |

| rpl_semi_sync_master_wait_no_slave | ON    |

+------------------------------------+-------+

5 rows in set (0.00 sec)

 

mysql> set global rpl_semi_sync_master_enabled=1;

Query OK, 0 rows affected (0.00 sec)

 

mysql> show variables like 'rpl%';

+------------------------------------+-------+

| Variable_name                      | Value |

+------------------------------------+-------+

| rpl_recovery_rank                  | 0    |

| rpl_semi_sync_master_enabled      | ON    |

| rpl_semi_sync_master_timeout      | 10000 |

| rpl_semi_sync_master_trace_level  | 32    |

| rpl_semi_sync_master_wait_no_slave | ON    |

+------------------------------------+-------+

rpl_semi_sync_master_enabled 的值是0(on)或者1(off),預設是1.

rpl_semi_sync_master_timeout的值預設是10000(10s)

5 rows in set (0.00 sec)

在slave執行如下操作:

mysql> install plugin rpl_semi_sync_slave soname 'semisync_slave.so';

Query OK, 0 rows affected (0.03 sec)

 

mysql> set global rpl_semi_sync_slave_enabled=1;

Query OK, 0 rows affected (0.00 sec)

 

mysql> show variables like 'rpl%';

+---------------------------------+-------+

| Variable_name                  | Value |

+---------------------------------+-------+

| rpl_recovery_rank              | 0    |

| rpl_semi_sync_slave_enabled    | ON    |

| rpl_semi_sync_slave_trace_level | 32    |

+---------------------------------+-------+

3 rows in set (0.00 sec)

 

mysql> show status like 'rpl%';

+----------------------------+-------------+

| Variable_name              | Value      |

+----------------------------+-------------+

| Rpl_semi_sync_slave_status | ON          |

| Rpl_status                | AUTH_MASTER |

+----------------------------+-------------+

2 rows in set (0.01 sec)

mysql> stop slave io_thread;

Query OK, 0 rows affected (0.00 sec)

 

mysql> start slave io_thread;

Query OK, 0 rows affected (0.00 sec)

 

rpl_semi_sync_slave_enabled的值是0(on)或者1(off),預設是1.

  • 1
  • 2
  • 下一頁

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.