Keepalived双机热备——Haproxy搭建web群集

一、认识keepalived

keepalived是一个开源的软件,用于实现高可用性和负载均衡。它主要用于在多个服务器之间提供故障转移和负载均衡的功能。keepalived可以监控服务器的状态,并在主服务器发生故障时自动将备份服务器切换为主服务器,以确保服务的连续性。

keepalived的主要特点包括:

  1. VRRP协议支持:keepalived使用虚拟路由冗余协议(VRRP)来实现故障转移。VRRP允许多个服务器共享一个虚拟IP地址,当主服务器不可用时,备份服务器会接管该IP地址。
  2. 健康检查:keepalived可以定期检查服务器的健康状态,例如检查服务器的网络连接、CPU负载、内存使用等。如果服务器的健康状态不正常,keepalived会将其标记为不可用,并将流量转发到其他可用的服务器。
  3. 负载均衡:keepalived还支持基于轮询、加权轮询、源IP哈希等算法的负载均衡。它可以将流量均匀地分发到多个服务器上,提高系统的性能和可扩展性。
  4. 配置灵活:keepalived的配置文件采用简单易懂的语法,可以根据实际需求进行灵活配置。用户可以定义虚拟IP地址、服务器组、健康检查参数等

二、认识Haproxy 

Haproxy是一款可以供高可用性、负载均衡和基于TCP和HTTP应用的代理软件

  • 适用于负载较大的站点
  • 运行在硬件上可支持数以万计的并发连接请求

 三、实验案例

3.1 实验拓扑图:

 

3.2 实验需求:

 实验环境

虚拟机 3台 centos7.9

网卡NAT模式 数量 1

组件包Haproxy nginx(httpd)

设备

IP

备注

Centos01

192.168.160.51

Node1

Centos02

192.168.160.53

Web1

Centos03

192.168.160.54

Web2

3.3 初始配置:

关闭防火墙:

Systemctl disable firewalld --now

关闭 selinux:

setenforce 0
sed -i 's/SELINUX=.*/SELINUX=disabled/g' /etc/selinux/config

 3.4 编译安装Haproxy :

将haproxy安装包上传至node1安装组件 node1配置

yum -y install pcre-devel bzip2-devel gcc gcc-c++ make

 解压缩安装包:

tar zxf haproxy-1.5.19.tar.gz 
cd haproxy-1.5.19
make TARGET=linux26 && make install

 创建主配置文件:

[root@xiao ~]# mkdir /etc/haproxy
[root@xiao ~]# cp examples/haproxy.cfg /etc/haproxy/

添加群集信息:

[root@xiao haproxy-1.5.19]# vim /etc/haproxy/haproxy.cfg 



global
        log 127.0.0.1   local0
        log 127.0.0.1   local1 notice
        #log loghost    local0 info
        maxconn 4096
        chroot /usr/share/haproxy
        uid 99
        gid 99
        daemon
        #debug
        #quiet

defaults
        log     global
        mode    http
        option  httplog
        option  dontlognull
        retries 3
        redispatch
        maxconn 2000
        contimeout      5000
        clitimeout      50000
        srvtimeout      50000


listen  web 0.0.0.0:80
        option  httpchk GET /index.html
        balance roundrobin
        server  inst1 192.168.10.53:80 check inter 2000 fall 3
        server  inst2 192.168.10.54:80 check inter 2000 fall 3

 创建群集根目录:

[root@xiao haproxy-1.5.19]# mkdir /usr/share/haproxy

添加 haproxy系统服务:

[root@xiao haproxy-1.5.19]# cp examples/haproxy.init /etc/init.d/haproxy
[root@xiao haproxy-1.5.19]# ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy
[root@xiao haproxy-1.5.19]# chmod +x /etc/init.d/haproxy
[root@xiao haproxy-1.5.19]# chkconfig --add haproxy

[root@xiao haproxy-1.5.19]# systemctl start haproxy    开启服务

3.5 安装Nginx 节点配置将nginx安装包上传至web1和web2:

安装组件:

[root@xiao1 nginx-1.24.0]# yum -y install pcre-devel zlib-devel gcc gcc-c++ make

创建nginx用户 :

[root@xiao1 nginx-1.24.0]# useradd -M -s /sbin/nologin nginx

 解压文件并编译安装:

[root@wei1 nginx-1.24.0]# tar zxf nginx-1.24.0.tar.gz 
[root@wei1 nginx-1.24.0]# cd nginx-1.24.0/
[root@wei1 nginx-1.24.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
[root@wei1 nginx-1.24.0]# make && make install
[root@wei1 nginx-1.24.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

[root@wei1 nginx-1.24.0]# nginx  开启nginx

.四、实验结果:

 

 

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值