利用keepalived+haproxy实现LVS负载均衡高可用集群

本文介绍了如何在四台Linux主机上利用keepalived确保服务高可用,以及使用haproxy进行负载均衡调度。详细步骤包括haproxy的安装、配置、日志文件修改,以及在遇到故障如服务器关闭时的处理策略。此外,还涉及了设置黑名单、上传功能的实现以及keepalived配置文件的编辑,确保在节点故障时能平滑切换。

实验环境
准备四台可以互相ping通的主机,其中server1,server2作为调度器server3,server4作为服务器,配置好yum仓库,关闭火墙和selinux
实验思路
用keepalived来实现服务的高可用,haproxy作为调度器
安装haproxy

yum install haproxy -y

修改haproxy配置文件

vim /etc/haproxy/haproxy.cfg

在这里插入图片描述
修改日志文件

vim /etc/rsyslog.conf

在这里插入图片描述
在这里插入图片描述

启动haproxy

systemctl start haproxy

测试
在这里插入图片描述
关闭server4的httpd
在这里插入图片描述
修改配置文件
在这里插入图片描述
当以path_beg参数开头以path_end参数结尾优先访问static服务
在这里插入图片描述
在server4默认发布目录下创建images目录,并且放入一个jpg格式文件
测试
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
编辑配置文件设置黑名单
在这里插入图片描述
测试
在这里插入图片描述
这样的界面显然是很不友好的,可以将报错转入另一个网址
当黑名单IP访问时会转入百度页面
在这里插入图片描述
设置上传
在这里插入图片描述
在server4上编辑上传界面

vim /var/www/html/index.php
<html>
<body>

<form action="upload_file.php" method="post"
enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file" />
<br />
<input type="submit" name="submit" value="Submit" />
</form>

</body>
</html>

设置上传参数

vim upload_file.php
<?php
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/pjpeg"))
&& ($_FILES["file"]["size"] < 2000000))
  {
  if ($_FILES["file"]["error"] > 0)
    {
    echo "Return Code: " . $_FILES["file"]["error"] . "<br />";
    }
  else
    {
    echo "Upload: " . $_FILES["file"]["name"] . "<br />";
    echo "Type: " . $_FILES["file"]["type"] . "<br />";
    echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
    echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";

    if (file_exists("upload/" . $_FILES["file"]["name"]))
      {
      echo $_FILES["file"]["name"] . " already exists. ";
      }
    else
      {
      move_uploaded_file($_FILES["file"]["tmp_name"],
      "upload/" . $_FILES["file"]["name"]);
      echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
      }
    }
  }
else
  {
  echo "Invalid file";
  }
?>

建立上传目录,并赋予权限

mkdir /var/www/html/upload
chmod 777 /var/www/html/upload

测试
在这里插入图片描述
上传测试
选择上传文件
在这里插入图片描述
开始上传
在这里插入图片描述
上传成功
在这里插入图片描述
查看
在server4的/var/www/html/upload
在这里插入图片描述
编辑keepalived配置文件
在这里插入图片描述
在这里插入图片描述
编辑keepalived和haproxy绑定脚本

vim /opt/check_haproxy
#!/bin/bash
systemctl status haproxy
if [ "$?" -ne "0" ]
then
        systemctl restart haproxy
        if [ "$?" -ne "0" ]
        then
                systemctl stop keepalived
        fi
fi
chmod +x /opt/check_haproxy 

将配置好的文件发送至第二个调度器节点

scp /etc/haproxy/haproxy.cfg server2:/etc/haproxy/
scp /etc/keepalived/keepalived.conf server2:/etc/keepalived/
scp /opt/check_haproxy.sh server2:/opt/

在第二个节点修改keepalived配置文件
在这里插入图片描述

在这里插入图片描述
启动服务

systemctl start haproxy
systemctl start keepalived

测试:关闭第一个节点haproxy,资源会被第二个节点接管
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值