一个MySQL不能响应更多请求时,我们可以考虑主从复制,写都到主服务器,读都到从服务器上,这样可以增加并发响应能力,关于前端的读写分离先不讨论,我们先来构建一个MySQL的主从同步架构吧!
- master 172.16.1.18 hostname:master.laoguang.me
- slave 172.16.1.19 hostname:slave.laoguang.me
- [mysqld]
- server-id = 1 ##此id必须全局唯一
- sync_binlog = 1 ##为了减少延迟,让二进制日志同步写到磁盘,性能会有所降低
- #log-bin = 1 ## 二进制日志默认是开启的,如果你的没开启,请启用这个
- log-bin = mysql-bin
- innodb_flush_log_at_trx_commit=1 ##事务日志立刻刷写到磁盘
- service mysqld start
- create user 'backup'@'172.16.1.19' identified by 'redhat';
- revoke all privileges,grant option from 'backup'@'172.16.1.19';
- grant replication client,replication slave on *.* to 'backup'@'172.16.1.19';
- [mysqld]
- server-id = 2 ##id必须全局唯一
- relay-log = mysql-relay ##开启中继日志,不指定目录默认在数据目录下
- relay-log-index = mysql-relay.index ##中继日志索引
- read-only = 1 ##从服务器一般用户只读
- #replicate_do_db = 'db_name' ##只同步某db_name库
- #rpplicate_ignore_db = 'db_name' ##不同步db_name库
- #replicate_do_table = 'tb_name' ##只同步tb_name表
- #replicate_ignore_table = 'tb_name' ##不同步tb_name表
- #replicate_wild_do_table = 'name%' ##通配同步,如只同步name开头的
- #replicate_wild_ignore_table = '_name' ##通配不同步,不同步第一个字符是任意字符后面跟的是name的表或库
- service mysqld start
- mysql> change master to master_host='172.16.1.18',
- -> master_user='backup',
- -> master_password='redhat',
- -> master_log_file='mysql-bin.000001';
- mysql> start slave
- mysql> show slave status\G;
- mysql> create database testsycn; ##主库上建立
- mysql> show databases; ##从库上查看,如果有证明建立成功
- mysql> INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so'; ##加载这个补丁
- mysql> show variables like '%semi%'; ##查看新增补丁后的新系统变量,由此可知模块功能没有启用
- +------------------------------------+-------+
- | Variable_name | Value |
- +------------------------------------+-------+
- | 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 |
- +------------------------------------+-------+
- mysql> set global rpl_semi_sync_master_enabled=on;
- ---------------不是很华丽的分隔---------------
- 如果想长期有效写入/etc/my.cnf
- [mysqld]
- rpl_semi_sync_master_enabled=1 ##启用模块
- rpl_semi_sync_master_timeout=10000##主库等待半同步复制信息返回的超时间隔,单位毫秒,超过间隔降级为异步模式
- rpl_semi_sync_master_wait_no_slave=On ##联系不上从服务器也会等待timeout,默认开启可不写
- ---------------不是很华丽的分隔---------------
- mysql> show status like '%semi%'; ##查看状态
- +--------------------------------------------+-------+
- | Variable_name | Value |
- +--------------------------------------------+-------+
- | Rpl_semi_sync_master_clients | 0 |
- | Rpl_semi_sync_master_net_avg_wait_time | 0 |
- | Rpl_semi_sync_master_net_wait_time | 0 |
- | Rpl_semi_sync_master_net_waits | 0 |
- | Rpl_semi_sync_master_no_times | 0 |
- | Rpl_semi_sync_master_no_tx | 0 |
- | Rpl_semi_sync_master_status | ON |
- | Rpl_semi_sync_master_timefunc_failures | 0 |
- | Rpl_semi_sync_master_tx_avg_wait_time | 0 |
- | Rpl_semi_sync_master_tx_wait_time | 0 |
- | Rpl_semi_sync_master_tx_waits | 0 |
- | Rpl_semi_sync_master_wait_pos_backtraverse | 0 |
- | Rpl_semi_sync_master_wait_sessions | 0 |
- | Rpl_semi_sync_master_yes_tx | 0 |
- +--------------------------------------------+-------+
- mysql> install plugin rpl_semi_sync_slave SONAME 'semisync_slave.so'; ##加载补丁
- mysql> show variables like '%semi%'; ##由图可知同样也需开启
- +---------------------------------+-------+
- | Variable_name | Value |
- +---------------------------------+-------+
- | rpl_semi_sync_slave_enabled | OFF |
- | rpl_semi_sync_slave_trace_level | 32 |
- +---------------------------------+-------+
- mysql> set global rpl_semi_sync_slave_enabled=1; ##如果长期有效写入配置文件
- ---------------不是很华丽的分隔---------------
- [mysqld]
- rpl_semi_sync_slave_enabled=1
- ---------------不是很华丽的分隔---------------
- mysql> stop slave;
- mysql> start slave;
- mysql> show status like '%semi%';
- Rpl_semi_sync_master_clients | 1
- mysql> create database free;
- mysql> show databases;