Haproxy实现负载均衡---动静分离

àì夳堔傛蜴生んèń 2023-07-13 04:20 83阅读 0赞

文章目录

  • 1.在haproxy端配置动静分离策略
  • 2.在haproxy端配置http
  • 3.动态测试:
  • 4.静态测试

1.在haproxy端配置动静分离策略

  1. cd /etc/haproxy
  2. vim haproxy.cfg
  3. 注释掉9396行内容,写入动静分离的策略:
  4. 64 acl url_static path_beg -i /images #(以/images开头 默认根目录)
  5. 65 acl url_static path_end -i .jpg .gif .png
  6. 66 use_backend static if url_static
  7. 67 default_backend app
  8. 73 backend static
  9. 74 # balance roundrobin
  10. 75 server static 172.25.254.3:80 check
  11. 80 backend app
  12. 81 balance roundrobin
  13. 82 server web1 172.25.254.2:80 check
  14. 83 server web2 172.25.254.1:8000 check

写入的这部分内容表示:如果匹配到/images开始或者以.jpg .gif .png结尾的请求,则为静态,连接到server3;否则为动态,连接到server1或server2轮询。
在这里插入图片描述

2.在haproxy端配置http

在server1上安装httpd服务,且更改httpd服务的工作端口为8000,添加web服务的资源

  1. yum install httpd -y #也可以做诶一台http服务器
  2. cd /var/www/html/
  3. vim index.html
  4. vim /etc/httpd/conf/httpd.conf #修改端口为8000,不然会与haproxy的80端口冲突
  5. 42 Listen 8000
  6. systemctl start httpd

重启haproxy:

  1. systemctl restart haproxy

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

3.动态测试:

  1. curl 172.25.254.1 #在server1和server2之间轮询

在这里插入图片描述
把server1做为backup:

  1. vim haproxy.cfg
  2. 80 backend app
  3. 81 # balance roundrobin
  4. 82 server web1 172.25.254.2:80 check
  5. 83 server web2 172.25.254.1:8000 check backup #备用
  6. systemctl restart haproxy

在这里插入图片描述
测试:

  1. curl 172.25.254.1 #只能看到后端的server2

在这里插入图片描述
关闭server2的http:

  1. systemctl stop httpd
  2. curl 172.25.254.1 #备用server1开始工作

在这里插入图片描述

4.静态测试

在server3中:

在server3的httpd服务的默认发布目录里,新建images目录,放置.jpg的图片。

  1. cd /var/www/html/
  2. mkdir images #在目录中放一张图片

在这里插入图片描述
测试:

  1. 访问172.25.254.1/images---可以看到该图片
  2. server1中并没有图片资源,haproxy直到我们要访问的是静态资源,所以帮我们定位到了server3上。

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

发表评论

表情:
评论列表 (有 0 条评论,83人围观)

还没有评论,来说两句吧...

相关阅读