RedHat 7配置HAProxy实现Web负载均衡


本文将简单介绍使用HAProxy实现web负载均衡,主要内容包括基于权重的轮询、为HAProxy配置https、配置http重定向为https、配置HAProxy使用独立日志。

一、测试环境

HAProxy:

主机名:RH7-HAProxy

IP地址:192.168.10.20

操作系统:Red Hat Enterprise Linux Server release 7.2 (Maipo)最小化安装

防火墙与SELinux:关闭

安装的服务:HAProxy-1.5.14

WEB01:

主机名:RH7-Web-01

IP地址:192.168.10.21

操作系统:Red Hat Enterprise Linux Server release 7.2 (Maipo)最小化安装

防火墙与SELinux:关闭

安装的服务:Apache-httpd 2.4

WEB02:

主机名:RH7-Web-02

IP地址:192.168.10.22

操作系统:Red Hat Enterprise Linux Server release 7.2 (Maipo)最小化安装

防火墙与SELinux:关闭

安装的服务:Apache-httpd 2.4

本文原始出处:江健龙的技术博客http://jiangjianlong.blog.51cto.com/3735273/1887279


二、WEB页面访问测试

1、使用浏览器访问两台web的IP地址,能成功访问到不同的页面,方便我们后面直观地观察负载均衡的效果。由于Apache的安装配置不是本文重点,具体可参考本人之前的博文《RedHat 7安装配置Apache 2.4》(http://jiangjianlong.blog.51cto.com/3735273/1858650

wKioL1hjY7GQIT2oAAB9sPo9Z-Q977.png

2、在RH7-HAProxy上也访问一下两台Web,确认也可以正常访问

wKiom1hjY5my1D1pAABulDydIV4123.png


三、安装配置HAProxy

1、[root@RH7-HAProxy~]yum -y install haproxy

2、[root@RH7-HAProxy~]systemctl start haproxy

3、[root@RH7-HAProxy~]systemctl enable haproxy

4、[root@RH7-HAProxy~]mv /etc/haproxy/haproxy.cfg /etc/haproxy/haproxy.cfg.bak

5、[root@RH7-HAProxy~]vi /etc/haproxy/haproxy.cfg

增加以下内容,然后重启haproxy服务

wKioL1hjZI-TnbmOAAFiHSs_B5w667.png

6、使用浏览器访问HAProxy的IP地址,多次刷新,成功实现轮询访问web01和web02

wKiom1hjZMOzES0YAAA0FRdLgmQ728.png

wKiom1hjZMTzYzLQAAA2NC2WYNo532.png

7、登录haproxy的后台

wKioL1hjZMSyRdUlAAB4xS9bihc152.png

8、可以看到访问web01和web02的相关统计数据

wKiom1hjZzHgtbgXAAHcY_QxeQU748.png

9、修改haproxy的配置文件,将web01的权重改为3,web02的权重仍为1,这样访问到两台web的比例应该为3:1,改好后重启下haproxy服务

wKiom1hkorqiG64bAAGSVaS8aEs493.png10、再次通过浏览器访问HAProxy的IP地址,多次刷新进行访问测试

11、再次登录HAProxy后台查看统计数据,可以看到访问到web01和web02的比例为3:1

wKioL1hko3rye2kVAAHH_SsL3qc068.png


四、配置HAProxy使用Https加密访问

1、采用客户端到HAProxy使用https、HAProxy到WEB端使用http的方式,只需要在HAProxy上配置证书,这里我们就配置一张自签名证书来测试一下

wKioL1hjZMbSpW03AAIh2oV7Tlo001.png

2、查看一下配置好的证书jiangjianlong.pem

wKiom1hjZMiTt4wYAAO3H-_Vv_Q107.png

3、修改HAProxy的配置文件,增加以下参数后重启haproxy服务

wKioL1hjZM-hxDCOAAGVHbfsLho625.png

4、使用https协议访问HAProxy的IP地址,提示证书存在问题,这是因为自签名证书不受浏览器信任,但说明上文配置的证书已经生效了,点击继续浏览此网站

wKioL1hjZMvC1x8qAACyAaI6wnc031.png

5、成功访问到Web01页面,刷新也能访问到Web02,说明在https的加密访问下负载均衡也没问题

wKioL1hjZMzxoQhMAAA70pipI_0221.png

wKiom1hjZMzTxlUYAAA8X6cXllA765.png

6、通过hosts解析配置一个域名指向HAProxy的IP地址,也能正常访问

wKioL1hjZM3xWjFZAAA8oj4Oj-g215.png

7、查看下证书信息,跟我们创建的证书信息一致

wKiom1hjZM2g_mJEAABSkHpo0NI309.png

wKiom1hjZM7yVTDoAABtEJWmnbo666.png

8、配置http重定向,自动将http重定向为https,修改haproxy配置文件,增加以下参数,并重启服务

wKioL1hkpmqxojBkAABKa8RefkM777.png

9、使用浏览器测试,成功实现http自动重定向为https进行访问,但由于截图无法呈现这个动态的效果,就不截了。


五、配置HAProxy使用独立日志文件

本文原始出处:江健龙的技术博客http://jiangjianlong.blog.51cto.com/3735273/1887279

1、HAProxy的日志默认写入到系统日志中去,我们可以把它独立出来,方便排查管理。编辑/etc/rsyslog.conf,按下图进行修改

wKiom1hkqQ7z-AC7AADq-Fz59Wk157.png

wKioL1hkqdyQlWOpAADACicoeVg756.png

2、重启rsyslog服务,再通过浏览器访问一下web以便产生日志,然后查看/var/log/haproxy.log,发现日志已经按照我们上文所配置的那样,记录到/var/log/haproxy.log来了

wKioL1hkqQ-ToP9_AAIVkv0gQgI773.png


优秀的个人博客,低调大师

微信关注我们

原文链接:https://blog.51cto.com/jiangjianlong/1887279

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Eclipse(集成开发环境)

Eclipse(集成开发环境)

Eclipse 是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括Java开发工具(Java Development Kit,JDK)。

Java Development Kit(Java开发工具)

Java Development Kit(Java开发工具)

JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Java系统类库)和JAVA工具。