ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

haproxy负载均衡1

2021-08-03 20:06:08  阅读:186  来源: 互联网

标签:haproxy 负载 均衡 13 html file 172.25 root


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

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

在调度器上安装haproxy
编辑其配置文件
在这里插入图片描述
在这里插入图片描述
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

在这里插入图片描述
在配置文件添加这个命令,可以通过web形式监控后台

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

在这里插入图片描述
当任何一个server断电,都会有显示:

[root@server2 ~]# systemctl stop httpd

在这里插入图片描述

[root@server2 ~]# systemctl start httpd

在这里插入图片描述
恢复正常
2.添加认证
在这里插入图片描述

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

重启haproxy
在这里插入图片描述
3.日志记录

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

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
打开udp端口,让local2的日志不要存放在messages里,并且重启后自动生成haproxy的日志文件
在这里插入图片描述
在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.修改调度策略
在这里插入图片描述
修改为如图的策略,当url满足如图的条件时,会调度到3上面。(begin:/images时,ending:.png时,backend后端为 13)
当按照这个修改后的策略进行调度时:

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

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

[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中也已经完成了这个配置
在这里插入图片描述
此时,这个界面其实是调度2生成的,但是如果上传内容的话,就会调度到3上
在这里插入图片描述
随便上传一个符合上传要求的文件

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

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

标签:haproxy,负载,均衡,13,html,file,172.25,root
来源: https://blog.csdn.net/AwesomeWang7/article/details/119253142

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有