Keepalived双机热备——Haproxy搭建web群集

2024-02-29 21:20

本文主要是介绍Keepalived双机热备——Haproxy搭建web群集,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、认识keepalived

keepalived是一个开源的软件,用于实现高可用性和负载均衡。它主要用于在多个服务器之间提供故障转移和负载均衡的功能。keepalived可以监控服务器的状态,并在主服务器发生故障时自动将备份服务器切换为主服务器,以确保服务的连续性。

keepalived的主要特点包括:

  1. VRRP协议支持:keepalived使用虚拟路由冗余协议(VRRP)来实现故障转移。VRRP允许多个服务器共享一个虚拟IP地址,当主服务器不可用时,备份服务器会接管该IP地址。
  2. 健康检查:keepalived可以定期检查服务器的健康状态,例如检查服务器的网络连接、CPU负载、内存使用等。如果服务器的健康状态不正常,keepalived会将其标记为不可用,并将流量转发到其他可用的服务器。
  3. 负载均衡:keepalived还支持基于轮询、加权轮询、源IP哈希等算法的负载均衡。它可以将流量均匀地分发到多个服务器上,提高系统的性能和可扩展性。
  4. 配置灵活:keepalived的配置文件采用简单易懂的语法,可以根据实际需求进行灵活配置。用户可以定义虚拟IP地址、服务器组、健康检查参数等

二、认识Haproxy 

Haproxy是一款可以供高可用性、负载均衡和基于TCP和HTTP应用的代理软件

  • 适用于负载较大的站点
  • 运行在硬件上可支持数以万计的并发连接请求

 三、实验案例

3.1 实验拓扑图:

 

3.2 实验需求:

 实验环境

虚拟机 3台 centos7.9

网卡NAT模式 数量 1

组件包Haproxy nginx(httpd)

设备

IP

备注

Centos01

192.168.160.51

Node1

Centos02

192.168.160.53

Web1

Centos03

192.168.160.54

Web2

3.3 初始配置:

关闭防火墙:

Systemctl disable firewalld --now

关闭 selinux:

setenforce 0
sed -i 's/SELINUX=.*/SELINUX=disabled/g' /etc/selinux/config

 3.4 编译安装Haproxy :

将haproxy安装包上传至node1安装组件 node1配置

yum -y install pcre-devel bzip2-devel gcc gcc-c++ make

 解压缩安装包:

tar zxf haproxy-1.5.19.tar.gz 
cd haproxy-1.5.19
make TARGET=linux26 && make install

 创建主配置文件:

[root@xiao ~]# mkdir /etc/haproxy
[root@xiao ~]# cp examples/haproxy.cfg /etc/haproxy/

添加群集信息:

[root@xiao haproxy-1.5.19]# vim /etc/haproxy/haproxy.cfg globallog 127.0.0.1   local0log 127.0.0.1   local1 notice#log loghost    local0 infomaxconn 4096chroot /usr/share/haproxyuid 99gid 99daemon#debug#quietdefaultslog     globalmode    httpoption  httplogoption  dontlognullretries 3redispatchmaxconn 2000contimeout      5000clitimeout      50000srvtimeout      50000listen  web 0.0.0.0:80option  httpchk GET /index.htmlbalance roundrobinserver  inst1 192.168.10.53:80 check inter 2000 fall 3server  inst2 192.168.10.54:80 check inter 2000 fall 3

 创建群集根目录:

[root@xiao haproxy-1.5.19]# mkdir /usr/share/haproxy

添加 haproxy系统服务:

[root@xiao haproxy-1.5.19]# cp examples/haproxy.init /etc/init.d/haproxy
[root@xiao haproxy-1.5.19]# ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy
[root@xiao haproxy-1.5.19]# chmod +x /etc/init.d/haproxy
[root@xiao haproxy-1.5.19]# chkconfig --add haproxy[root@xiao haproxy-1.5.19]# systemctl start haproxy    开启服务

3.5 安装Nginx 节点配置将nginx安装包上传至web1和web2:

安装组件:

[root@xiao1 nginx-1.24.0]# yum -y install pcre-devel zlib-devel gcc gcc-c++ make

创建nginx用户 :

[root@xiao1 nginx-1.24.0]# useradd -M -s /sbin/nologin nginx

 解压文件并编译安装:

[root@wei1 nginx-1.24.0]# tar zxf nginx-1.24.0.tar.gz 
[root@wei1 nginx-1.24.0]# cd nginx-1.24.0/
[root@wei1 nginx-1.24.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
[root@wei1 nginx-1.24.0]# make && make install
[root@wei1 nginx-1.24.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/[root@wei1 nginx-1.24.0]# nginx  开启nginx

.四、实验结果:

 

 

这篇关于Keepalived双机热备——Haproxy搭建web群集的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/760123

相关文章

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)

《国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)》本文给大家利用deepseek模型搭建私有知识问答库的详细步骤和遇到的问题及解决办法,感兴趣的朋友一起看看吧... 目录1. 第1步大家在安装完ollama后,需要到系统环境变量中添加两个变量2. 第3步 “在cmd中

web网络安全之跨站脚本攻击(XSS)详解

《web网络安全之跨站脚本攻击(XSS)详解》:本文主要介绍web网络安全之跨站脚本攻击(XSS)的相关资料,跨站脚本攻击XSS是一种常见的Web安全漏洞,攻击者通过注入恶意脚本诱使用户执行,可能... 目录前言XSS 的类型1. 存储型 XSS(Stored XSS)示例:危害:2. 反射型 XSS(Re

Keepalived+Nginx双机配置小结

《Keepalived+Nginx双机配置小结》本文主要介绍了Keepalived+Nginx双机配置小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1.1 软硬件要求1.2 部署前服务器配置调优1.3 Nginx+Keepalived部署1.3

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.