MySQL复制-阿里云开发者社区

开发者社区> megachen> 正文

MySQL复制

简介: MySQL复制 MySQL传统的主从复制 master节点的配置 server_id=1 sync_binlog=1 log_bin=master-bin mysql> create user 'repl'@'192.
+关注继续查看

MySQL复制

MySQL传统的主从复制

master节点的配置

  • server_id=1
  • sync_binlog=1
  • log_bin=master-bin
  • mysql> create user 'repl'@'192.168.1.%' identified by 'password';
  • mysql> grant replication slave on . to 'repl'@'192.168.1.%';

slave节点的配置

  • server_id=2
  • relay_log=slave-bin
  • skip-slave-start=on # 默认MySQL启动就会自动start slave, 设置为on则需要手动start slave(推荐)
  • read_only=on # slave节点应该是只读的, 对super用户和relay log的repaly无效
  • mysql> change master to ...
  • mysql> start slave # 并不是连接到master节点, 而是设置连接到master节点的参数, 生成配置文件master.info在datadir项指定的目录中
  • mysql> stop slave

查看slave节点的状态

  • show slave status\G;

查看master节点的状态

  • show master status\G:

将master节点的数据备份恢复到slave节点上

  • mysqldump -uroot -proot -q -c --lock-all-tables --master-data=2 --no-autocommit --flush-logs --databases mydb > backup.sql
  • scp backup.sql root@node2:~
  • mysql -uroot -proot < backup.sql

MySQL传统的主从复制之辅助master

主要对充当master节点的slave节点进行配置

  • log_slave_updates=on # 默认情况下在replay中继日志时不会记录到binlog中, 开启该选项才可以
  • log_bin=on # 要记录二进制日志这个是必须的, log_slave_updates和log_bin是要同时设置的
  • 一个slave2是以slave为master的slave节点, 因为都是slave节点, 所以可以将他们都停下来进行快速的冷备份
    • 将slave中的数据文件拷贝到slave2中
    • 在slave2节点中, 删除拷贝过来的文件中的master.info, relay_log,info, 所有的二进制日志
  • 为slave节点添加具有复制权限的日志
    • create user 'repl'@'192.168.1.%' identified by 'password';
    • grant replication slave on . to 'repl'@'192.168.1.%';
  • 在slave2节点中配置连接slave的参数
    • mysql> change master to...
    • read_only=on
    • skip_slave_start=on

在master节点查看已经使用start slave连接的slave节点

  • show slave hosts;

slave转为master

  • 该slave必须是一个开启了log_slave_updates和log_bin的辅助master节点
  • mysql> stop slave;
  • systemctl stop mariadb
  • 删除master.info, relay_log.info 和 中继日志
  • systemctl start mariadb
  • 剩余的slave节点的master都指向该转为master的slave节点即可

MySQL主从复制(基于GTID)

master节点

  • 配置文件中相对于传统复制添加 gtid_mode=on 和 enforce_gtid_consistency=on
  • 创建具有复制权限的用户
  • show master status; 获取当前的gtid

slave节点

  • 配置文件中相对于传统复制添加 gtid_mode=on 和 enfoce_gtid_consistency=on
  • reset master
  • show global variables like '%gtid%'; 找到 gtid_executed 和 gtid_purged, 这两个变量是与gtid有关的
  • set @@gobal.gtid_purged=从master节点得到的gtid号, 这样再第一次同步时就可以跳过重复和一些不必要的操作减少错误和提高效率

MySQL半复制

与传统复制唯一的不同就是需要在配置文件中添加关于加载插件的信息

在master节点

  • plugin-load='rpl_semi_sync_master=semisync_master.so'
  • rpl_semi_sync_master_enabled=1

在slave节点

  • plugin-load='rpl_semi_sync_slave=semisync_slave.so'
  • rpl_semi_sync_slave_enabled=1

辅助master节点

  • plugin-load='rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so'
  • rpl_semi_sync_slave_enabled=1
  • rpl_semi_sync_master_enabled=1

查看相关信息

  • show plugins;
  • show status like '%semi%';
  • show global variables like '%semi%';

在mysql shell中加载插件和启动插件而不是通过编写配置文件

  • help install;
    • master节点
      • install plugin rpl_semi_sync_master soname 'semisync_master.so';
      • set @@global.rpl_semi_sync_master_enabled=0;
    • slave节点
      • install plugin rpl_semi_sync_slave soname 'semisync_slave.so';
      • set @@global.rpl_semi_sync_slave_enabled=0;

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
4617 0
mysql 主从复制的 工作原理
mysql 主从复制原理 主从形式   mysql主从复制 灵活 一主一从 主主复制 一主多从---扩展系统读取的性能,因为读是在从库读取的; 多主一从---5.7开始支持 联级复制---     用途及条件   mysql主从复制用途 实时灾备,用于故障切换 读写分离,...
1293 0
MySQL主从复制故障解决
丛库复制停止,进丛库查看,报错1007,数据库已存在,不能创建数据库 mysql> show slave status\G; Slave_IO_Running: Yes Slave_SQL_Running: No La...
680 0
MySQL主从复制
主库 开启主库binlog和server_id vim /etc/my.cnf [mysqld] log-bin=/var/lib/mysql/mysql-bin server_id=1 systemctl re...
774 0
+关注
megachen
Just for fun
157
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载