当前位置:Gxlcms > 数据库问题 > 简述mysql半同步复制—semisync

简述mysql半同步复制—semisync

时间:2021-07-01 10:21:17 帮助过:18人阅读

   mysql的半同步复制-semisync是基于默认的异步复制和完全同步复制之间,它是在master在执行完客户端提交的事务后不是立刻返回给客户端,而是等待至少一个slave收到并写到relay log中才返回给客户端。相对于异步复制,semisync提高了数据的安全性,但是又比完全同步性能好,所以master和slave之间的时间一定要一致,以免造成semisync失败。mysql的半同步复制的插件是由Google免费提供的在mysql的$basedir/lib/plugin下有相应的动态库文件,linux中是.so,DOS系统中是.dll,在默认情况下mysql是没有装载semisync的插件,所以要制作semisync要手动在mysql的shell中装载插件,下面就简单的说一说mysql的semisync配置,这里要注意要使用mysql的super用户来配置,并且mysql要5.5及以上版本才有,并且要在有异步复制的基础上才可以做配置

  1. #master中
  2. mysql> install plugin rpl_semi_sync_master soname ‘semisync_master.so‘;
  3. Query OK, 0 rows affected (0.00 sec)
  4. mysql> show global variables like ‘%semi%‘;                            
  5. +------------------------------------+-------+
  6. | Variable_name                      | Value |
  7. +------------------------------------+-------+
  8. | rpl_semi_sync_master_enabled       | OFF   | 
  9. | rpl_semi_sync_master_timeout       | 10000 | 
  10. | rpl_semi_sync_master_trace_level   | 32    | 
  11. | rpl_semi_sync_master_wait_no_slave | ON    | 
  12. +------------------------------------+-------+
  13. 4 rows in set (0.01 sec)
  14. mysql> set global rpl_semi_sync_master_enabled = 1;#开启master上的semisync,设置超时时间,可以通过设置rpl_semi_sync_master_timeout变量来修改,默认单位为毫秒
  15. Query OK, 0 rows affected (0.00 sec)
  16. mysql> show status like ‘%Rpl_semi_sync%‘;
  17. +--------------------------------------------+-------+
  18. | Variable_name                              | Value |
  19. +--------------------------------------------+-------+
  20. | Rpl_semi_sync_master_clients               | 1     | 
  21. | Rpl_semi_sync_master_net_avg_wait_time     | 565   | 
  22. | Rpl_semi_sync_master_net_wait_time         | 3391  | 
  23. | Rpl_semi_sync_master_net_waits             | 6     | 
  24. | Rpl_semi_sync_master_no_times              | 1     | 
  25. | Rpl_semi_sync_master_no_tx                 | 12    | 
  26. | Rpl_semi_sync_master_status                | ON    | 
  27. | Rpl_semi_sync_master_timefunc_failures     | 0     | 
  28. | Rpl_semi_sync_master_tx_avg_wait_time      | 588   | 
  29. | Rpl_semi_sync_master_tx_wait_time          | 3528  | 
  30. | Rpl_semi_sync_master_tx_waits              | 6     | 
  31. | Rpl_semi_sync_master_wait_pos_backtraverse | 0     | 
  32. | Rpl_semi_sync_master_wait_sessions         | 0     | 
  33. | Rpl_semi_sync_master_yes_tx                | 6     | 
  34. +--------------------------------------------+-------+
  35. 14 rows in set (0.00 sec)
  36. #slave中
  37. mysql> install plugin rpl_semi_sync_slave soname ‘semisync_slave.so‘;       
  38. Query OK, 0 rows affected (0.00 sec)
  39. mysql> show global variables like ‘%semi%‘;
  40. +---------------------------------+-------+
  41. | Variable_name                   | Value |
  42. +---------------------------------+-------+
  43. | rpl_semi_sync_slave_enabled     | OFF   |
  44. | rpl_semi_sync_slave_trace_level | 32    |
  45. +---------------------------------+-------+
  46. 2 rows in set (0.00 sec)
  47. mysql> set global rpl_semi_sync_slave_enabled = 1;
  48. Query OK, 0 rows affected (0.00 sec)
  49. mysql> stop slave IO_THREAD;start slave IO_THREAD;#重启slave上的IO线程
  50. Query OK, 0 rows affected (0.09 sec)
  51. Query OK, 0 rows affected (0.00 sec)
  52. mysql> show status like ‘%Rpl_semi_sync%‘;
  53. +----------------------------+-------+
  54. | Variable_name              | Value |
  55. +----------------------------+-------+
  56. | Rpl_semi_sync_slave_status | ON    |
  57. +----------------------------+-------+
  58. 1 row in set (0.00 sec)

这样简单的semisync就配置好了,这里要注意的是如果master超过超时时间没有接收到slave的消息时会自动转为异步复制,当然如果不需要semisync可以直接uninstall相应的插件

  1. mysql> uninstall plugin rpl_semi_sync_master;
  2. Query OK, 0 rows affected (0.00 sec)
  3. mysql> uninstall plugin rpl_semi_sync_slave;
  4. Query OK, 0 rows affected (0.00 sec)


本文出自 “技术随笔” 博客,谢绝转载!

简述mysql半同步复制—semisync

标签:mysql   semisync   

人气教程排行