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

相关文章

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏

本地搭建DeepSeek-R1、WebUI的完整过程及访问

《本地搭建DeepSeek-R1、WebUI的完整过程及访问》:本文主要介绍本地搭建DeepSeek-R1、WebUI的完整过程及访问的相关资料,DeepSeek-R1是一个开源的人工智能平台,主... 目录背景       搭建准备基础概念搭建过程访问对话测试总结背景       最近几年,人工智能技术

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

centos7基于keepalived+nginx部署k8s1.26.0高可用集群

《centos7基于keepalived+nginx部署k8s1.26.0高可用集群》Kubernetes是一个开源的容器编排平台,用于自动化地部署、扩展和管理容器化应用程序,在生产环境中,为了确保集... 目录一、初始化(所有节点都执行)二、安装containerd(所有节点都执行)三、安装docker-

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择