haproxy的学习与使用追加篇--读写分离,动静分离

在上一章博客中我们学习过了haproxy的配置,实现负载均衡等,那么我们在使用时我们经常会更具需求使得后端服务器显示的界面是不一样的

动静分离

1.在server2中书写httpd默认发布目录index.html
在这里插入图片描述
2.在server3中的httpd默认发布目录写index.php(php测试界面)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注意:书写了php界面后需要重启httpd
3.在server1配置haproxy的配置文件

# The public 'www' address in the DMZ

frontend public
bind *:80 name clear
#bind 192.168.1.10:443 ssl crt /etc/haproxy/haproxy.pem

    stats uri       /admin/stats
    #use_backend     static if { hdr_beg(host) -i img }
    use_backend     dynamic if { path_end .php   } 如果以.php结尾访问动态界面
    default_backend static		#默认访问静态界面

    #errorloc 403 http://172.25.77.1:8080/index.html
# the application servers go here
backend static		##静态后端
    balance         roundrobin
    server          web1 172.25.77.2:80 check inter 1000
backend dynamic		##动态后段         
    balance         roundrobin
    server          web2 172.25.77.3:80 check inter 1000

在这里插入图片描述
在这里插入图片描述
4.浏览器测试

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

读写分离

在上面我们根据动静将后端服务器分开,那么我们也可以根据读写将后端分开,根据读写的要求访问不同的后端
1.配置server1的haproxy的配置文件设置读写分离

frontend public
    acl read method HEAD	#HEAD读
    acl read method GET	#GET读
    acl write method POST	#POST写
    acl write method PUT	#PUT写
    bind            *:80 name clear
    #bind            192.168.1.10:443 ssl crt /etc/haproxy/haproxy.pem

    stats uri       /admin/stats
    use_backend     static if write	#如果动作是写的话访问static
    use_backend     dynamic if read		#如果动作是读的话访问dynamic
    default_backend static	#默认访问static

    #errorloc 403 http://172.25.77.1:8080/index.html
# the application servers go here
backend static
    balance         roundrobin
    server          web1 172.25.77.2:80 check inter 1000
backend dynamic
    balance         roundrobin
    server          web2 172.25.77.3:80 check inter 1000

在这里插入图片描述
2.server2(写后端)书写默认发布界面
在这里插入图片描述

index.php:选择图片的静态界面
upload_file.php:上传图片的动态界面
upload:存放上传图片的目录

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))   # 上传图片的大小(k为单位),可以自己调节大小
  {
  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";  # 不符合上传条件显示Invalid file
  }
?>

3.将同样的两个文件发送给server3,然后server2和server3重启httpd
在这里插入图片描述
4.浏览器测试
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_42446031/article/details/89515422