热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MariaDB+keepalived部署双主高可用数据库

确保/etc/my.cnf中有如下参数,没有的话需手工添加,并重启mysql服务。MariaDB[(none)]changemastertomaster_host192.168.1.201,master_userbackup,master_passwordbackup,master_log_filemysql-bin.

确保/etc/my.cnf中有如下参数,没有的话需手工添加,并重启mysql服务。

MariaDB [(none)]> change master to master_host=''192.168.1.201'',master_user=''backup'',master_password=''backup'',master_log_file=''mysql-bin.000010'',master_log_pos=245;

注意:245对应上面在201上面记下的Position,mysql-bin.000010对应201上面记录的File

Slave_IO_Running: Yes            

Slave_SQL_Running: Yes

两项都显示Yes时说明从201同步数据成功。

至此201为主202为从的主从架构数据设置成功!

七、设置201和202互为主从:

 

1、202机器上增加一个帐号专门用于同步数据:

MariaDB [(none)]> grant replication slave on *.* to ''backup''@''192.168.1.201'' identified by ''backup''; flush privileges;

2、显示202做为主库时的状态:

MariaDB [(none)]> show master status;

3、在201数据库服务器上:

MariaDB [(none)]> change master to master_host=''192.168.1.202'',master_user=''backup'',master_password=''backup'',master_log_file=''mysql-bin.000005'',master_log_pos=5005;

注意:5005对应上面在202上面记下的Position,mysql-bin.000005对应202上面记录的File

显示状态:

MariaDB [(none)]> show slave status \G;

Slave_IO_Running: Yes            

Slave_SQL_Running: Yes

两项都显示Yes时说明从202同步数据成功。

至此201、202互为主从设置成功!

可以试试在这两台服务器上任何一台增加一个数据库,并建个表,增加一些数据看看,互为主从同步的状态是否成功!

首先在201上面:

MariaDB [(none)]> create database mysqltest;

MariaDB [(none)]> use mysqltest;

MariaDB [mysqltest]> create table user(id int(5),name char(10));

MariaDB [mysqltest]> insert into user values (00001,''zhangsan'');

在202上面验证一下:

MariaDB [(none)]> use mysqltest;

MariaDB [mysqltest]> select * from user;

会发现201上面的数据已经自动同步到202上面了

同样在202上面:

MariaDB [mysqltest]> insert into user values (00002,''wander'');

在201上面验证一下:

MariaDB [mysqltest]> select * from user;

互为主从结构设置完毕

注意:如果同步不成功,首先要确保服务器3306端口打开的。

centos可以用service iptables stop关闭防火墙。

八、利用keepalived实现高可用

 

keepalived实现虚拟IP,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换;

1、keepalived设置:

201服务器上面,编辑keeplaived.conf配置文件:

[root@localhost /]# vi /usr/local/keepalived/etc/keepalived/keepalived.conf

配置文件内容如下:

! Configuration File for keepalived

global_defs {
   router_id mysql-ha
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 201
    priority 100
    advert_int 1
    nopreempt
    authentication {
        auth_type PASS
        auth_pass 123456
    }
    virtual_ipaddress {
        192.168.1.200
    }
}

virtual_server 192.168.1.200 3306 {
    delay_loop 2
    lb_algo rr
    lb_kind DR
    persistence_timeout 60
    protocol TCP
    real_server 192.168.1.201 3306 {
        weight 1
        notify_down /usr/local/keepalived/etc/keepalived/mysql.sh
        TCP_CHECK {
connect_port 3306
connect_timeout 3
nb_get_retry 2
delay_before_retry 1
        }
    }
}
~                

          

编辑mysql服务停止后的切换脚本:mysql.sh

[root@localhost /]# vi /usr/local/keepalived/etc/keepalived/mysql.sh

内容如下:

#!/bin/bash
pkill keepalived

2、启动201上面的keepalived

[root@localhost /]# /usr/local/keepalived/sbin/keepalived -f /usr/local/keepalived/etc/keepalived/keepalived.conf -D

查看:

启动成功后会有三个keepalived进程

此是在任一局域机器上面ping 192.168.1.200发现已经可以ping通,并且用192.168.1.200这个IP也能够连接到数据库服务器。

3、在202机器上面重复1、2步骤;

配置keepalived.conf文件的时候注意要把 

real_server 192.168.1.201 3306改为 real_server 192.168.1.202 3306

virtual_router_id 201 改为virtual_router_id 202

至此MariaDB+Keepalived双主高可用配置MySQL-HA设置完毕。

可以试着把201上面的mariaDB停止 

[root@localhost /]# service mariamysql stop;

会发现连接192.168.1.200还是可以连接上去的,keepalived会自动切换到202的服务器上面去。这样,当一台数据库服务器发生故障时,另一台服务器可以立即切换过来,保证高可用。


推荐阅读
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • 本文档详细介绍了2017年8月31日关于MySQL数据库备份与恢复的教学内容,包括MySQL日志功能、备份策略、备份工具及实战演练。 ... [详细]
  • 本文详细介绍了如何解决在使用本地SQlyog客户端尝试连接阿里云上的MariaDB数据库时遇到的2003错误,即无法连接到MySQL服务器的问题。 ... [详细]
  • centos 7.0 lnmp成功安装过程(很乱)
    下载nginx[rootlocalhostsrc]#wgethttp:nginx.orgdownloadnginx-1.7.9.tar.gz--2015-01-2412:55:2 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • CentOS 7 默认安装了 MariaDB,作为 MySQL 的一个分支。然而,出于特定需求,我们可能仍需在系统中安装 MySQL。本文将详细介绍如何通过 Yum 包管理器在 CentOS 7 上安装 MySQL,并提供一些常用的 MySQL 命令。 ... [详细]
  • 在重新安装Ubuntu并配置Django和PyCharm后,忘记测试MySQL连接,导致在后续配置过程中遇到错误:ERROR 2003 (HY000) - 无法连接到本地服务器 ‘127.0.0.1’ (111)。本文将详细介绍该错误的原因及解决步骤,帮助用户快速恢复MySQL服务的正常运行。我们将从检查网络配置、验证MySQL服务状态、配置防火墙规则等方面入手,提供全面的故障排除指南。 ... [详细]
author-avatar
李长倩63399
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有