使用Haproxy搭建Web群集

1、Haproxy概述。

        Haproxy是目前比较流行的一种群集调度工具,同类群集调度工具有很多,如LVS和Nginx。相比较而言,LVS性能最好,但是搭建相对复杂;Nginx的upstream模块支持群集功能,但是对群集节点健康检查功能不强,性能没有Haproxy号。

1.2、HTTP请求

        通过URL访问网站使用的协议是HTTP协议,此类请求一般称为HTTP请求。HTTP请求的方式分为GET方式和POST方式。当使用浏览器访问某一个URL,会根据请求URL返回状态码,通常正常的状态码为2XX、3XX(如200、300),如果出现异常会返回4XX、5XX(如400、500)。

1.3、负载均衡常用调度算法。

1)RR。RR算法是最简单最常用的一种算法,即轮询调度。

2)LC。LC算法即最小连接数算法,根据后端的节点连接数大小动态分配前端请求。

3)SH。SH即基于来源访问调度算法。

2、案例环境

组件包:Haproxy nginx(httpd)

设备

IP

备注

Centos01

192.168.136.10

Node1

Centos02

192.168.136.20

Web1

Centos03

192.168.136.30

Web2

2.1、编译安装Haproxy

上传Haproxy的软件包到node1并安装组件

[root@nodeAAA ~]# yum -y install pcre-devel bzip2-devel gcc gcc-c++ make

[root@nodeAAA ~]# tar zxf haproxy-1.5.19.tar.gz 

[root@nodeAAA ~]# cd haproxy-1.5.19
[root@nodeAAA haproxy-1.5.19]# make TARGET=linux26 && make install


建立Haproxy的配置文件

[root@nodeAAA haproxy-1.5.19]# mkdir /etc/haproxy
[root@nodeAAA haproxy-1.5.19]# cp examples/haproxy.cfg /etc/haproxy/


修改配置文件,添加Web节点
[root@nodeAAA haproxy-1.5.19]# vim /etc/haproxy/haproxy.cfg 

listen  WEB *:80
        option  httpchk GET /index.html
        balance roundrobin
        server  inst1 192.168.136.20:80 check inter 2000 fall 3
        server  inst2 192.168.136.30:80 check inter 2000 fall 3


创建群集根目录

[root@nodeAAA ~]# mkdir /usr/share/haproxy


添加Haproxy为系统服务

[root@nodeAAA ~]# cd haproxy-1.5.19
[root@nodeAAA haproxy-1.5.19]# cp examples/haproxy.init /etc/init.d/haproxy
[root@nodeAAA haproxy-1.5.19]# ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy
[root@nodeAAA haproxy-1.5.19]# chmod +x /etc/init.d/haproxy 
[root@nodeAAA haproxy-1.5.19]# chkconfig --add /etc/init.d/haproxy 
[root@nodeAAA haproxy-1.5.19]# systemctl start haproxy

2.2、编译安装Nginx服务器。 

将Nginx软件包上传到web1和web2,并安装组件

[root@nodeBBB ~]# yum -y install pcre-devel zlib-devel gcc gcc-c++ make


创建Nginx用户

[root@nodeBBB ~]# useradd -M -s /sbin/nologin nginx


解包然后编译安装

[root@nodeBBB ~]# tar zxf nginx-1.24.0.tar.gz 
[root@nodeBBB ~]# cd nginx-1.24.0
[root@nodeBBB nginx-1.24.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module

[root@nodeBBB nginx-1.24.0]# make && make install


创建主程序链接文件

[root@nodeBBB nginx-1.24.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/


修改测试页面的内容

[root@nodeBBB ~]# vim /usr/local/nginx/html/index.html 
启动Nginx

[root@nodeBBB ~]# nginx

2.3、验证测试

使用浏览器访问http://192.168.136.10(调度服务器)

刷新网页即可轮询切换

2.4、Haproxy日志

修改Haproxy配置文件中的日志配置

[root@nodeAAA ~]# vim /etc/haproxy/haproxy.cfg 
global
        log /dev/log    local0
        log /dev/log    local1 notice


配置Haproxy日志

[root@nodeAAA ~]# vim /etc/rsyslog.d/haproxy.conf
if ($programname == 'haproxy' and $syslogseverity-text == 'info') then -/var/log/haproxy/haproxy-info.log
& ~
if ($programname == 'haproxy' and $syslogseverity-text == 'notice') then -/var/log/haproxy/haproxy-notice.log
& ~


创建日志目录

[root@nodeAAA ~]# vim /etc/rsyslog.d/haproxy.conf

[root@nodeAAA ~]# mkdir /var/log/haproxy


重新启动服务
[root@nodeAAA ~]# systemctl restart haproxy
[root@nodeAAA ~]# systemctl restart rsyslog

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/499811.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

手机备忘录导到电脑上有什么方法简单点

在这个信息爆炸的时代,我们每天都在处理海量的信息和待办事项。手机备忘录里记录着重要的灵感、会议安排、待购物品清单……但每次想在电脑上继续编辑或查看时,我都感到无比头疼。难道就没有一种简单的方法,能让手机备忘录和电脑轻松同步吗&a…

Python 编程语言以及相关的库和工具来进行金融市场数据分析、策略开发和交易执行的过程。

Python 量化是指利用 Python 编程语言以及相关的库和工具来进行金融市场数据分析、策略开发和交易执行的过程。 Python 由于其简洁、易学、强大的生态系统和丰富的金融库而成为量化交易的首选编程语言之一。 量化交易在金融领域得到广泛应用,它允许交易者通过系统…

day57 集合 List Set Map

List实现类 List接口特点:元素有序 可重复 Arraylist 可变数组 jdk 8 以前Arraylist容量初始值10 jdk8 之后初始值为0,添加数据时,容量为10; ArrayList与Vector的区别? LinkList:双向链表 优点&#xff1…

数据处理安全评估:25项核心控制点

01 数据流与风险 数据处理活动是数据安全风险评估的核心,它是区别网络安全关键之一。以数据为中心,关注数据的流动过程,数据流转至的任何环节,都可能产生风险,任何可能接触到数据的角色都存在风险隐患。 关注数据的静…

【基于ChatGPT大模型】GIS应用、数据清洗、统计分析、论文助手、项目基金助手、科研绘图、AI绘图

以ChatGPT、LLaMA、Gemini、DALLE、Midjourney、Stable Diffusion、星火大模型、文心一言、千问为代表AI大语言模型带来了新一波人工智能浪潮,可以面向科研选题、思维导图、数据清洗、统计分析、高级编程、代码调试、算法学习、论文检索、写作、翻译、润色、文献辅助…

【JavaEE】_HttpServletResponse类

目录 1. 核心方法 2. 关于setStatus(400)与sendError 2.1 setStatus(400) 2.2 sendError 3. setHeader方法 4. 构造重定向响应 4.1 使用setHeader和setStatus实现重定向 4.2 使用sendRedirect实现重定向 本专栏已有文章介绍HttpServlet和HttpServletRequest类&#…

【Python】Win创建虚拟环境运行Python

我习惯使用VS Code工具来编辑代码, 教程环境 Win11 Windows系统上,可以使用Python的内置工具venv来创建虚拟环境。以下是在Win上创建Python虚拟环境的步骤: 安装Python虚拟环境工具:首先确保系统中已经安装了Python 3。可以在Micr…

奇安信发布《2024人工智能安全报告》,AI深度伪造欺诈激增30倍

2024年2月29日,奇安信集团对外发布《2024人工智能安全报告》(以下简称《报告》)。《报告》认为,人工智能技术的恶意使用将快速增长,在政治安全、网络安全、物理安全和军事安全等方面构成严重威胁。 《报告》揭示了基于…

Linux(CentOS)学习

一、认识Linux 1、如何修改Linux时区 2、配置固定IP 3、重启网络服务 3、小技巧快捷键 4、环境变量设置 5、Linux文件的上传和下载 6、压缩和解压 二、基础命令 1、目录命令 (1、)查看目录内容(ls) 1、ls //查看当前目录内容 2、- a //显示隐藏内容 3…

2024年腾讯云十大优惠活动,TOP10

腾讯云服务器多少钱一年?62元一年起,2核2G3M配置,腾讯云2核4G5M轻量应用服务器218元一年、756元3年,4核16G12M服务器32元1个月、312元一年,8核32G22M服务器115元1个月、345元3个月,腾讯云服务器网txyfwq.co…

SpringCloud Alibaba(保姆级入门及操作)

第一章 微服务概念 1.0 科普一些术语 科普一下项目开发过程中常出现的术语,方便后续内容的理解。 **服务器:**分软件与硬件,软件:类型tomcat这种跑项目的程序, 硬件:用来部署项目的电脑(一般性能比个人电脑好) **服务:**操作系统上术语:一个程序,开发中术语:一个…

给nginx部署https及自签名ssl证书

一、生成服务器root证书 openssl genrsa -out root.key 2048 openssl req -new -key root.key -out root.csr#Country Name (2 letter code) [XX]:---> CN#Country Name (2 letter code) [XX]:---> CN#State or Province Name (full name) []:---> Shanghai#Locality…