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上。但是这些操作在客户端是完全看不出来区别的