实验环境
准备四台可以互相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,资源会被第二个节点接管


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

7456

被折叠的 条评论
为什么被折叠?



