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

mysql和haproxy高可用

这片文章主要介绍mysql+haproxy+keepalived的高可用使用。有两种模式:第一种:数据库宕机触发VIP漂移的高可用使用。第二种:haproxy宕机出发VIP漂移的高

这片文章主要介绍mysql+haproxy+keepalived的高可用使用。

有两种模式:

第一种:数据库宕机触发VIP漂移的高可用使用。

第二种:haproxy宕机出发VIP漂移的高可用。

这两种模式的底层数据库均为双主模式或者MGR的多主模式,mariadb的galera模式,percona的pxc模式;也就是底层的数据库每一个都可写。

在双主的模式下,如果添加了haproxy这一层,那么就可以实现了数据库读写的负载均衡,VIP随着haproxy的状态而漂移,即上面提到的第一种情况。

如果没有加入haproxy这一层,那么就只实现了双主模式数据库的高可用,即一个数据库宕机,则VIP漂移,VIP随着数据库的状态而漂移,即上面提到的第二种情况。

下面分别来说明这两种情况的使用。

双主模式的数据库: 10.9.8.201和10.9.8.223

VIP地址: 10.9.8.120

【因服务器资源限制,因此只使用此两台服务器】

数据库宕机触发VIP漂移

已经配置好的双主模式数据库。然后在两个服务器上分别下载keepalive软件,直接yum安装即可。

keepalived的配置文件有很长,原因是里面有lvs的配置,这里只需要部分配置即可,如下:

[root@test1 keepalived]# vim /etc/keepalived/keepalived.conf 
! Configuration File for keepalived
global_defs {
   router_id LVS_DB2
}
vrrp_script check_haproxy {
    script "/etc/keepalived/check_mysql.sh"
    interval 3
    weight -5}
vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {        10.9.8.120 dev ens33
    }
    track_script {
        check_haproxy
    }
}

检测脚本内容如下:脚本内容很简单,就是检查mysql进程是否存在,若是不存在,则停止当前的keepalive,让其VIP进行漂移。【要给检测脚本加上可执行的权限】

#!/bin/bashif [ $(ps -C mysqld --no-header | wc -l) -eq 0 ]; then
    service keepalived stopfi

上面就是master的配置,做为backup的keepalived的配置和上面基本一样,只需要更改router_id,state,priority三个值即可。

state值的说明,主和备keepalived的state的值均可以设置为BACKUP,这样的话,先启动的服务器即为主,当发生VIP漂移后,原来的主启动后VIP不会再发生漂移,可以减少网络抖动的影响。

测试:

[root@test1 keepalived]# ip addr1: lo:mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever2: ens33:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:01:9c:98 brd ff:ff:ff:ff:ff:ff
    inet 10.9.8.201/22 brd 10.9.11.255 scope global ens33
       valid_lft forever preferred_lft forever    inet 10.9.8.120/32 scope global ens33
       valid_lft forever preferred_lft forever
    inet6 fe80::744a:3948:cdf2:1976/64 scope link 
       valid_lft forever preferred_lft forever
[root@test1 keepalived]# ps uax |grep mysql
root      60710  0.0  0.0  11764  1632 pts/0    S    15:21   0:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql/data --pid-file=/data/mysql/data/test1.pid
mysql     62092  0.0 16.5 2190032 309408 pts/0  Sl   15:21   0:01 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/data/mysql/log/error.log --open-files-limit=65535 --pid-file=/data/mysql/data/test1.pid --socket=/data/mysql/run/mysql.sock --port=3306root      63704  0.0  0.0 112648   960 pts/0    R+   16:00   0:00 grep --color=auto mysql
[root@test1 keepalived]#

主上面的VIP存在以及mysql服务存在。停掉主上面的mysql服务,查看VIP是否漂移。【主上的VIP已经不存在】

[root@test1 keepalived]# service mysqld stop
Shutting down MySQL........... SUCCESS! [root@test1 keepalived]# ip addr1: lo:mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever2: ens33:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:01:9c:98 brd ff:ff:ff:ff:ff:ff
    inet 10.9.8.201/22 brd 10.9.11.255 scope global ens33
       valid_lft forever preferred_lft forever
    inet6 fe80::744a:3948:cdf2:1976/64 scope link 
       valid_lft forever preferred_lft forever
[root@test1 keepalived]# ps aux |grep mysql
root      63933  0.0  0.0 112648   956 pts/0    R+   16:01   0:00 grep --color=auto mysql
[root@test1 keepalived]#

在back上面查看VIP是否存在: 【可以看到VIP已经漂移到BACKUP上面】

[root@monitor keepalived]# ip addr1: lo:mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever2: ens33:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:7c:ae:10 brd ff:ff:ff:ff:ff:ff
    inet 10.9.8.223/22 brd 10.9.11.255 scope global ens33
       valid_lft forever preferred_lft forever    inet 10.9.8.120/32 scope global ens33
       valid_lft forever preferred_lft forever
    inet6 fe80::d4e4:4f75:1be6:2134/64 scope link 
       valid_lft forever preferred_lft forever3: docker0:mtu 1500 qdisc noqueue state DOWN 
    link/ether 02:42:25:78:a0:39 brd ff:ff:ff:ff:ff:ff
    inet 172.17.0.1/16 brd 172.17.255.255 scope global docker0
       valid_lft forever preferred_lft forever
[root@monitor keepalived]#

上面的实例中VIP随着数据库的状态而漂移。

HAPROXY状态触发VIP漂移

在这个架构下,其实就是在上面mysql+keepalived的架构中插入一层,使用haproxy做负载均衡。

在两台机器上分别安装haproxy,直接yum安装即可,haproxy的配置很简单,就是做一个负载均衡。

配置很简单,haproxy的两个服务器都是用同样的配置。【需要说明,因为后面访问的是mysql,因此需要使用四层负载均衡,mode需要选择tcp】

#---------------------------------------------------------------------# Example configuration for a possible web application.  See the
# full configuration options online.
#
#   http://haproxy.1wt.eu/download/1.4/doc/configuration.txt#
#---------------------------------------------------------------------#---------------------------------------------------------------------# Global settings
#---------------------------------------------------------------------global
    # to have these messages end up in /var/log/haproxy.log you will
    # need to:
    #
    # 1) configure syslog to accept network log events.  This is done
    #    by adding the '-r' option to the SYSLOGD_OPTIONS in
    #    /etc/sysconfig/syslog
    #
    # 2) configure local2 events to go to the /var/log/haproxy.log
    #   file. A line like the following can be added to
    #   /etc/sysconfig/syslog
    #
    #    local2.*                       /var/log/haproxy.log
    #
    log         127.0.0.1 local2    chroot      /var/lib/haproxy
    pidfile     /var/run/haproxy.pid
    maxconn     4000
    user        haproxy
    group       haproxy
    daemon
    # turn on stats unix socket
    stats socket /var/lib/haproxy/stats
#---------------------------------------------------------------------# common defaults that all the 'listen' and 'backend' sections will
# use if not designated in their block
#---------------------------------------------------------------------defaults
    mode                    http
    log                     global
    option                  httplog
    option                  dontlognull
    option http-server-close
    option forwardfor       except 127.0.0.0/8
    option                  redispatch
    retries                 3
    timeout http-request    10s
    timeout queue           1m
    timeout connect         10s
    timeout client          1m
    timeout server          1m
    timeout http-keep-alive 10s
    timeout check           10s
    maxconn                 3000#---------------------------------------------------------------------# main frontend which proxys to the backends
#---------------------------------------------------------------------frontend mysql    mode tcp
    bind *:6039
    default_backend back_mysql
#---------------------------------------------------------------------# static backend for serving up images, stylesheets and such
#---------------------------------------------------------------------backend back_mysql    mode  tcp
    balance     roundrobin
    server  db1 10.9.8.201:3306 check
    server  db2 10.9.8.223:3306 check

然后修改keepalived的检测脚本,上面的模式检查的是mysql的状态,这一次检查的是haproxy的状态。

! Configuration File for keepalived
global_defs {
   router_id LVS_DB2
}
vrrp_script check_haproxy {    script "/etc/keepalived/check_haproxy_status.sh"
    interval 3
    weight -5}
vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 51
    priority 9
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {        10.9.8.120 dev ens33
    }
    
    track_script {
        check_haproxy
    }
}

脚本内容如下:

#!/bin/bashif [ $(ps -C haproxy --no-header | wc -l) -eq 0 ];then
    sudo service keepalived stopfi

修改完之后重启keepalive即可。

加入了haproxy需要说明的是,在连接数据库的时候需要使用VIP+haproxy_PORT,上面我们配置haproxy监听了6039端口,那么连接的时候就是用VIP+6039端口。

 


推荐阅读
  • 在开发过程中,我最初也依赖于功能全面但操作繁琐的集成开发环境(IDE),如Borland Delphi 和 Microsoft Visual Studio。然而,随着对高效开发的追求,我逐渐转向了更加轻量级和灵活的工具组合。通过 CLIfe,我构建了一个高度定制化的开发环境,不仅提高了代码编写效率,还简化了项目管理流程。这一配置结合了多种强大的命令行工具和插件,使我在日常开发中能够更加得心应手。 ... [详细]
  • 本文详细介绍了在 CentOS 7 系统中配置 fstab 文件以实现开机自动挂载 NFS 共享目录的方法,并解决了常见的配置失败问题。 ... [详细]
  • vsftpd配置(虚拟用户、匿名用户登录)
    一、ftp服务搭建(一)概述1.ftp连接及传输模式(1)控制连接TCP21,用于发送FTP命令信息 ... [详细]
  • 阿里云服务器搭建详解——Ubuntu
    由于自己电脑配置跟不上,双系统一开,整个电脑就会变得非常卡顿,所以决定在阿里云买一个云服务器。听朋友说,学生买的话是非常便宜 ... [详细]
  • 为什么多数程序员难以成为架构师?
    探讨80%的程序员为何难以晋升为架构师,涉及技术深度、经验积累和综合能力等方面。本文将详细解析Tomcat的配置和服务组件,帮助读者理解其内部机制。 ... [详细]
  • 基于iSCSI的SQL Server 2012群集测试(一)SQL群集安装
    一、测试需求介绍与准备公司计划服务器迁移过程计划同时上线SQLServer2012,引入SQLServer2012群集提高高可用性,需要对SQLServ ... [详细]
  • Spring Boot 中配置全局文件上传路径并实现文件上传功能
    本文介绍如何在 Spring Boot 项目中配置全局文件上传路径,并通过读取配置项实现文件上传功能。通过这种方式,可以更好地管理和维护文件路径。 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • CentOS 7 中 iptables 过滤表实例与 NAT 表应用详解
    在 CentOS 7 系统中,iptables 的过滤表和 NAT 表具有重要的应用价值。本文通过具体实例详细介绍了如何配置 iptables 的过滤表,包括编写脚本文件 `/usr/local/sbin/iptables.sh`,并使用 `iptables -F` 清空现有规则。此外,还深入探讨了 NAT 表的配置方法,帮助读者更好地理解和应用这些网络防火墙技术。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • 服务器部署中的安全策略实践与优化
    服务器部署中的安全策略实践与优化 ... [详细]
  • 在本文中,我们将探讨如何在Docker环境中高效地管理和利用数据库。首先,需要安装Docker Desktop以确保本地环境准备就绪。接下来,可以从Docker Hub中选择合适的数据库镜像,并通过简单的命令将其拉取到本地。此外,我们还将介绍如何配置和优化这些数据库容器,以实现最佳性能和安全性。 ... [详细]
  • 本文详细介绍了在CentOS 6.5 64位系统上使用阿里云ECS服务器搭建LAMP环境的具体步骤。首先,通过PuTTY工具实现远程连接至服务器。接着,检查当前系统的磁盘空间使用情况,确保有足够的空间进行后续操作,可使用 `df` 命令进行查看。此外,文章还涵盖了安装和配置Apache、MySQL和PHP的相关步骤,以及常见问题的解决方法,帮助用户顺利完成LAMP环境的搭建。 ... [详细]
  • 对于希望在未越狱的iOS设备上修改Hosts文件的苹果用户来说,了解文件的具体位置和操作步骤至关重要。本文将详细介绍如何通过安装最新版本的iTunes来实现这一目标,并提供实用的操作指南,帮助用户轻松完成Hosts文件的编辑。 ... [详细]
  • Amoeba 通过优化 MySQL 的读写分离功能显著提升了数据库性能。作为一款基于 MySQL 协议的代理工具,Amoeba 能够高效地处理应用程序的请求,并根据预设的规则将 SQL 请求智能地分配到不同的数据库实例,从而实现负载均衡和高可用性。该方案不仅提高了系统的并发处理能力,还有效减少了主数据库的负担,确保了数据的一致性和可靠性。 ... [详细]
author-avatar
郝韵G
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有