设为首页 收藏本站
查看: 865|回复: 0

[经验分享] MySQL主从复制Galera

[复制链接]

尚未签到

发表于 2018-9-30 07:03:39 | 显示全部楼层 |阅读模式
  一、主从复制的问题和解决方案
  二、Galera Cluster
  三、MySQL 5.6的多线程复制、GTID
  MySQL Replication:
  Master HA或多主节点模型
  MMM:multi master MySQL
  MHA:Master HA
  对主节点进行监控,可实现自动故障转移至其他从节点,通过提升某一从节点为新的主节点
  Galera Cluster:wresp
  通过wresp协议在全局实现复制:任何一节点都可读写
  读写分离://一般都是自己研发的
  mysql-proxy:没有stable稳定版本
  mysql-proxy--> Atals (Qihoo)
  Amoeba:目前,活跃度不高
  一、复制的问题和解决方案:
  (1)数据损坏或丢失:
  某个slave上损坏:在slave上重放二进制日志,各种原因,导致数据不一致。例如硬件故障
  //使用其他master上的备份的数据集,在新的slave上进行还原,从备份的位置开始从master上进行复制。
  重新复制即可//下线故障的slave,还原然后重新复制即可
  master数据损坏或丢失:
  //在各个slave上根据其gtid,找出最新的salve,然后提升为master
  //MHA+semi repl //MHA和一个node半同步复制,提升半同步node为新的master即可
  //最后方案:
  二进制日志分析,然后还原
  单个故障了:活该!
  (2)混合使用存储引擎;//坚决杜绝
  MyISAM不支持事务//不能回滚的
  InnoDB支持事务

  (3)不唯一的server>  整个复制集群,可能导致错乱。

  //例如某个slave的server>
  修改server>  (4)复制延迟
  从node落后于master
  自己写脚本,不断监控,发现落后的时间不等于0,后,可以重启slave的io线程
  需要额外的监控工具来辅助实现。
  在master上事务是可以并发的,但是往同一个二进制日志写入是单线程的
  因此slave在本地应用也是单线程的
  master上有多个库,每一个库的事务是可以并行的,因为对A库的锁,对B库是没有影响的,但是反映到二进制日志中必然有先后的顺序
  因此slave落后是没有办法避免的,因此mysql 5.5之后引入了多线程机制。
  支持一从多主和多线程复制
  多线程复制//每一个数据库只启用一个线程
  //但是主库是不能一样的
  多线程复制:还是有用的,依赖于gtid
  //MySQL 5.6.3之后,MariaDB10.0.5之后
  复制线程:Master上的IO线程和Slave上的IO、SQL线程,
  数据库服务的衡量指标:
  qps:query per second
  tps:事务per second
  数据库压力测试工具:
  sysbench
  二、Galera Cluster:多用于MySQL的数据复制
  http://galeracluster.com/
  更底层的复制机制
  需要单独编译实现。
  安装方式
  msyql官方或者galera //官方提供的支持galera 的版本
  percona-cluster //整合过mysql版本
  mariadb-cluster //专用的复制
  base和epel都没有提供galera-cluster的源
  默认的mariadb版本是不支持galera的
  需要用到的包:
  MariaDB-5.5.46-centos7-x86_64-client.rpm
  MariaDB-5.5.46-centos7-x86_64-common.rpm
  MariaDB-Galera-5.5.46-centos7-x86_64-common.rpm
  //至少需要3个node
  1.前提:hosts文件和时间同步
  node1:192.168.1.67
  node2:192.168.1.68
  node3:192.168.1.69
  node1:
  建议在本地配置yum源
  yum remove mariadb //卸载client和server端
  yum install MairaDB-Galera-server
  node2:
  建议在本地配置yum源
  yum remove mariadb //卸载client和server端
  yum install MairaDB-Galera-server
  node3:
  建议在本地配置yum源
  yum remove mariadb //卸载client和server端
  yum install MairaDB-Galera-server
  2.配置文件说明/etc/my.cnf.d/server.cnf
  ...
  [galera]
  # Manatory settings //强制配置
  #wresp_provider = /usr/lib64/galera/libgalera_smm.so
  #wresp_cluster_address = "gcomm://192.168.1.67, 192.168.1.68, 192.168.1.69"
  #wresp_cluster_name = "mycluster"
  #wresp_node_name = 'node1'
  #wresp_node_address = '192.168.1.67' //这两个可以省略
  #binlog_format = row
  #default_storage_engine=InnoDB
  #bind-address=0.0.0.0
  # Optional setting
  #wsrep_slave_threads=1
  #innodb_flush_logs_at_trx_commit=0
  ...
  首次启动:需要初始化集群,在其中一个node上执行如下命令
  /etc/init.d/mysql start --wsreq-new-cluster
  而后正常启动其他节点即可
  3.修改配置文件
  node1:
  [galera]
  wresp_provider=/usr/lib64/galera/libgalera_smm.so
  wresp_cluster_address="gcomm://192.168.1.67, 192.168.1.68, 192.168.1.69"
  binlog_format=row
  default_storage_engine=InnoDB
  innodb_autoinc_lock_mode=2
  bind-address=0.0.0.0
  wresp_cluster_name="mycluster"
  node2: 和 node3: 配置文件相同
  node1:任意一个node都可以
  /etc/rc.d/init.d/mysql start --wsrep-new-cluster
  node2:
  service mysql start
  node3:
  service mysql start
  3.测试
  mysql> 任何一个node创建数据
  在其他node上可以看到有数据
  node1:
  > use mydb;
  > create table tb2 (id int unsigned auto_increment not null primary key,name char(30));
  > insert into tb2 (name) values ('hi'),('hello');
  node2:
  > select * from tb2;
  id | name
  ---------
  1| h1
  4| hello
  > insert into tb2 (name) values ('to'),('from');
  > select * from tb2
  1hi
  4hello
  5to
  8from
  使用全局id生成器
  r/w分离器:
  要么自己写
  要么使用开源的工具
  或者在应用层配置实现 //一旦故障需要手动修改或者使用vrrp
  亲测方法:
  1.复制所有的rpm文件
  2.createrepot /testrepo
  3.修改yum文件指向该yum源即可
  4.使用yum进行安装即可
  三、MySQL 5.6的多线程复制、GTID
  注意:任何服务或者主机都应该被监控
  mysql落后的原因:单线程复制,
  5.5 半同步
  5.6 GTID、多线程复制,
  MariaDB在配置文件的mysqld选项组中添加:
  slave-parallel-threads
  MASTER: my.cnf添加以下参数
  binlog_format = row
  gtid_mode = ON
  enforce-gtid-consistency = ON
  slave_parallel_workers=4           --开启基于库的多线程复制默认0不开启
  binlog_cache_size = 8M
  max_binlog_size = 50M
  max_binlog_cache_size = 100M
  sync_binlog = 1
  expire_logs_days = 1
  log-slave-updates=true
  SLAVE: my.cnf添加以下参数
  binlog_format = row
  gtid_mode = ON
  enforce-gtid-consistency = ON
  binlog_cache_size = 8M
  max_binlog_size = 50M
  max_binlog_cache_size = 100M
  sync_binlog = 1
  expire_logs_days = 1
  slave_parallel_workers=4
  max_relay_log_size = 50M
  relay_log_purge = 1
  relay_log_recovery = 1
  master_verify_checksum = 1        --主事件校验
  slave_sql_verify_checksum = 1     --从事件校验
  slave_allow_batching = 1
  log-slave-updates=true
  MySQL 5.6和5.7的并行复制:参考
  http://www.cnblogs.com/xiaotengyi/p/5532191.html


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-606102-1-1.html 上篇帖子: MySQL主从复制(一) 下篇帖子: MySQL类型float double decimal的区别
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表