haproxy负载均衡1

haproxy也可以实现负载均衡,环境依旧是两台调度器,两台服务端
1.

[root@server1 ~]# yum install haproxy -y

在调度器上安装haproxy
编辑其配置文件
haproxy负载均衡1
haproxy负载均衡1
haproxy自带健康监测

[root@server3 ~]# systemctl stop httpd
[root@chihao Desktop]# curl 172.25.254.11
server2
[root@chihao Desktop]# curl 172.25.254.11
server2
[root@chihao Desktop]# curl 172.25.254.11
server2
[root@server3 ~]# systemctl start httpd.service 
[root@chihao Desktop]# curl 172.25.254.11
server2
[root@chihao Desktop]# curl 172.25.254.11
server3
[root@chihao Desktop]# curl 172.25.254.11
server2
[root@chihao Desktop]# curl 172.25.254.11
server3

haproxy负载均衡1
在配置文件添加这个命令,可以通过web形式监控后台

[root@server1 haproxy]# systemctl restart haproxy.service 

haproxy负载均衡1
当任何一个server断电,都会有显示:

[root@server2 ~]# systemctl stop httpd

haproxy负载均衡1

[root@server2 ~]# systemctl start httpd

haproxy负载均衡1
恢复正常
2.添加认证
haproxy负载均衡1

[root@server1 ~]# systemctl restart haproxy.service 

重启haproxy
haproxy负载均衡1
3.日志记录

[root@server1 ~]# vim /etc/rsyslog.conf

haproxy负载均衡1
haproxy负载均衡1
haproxy负载均衡1
打开udp端口,让local2的日志不要存放在messages里,并且重启后自动生成haproxy的日志文件
haproxy负载均衡1
在haproxy的配置文件中可以找到这个模板

[root@server1 ~]# systemctl restart rsyslog.service 

模拟客户端访问调度器:

[westos@chihao Desktop]$ curl 172.25.254.11
server2
[westos@chihao Desktop]$ curl 172.25.254.11
server3
[westos@chihao Desktop]$ curl 172.25.254.11
server2
[westos@chihao Desktop]$ 
[westos@chihao Desktop]$ curl 172.25.254.11
server3
[root@server1 ~]# cat /var/log/haproxy.log 
Aug  3 13:13:37 localhost haproxy[4141]: 172.25.254.1:49282 [03/Aug/2021:13:13:37.825] main app/app1 0/0/0/1/1 200 284 - - ---- 1/1/0/1/0 0/0 "GET / HTTP/1.1"
Aug  3 13:13:38 localhost haproxy[4141]: 172.25.254.1:49284 [03/Aug/2021:13:13:38.208] main app/app2 0/0/0/1/1 200 284 - - ---- 1/1/0/1/0 0/0 "GET / HTTP/1.1"
Aug  3 13:13:38 localhost haproxy[4141]: 172.25.254.1:49286 [03/Aug/2021:13:13:38.556] main app/app1 0/0/0/1/1 200 284 - - ---- 1/1/0/1/0 0/0 "GET / HTTP/1.1"
Aug  3 13:13:39 localhost haproxy[4141]: 172.25.254.1:49288 [03/Aug/2021:13:13:39.639] main app/app2 0/0/0/1/1 200 284 - - ---- 1/1/0/1/0 0/0 "GET / HTTP/1.1"

在调度器上可以看到访问的日志
4.修改调度策略
haproxy负载均衡1
修改为如图的策略,当url满足如图的条件时,会调度到3上面。(begin:/images时,ending:.png时,backend后端为 13)
当按照这个修改后的策略进行调度时:

[root@server3 images]# pwd
/var/www/html/images
[root@server3 images]# ls
test.png

haproxy负载均衡1
就按照如策略所示调度到3的指定的图片界面
5.读写分离
通过修改haproxy的配置文件实现读写分离,读的时候调度2的内容,上传调度3的内容
haproxy负载均衡1
读的时候读默认的app,写的时候写static里的
haproxy负载均衡1
这是读的结果

[root@server3 html]# ls
images  index.html  index.php  upload  upload_file.php
[root@server3 html]# pwd
/var/www/html
[root@server3 html]# yum install php -y

在3上安装php,并且编辑一个php的上传文件

[root@server3 html]# cat 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>
[root@server3 html]# cat 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";
  }
?>

这两个文件里的内容不重要,是为实现读写分离看效果
同样的在2中也编辑好这些文件,可以通过scp把3上已经编辑好的内容 复制过去

[root@server2 html]# yum install php -y
[root@server2 html]# ls
index.html  index.php  upload  upload_file.php
[root@server2 html]# pwd
/var/www/html

2中也已经完成了这个配置
haproxy负载均衡1
此时,这个界面其实是调度2生成的,但是如果上传内容的话,就会调度到3上
haproxy负载均衡1
随便上传一个符合上传要求的文件

[root@server2 html]# ls upload/
[root@server3 html]# ls upload/
iso7.gif

此时,同样的目录中,2是没有刚才上传的文件的 ,但是3有
说明做到了调度的读写分离
即当只是访问时,调度到2上,当上传时,调度到3上。但是这些操作在客户端是完全看不出来区别的

上一篇:企业运维实战--k8s高可用集群部署


下一篇:Haproxy搭建Web群集