实验环境
- 在linux环境中,通过母盘是redhat7.6的操作系统,克隆搭建四台域名分别为node1,node2, node3,node4; 主机名分别为server1,server2,server3, server4的四台虚拟机。(名称可以任选)
- 给四台主机分别配置好各自的ip地址和dns地址解析,实现四台虚拟机可以互相ping通。
对于虚拟机的ip和对应的dns解析可以参考
- 配置好四台主机的yum源仓库,(可以通过宿主机的httpd服务,搭建网络仓库)
- 关闭掉所有虚拟机的防火墙,并将所有主机的selinux设置为disabled状态
利用haproxy对后端服务器server3,server4做负载均衡
实现步骤
- 在server2上
yum install haproxy -y
修改配置文件
- 重启服务,并确保server3,server4上的httpd服务打开,测试
具有对后端服务器健康检查的功能
- 可以通过网页上查看后端server的状态信息
- 由于haproxy的日志信息放在local2上,可以通过修改
/etc/rsyslog.conf
来生成访问日志
systemctl restart rsyslog.service
重启日志服务,访问测试
cat /var/log/haproxy.log
自身定义的日志存放地址
source 调度算法
源地址-hash算法,和nginx的ip_hash 算法很像,通过源地址的ip来访问 指定的后端服务器,
haproxy 的动态和静态分离
测试:
haproxy 的acl 规则书写
黑名单
测试:
当被禁止访问了之后,可以选择不显示被禁止的页面,可以导到另一个界面
测试:
上传控制
修改配置文件
在server3和server4的httpd默认发布目录,建立上传界面,和上传参数
上传界面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>
设置上传参数 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";
}
?>
需要下载 yum install php -y
上传测试: