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

[经验分享] Keepalived+MySQL主主互备模式实现高可用

[复制链接]
YunVN网友  发表于 2018-12-31 11:39:35 |阅读模式
  MySQL的高可用方案很多,这是一个配置简单而且实用的高可用解决方案。
  

  实验架构图:

  

  修改DB1配置文件增加以下几项:
  [mysqld]
  log-bin=mysql-bin
  relay-log=mysql-relay-bin
  server-id=1
  replicate-wild-ignore-table=mysql.%
  replicate-wild-ignore-table=test.%
  replicate-wild-ignore-table=information_schema.%
  

  修改DB2配置文件增加以下几项:
[mysqld]
log-bin=mysql-bin
relay-log=mysql-relay-bin
server-id=2
replicate-wild-ignore-table=mysql.%
replicate-wild-ignore-table=test.%
replicate-wild-ignore-table=information_schema.%
  

  推荐在主从库上使用replicate-wild-ignore-table和replicate_wild_do_table两个选项来解决复制过滤的问题。
  

  保证数据同步
  如果DB1上已经有MySQL数据,那么在执行主主互备之前,需要将DB1和DB2上的MySQL保持数据同步。

  首先在DB1上执行锁表然后将数据导出,在DB2上应用。
  锁表命令:FLUSH TABLES WITH READ LOCK;
  

  创建复制用户并授权
  首先在DB1创建复制用户


  然后在DB2的MySQL库中将DB1设为自己的主服务器

  

  mysql> change master to \
  -> master_host='192.168.0.254',
  -> master_user='repl_user',
  -> master_password='123456',
  -> master_log_file='mysql-bin.000002',
  -> master_log_pos=106;
  

  注意:master_log_file和master_log_pos这两个选项的值要对应在DB1上通过SQL语句"show master status" 查询到的值。
  

  在DB2上启动Slave服务
  

  mysql> start slave;
  

  查看DB2上slave的运行状态

  这样DB1到DB2的主从复制已经完成,接下来配置从DB2到DB1的主从复制,这个过程和前面完全一样。首先在DB2的MySQL库中创建复制用户

  然后在DB1的MySQL库中将DB2设为自己的主服务器
mysql> change master to \
    -> master_host='192.168.0.251',
    -> master_user='repl_user',
    -> master_password='123456',
    -> master_log_file='mysql-bin.000002',
    -> master_log_pos=106;
  

  启动复制线程
mysql> start slave;
  

  查看DB1上slave的运行状态
  
  从状态看出复制服务运行正常,MySQL双主模式的主从复制配置完成。
  

  配置Keepalived实现MySQL双主高可用

  

  需要在两台服务器上安装keepalived,这里拿DB1安装过程举例,DB2的安装过程相同这里不重复。
  tar xf keepalived-1.2.12.tar.gz

  cd keepalived-1.2.12
  ./configure --sysconf=/etc --with-kernel-dir=/usr/src/kernels/2.6.32-504.el6.x86_64/
  make
  make install
  

  DB1服务器配置文件 /etc/keepalived/keepalived.conf
  

  global_defs {
     notification_email {
          root@localhost
     }
     notification_email_from keepalived.example.com
     router_id MySQL_HA
  }
  

  vrrp_script check_mysqld {
          script "/etc/keepalived/check_slave.pl 127.0.0.1"
          interval 2
          weight 21
  }
  

  vrrp_instance HA_1 {
      state BACKUP      //DB1和DB2上均配置为BACKUP
      interface eth0
      virtual_router_id 80
      priority 100
      advert_int 2
      nopreempt      //不抢占模式,只在优先级高的机器上设置即可,优先级低的机器可以不设置。
  

      authentication {
          auth_type PASS
          auth_pass 23b14455cd
      }
  track_script {
    check_mysqld
  }
  virtual_ipaddress {
          192.168.0.150  
      }
  }
  

  其中,/etc/keepalived/check_slave.pl  脚本内容为:
  
  

  #!/usr/bin/perl -w
  use DBI;
  use DBD::mysql;
  

  # CONFIG VARIABLES
  $SBM = 120;
  $db = "wpdb";
  $host = $ARGV[0];
  $port = 3306;
  $user = "root";
  $pw = "123456";
  

  # SQL query
  $query = "show slave status";
  

  $dbh = DBI->connect("DBI:mysql:$db:$host:$port", $user, $pw, { RaiseError => 0,PrintError => 0 });
  

  if (!defined($dbh)) {
      exit 1;
  }
  

  $sqlQuery = $dbh->prepare($query);
  $sqlQuery->execute;
  

  $Slave_IO_Running =  "";
  $Slave_SQL_Running = "";
  $Seconds_Behind_Master = "";
  

  while (my $ref = $sqlQuery->fetchrow_hashref()) {
      $Slave_IO_Running = $ref->{'Slave_IO_Running'};
      $Slave_SQL_Running = $ref->{'Slave_SQL_Running'};
      $Seconds_Behind_Master = $ref->{'Seconds_Behind_Master'};
  }
  

  $sqlQuery->finish;
  $dbh->disconnect();
  

  if ( $Slave_IO_Running eq "No" || $Slave_SQL_Running eq "No" ) {
      exit 1;
  } else {
      if ( $Seconds_Behind_Master > $SBM ) {
          exit 1;
      } else {
          exit 0;
      }
  }
  

  这是用Perl写的检测MySQL复制状态的脚本,修改文件中的MySQL数据库端口,用户名,密码即可直接使用。
  

  如果执行这个脚本报如下错误时:


  使用以下命令可以解决:
  # yum install  perl-DBI perl-DBD-MySQL -y
  

  DB2的keepalived.conf文件和DB1基本一样,只需将priority值修改为90,由于配置的是不抢占模式,还需要去掉nopreempt选项。
  

  然后分别启动两台主机上的keepalived服务
  

  测试服务的高可用功能
  

  我们在192.168.0.3这台主机上用mysql客户端连接vip:192.168.0.150
  
  

  
  从上面两张图可以看出来,目前是连到了192.168.0.254这台服务器上,也就表示游标IP在这台服务器上。
  

  
  

  测试故障转移

  故障模拟,我们这时手动停掉192.168.0.254的MySQL复制线程
  
  这里可以看到,当停掉复制线程后,执行查询时连接中断了一次,马上再次连接上完成查询,显示的server_id已经变成2了,表示服务器已经切换了。
  

  查看DB2服务器的IP地址验证游标IP是否转移过来了

  
  

  实验完成!




运维网声明 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-657928-1-1.html 上篇帖子: keepalived双主模型高可用+lvs 下篇帖子: Keepalived + LVS 高可用负载均衡集群部署
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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