使用Nginx作为反向代理和负载均衡器

💓 博客主页:瑕疵的CSDN主页
📝 Gitee主页:瑕疵的gitee主页
⏩ 文章专栏:《热点资讯》

使用Nginx作为反向代理和负载均衡器

    • 引言
    • Nginx 简介
      • 安装 Nginx
        • Ubuntu
        • CentOS
      • 配置 Nginx 作为反向代理
      • 配置 Nginx 作为负载均衡器
      • 高级配置
        • 会话持久性
        • 健康检查
      • 监控和日志
      • 总结

引言

Nginx 是一个高性能的 HTTP 和反向代理服务器,广泛应用于 Web 服务中。它不仅能够处理静态内容,还可以作为反向代理和负载均衡器来分发请求。本文将详细介绍如何使用 Nginx 作为反向代理和负载均衡器,提高系统的可用性和性能。

Nginx 简介

Nginx 是由 Igor Sysoev 于 2002 年创建的开源项目。它以其高性能、稳定性、丰富的功能和低资源消耗而闻名。Nginx 主要用于提供 Web 服务、反向代理、负载均衡和缓存等功能。

安装 Nginx

在大多数 Linux 发行版中,可以通过包管理器安装 Nginx。以下是 Ubuntu 和 CentOS 的安装方法:

Ubuntu
```bash
sudo apt update
sudo apt install nginx


<div class="cl-preview-section"><h4><a id="4_19"></a>CentOS</h4></div>```bash
sudo yum install epel-release
sudo yum install nginx

配置 Nginx 作为反向代理

反向代理是一种服务器,它位于客户端和后端服务器之间,客户端发送的请求首先到达反向代理服务器,然后由反向代理服务器转发到后端服务器。Nginx 可以非常方便地配置为反向代理。

假设我们有一个后端服务运行在 127.0.0.1:5000,我们希望 Nginx 将所有请求转发到这个地址。

  1. 编辑 Nginx 配置文件
    通常,Nginx 的主配置文件位于 /etc/nginx/nginx.conf,而站点配置文件位于 /etc/nginx/sites-available/default。我们可以编辑 default 文件来配置反向代理。

    server {listen 80;server_name example.com;location / {proxy_pass http://127.0.0.1:5000;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header X-Forwarded-Proto $scheme;}
    }
    
  2. 测试配置文件
    在重新加载 Nginx 之前,最好先测试配置文件是否正确。

    sudo nginx -t
    
  3. 重新加载 Nginx
    如果配置文件没有错误,可以重新加载 Nginx 以应用更改。

    sudo systemctl reload nginx
    

配置 Nginx 作为负载均衡器

负载均衡器可以将请求分发到多个后端服务器,从而提高系统的可用性和性能。Nginx 支持多种负载均衡算法,如轮询、最少连接数、哈希等。

假设我们有两个后端服务分别运行在 127.0.0.1:5000127.0.0.1:5001,我们希望 Nginx 将请求均匀分发到这两个服务。

  1. 编辑 Nginx 配置文件
    default 文件中添加一个 upstream 块来定义后端服务器池。

    upstream backend {server 127.0.0.1:5000;server 127.0.0.1:5001;
    }server {listen 80;server_name example.com;location / {proxy_pass http://backend;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header X-Forwarded-Proto $scheme;}
    }
    
  2. 测试配置文件
    同样,我们需要测试配置文件是否正确。

    sudo nginx -t
    
  3. 重新加载 Nginx
    如果配置文件没有错误,可以重新加载 Nginx 以应用更改。

    sudo systemctl reload nginx
    

高级配置

会话持久性
在某些情况下,我们希望同一个客户端的请求总是被转发到同一个后端服务器。这称为会话持久性或粘性会话。Nginx 支持基于 IP 地址的会话持久性。

upstream backend {ip_hash;server 127.0.0.1:5000;server 127.0.0.1:5001;
}

健康检查
Nginx 可以配置健康检查,自动检测后端服务器的状态,并在服务器不可用时将其从负载均衡池中移除。

upstream backend {server 127.0.0.1:5000;server 127.0.0.1:5001;health_check;
}

监控和日志

Nginx 提供了详细的日志功能,可以帮助我们监控服务器的性能和状态。

  1. 访问日志
    访问日志记录了每个请求的详细信息。

    access_log /var/log/nginx/access.log;
    
  2. 错误日志
    错误日志记录了 Nginx 运行过程中遇到的错误。

    error_log /var/log/nginx/error.log;
    

总结

通过本文,你已经学会了如何使用 Nginx 作为反向代理和负载均衡器。Nginx 的强大之处在于其高性能、稳定性和丰富的功能。掌握这些知识将有助于你在实际工作中更好地利用 Nginx 来提高系统的可用性和性能。
Nginx 反向代理架构图

Nginx 作为反向代理和负载均衡器,能够显著提高系统的可用性和性能。
Nginx 负载均衡架构图

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

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

相关文章

「实战应用」使用 DHTMLX 构建数据透视表,促进有效的数据分析

概述&#xff1a;在本文中&#xff0c;您将了解组织何时选择数据透视表来处理大数据&#xff0c;并熟悉用于在网页上实现此功能的 DHTMLX 工具。 如今&#xff0c;高效处理大数据已成为企业的必需。企业每天必须处理大量数据&#xff0c;以将其转化为可操作的见解并获得竞争优…

Stable diffusion 3.5本地运行环境配置记录

1.环境配置 创建虚环境 conda create -n sd3.5 python3.10Pytorch(>2.0) conda install pytorch2.2.2 torchvision0.17.2 torchaudio2.2.2 pytorch-cuda12.1 -c pytorch -c nvidiaJupyter能使用Anaconda虚环境 conda install ipykernel python -m ipykernel install --user …

openGauss数据库-头歌实验1-4 数据库及表的创建

一、创建数据库 &#xff08;一&#xff09;任务描述 本关任务&#xff1a;创建指定数据库。 &#xff08;二&#xff09;相关知识 数据库其实就是可以存放大量数据的仓库&#xff0c;学习数据库我们就从创建一个数据库开始吧。 为了完成本关任务&#xff0c;你需要掌握&a…

图解TCP三次握手:一步步构建网络会话

在互联网通信中&#xff0c;确保数据传输的可靠性至关重要。TCP三次握手的过程正是为了解决这一问题而设计的。在建立连接之前&#xff0c;客户端和服务器需要确认彼此的存在与准备状态&#xff0c;以防止因网络延迟或数据丢失而导致的错误。通过三次握手&#xff0c;双方不仅能…

[ shell 脚本实战篇 ] 编写恶意程序实现需求(恶意程序A监测特定目录B出现特定文件C执行恶意操作D-linux)

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

讲讲RabbitMQ 性能优化

大家好&#xff0c;我是锋哥。今天分享关于【RabbitMQ 性能优化&#xff1f;】面试题。希望对大家有帮助&#xff1b; 讲讲RabbitMQ 性能优化 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 RabbitMQ 是一个强大的消息代理&#xff0c;广泛用于分布式系统中&#x…

2-139 基于matlab的弹道轨迹仿真

基于matlab的弹道轨迹仿真。设计GUI图形用户界面&#xff0c;对导弹参数根据需求进行设置&#xff0c;直观的实现更改攻角、各级火箭喷射时间等参数后得到对应参数下的导弹弹道图像以及导弹的飞行时间和飞行距离。得到飞行时间集导弹射程。程序已调通&#xff0c;可直接运行。 …

【spark的集群模式搭建】Standalone集群模式的搭建(简单明了的安装教程)

文章目录 1、使用Anaconda部署Python2、上传、解压、重命名3、创建软连接4、配置spark环境变量5、修改 spark-env.sh配置文件6、启动hdfs&#xff0c;创建文件夹7、修改spark-defaults.conf配置文件8、修改workers配置文件9、修改log4j.properties配置文件&#xff08;可选&…

HTML 基础标签——多媒体标签<img>、<object> 与 <embed>

文章目录 1. `<img>` 标签主要属性示例注意事项2. `<object>` 标签概述主要属性示例注意事项3. `<embed>` 标签概述主要属性示例注意事项小结在现代网页设计中,多媒体内容的使用变得越来越重要,因为它能够有效增强用户体验、吸引注意力并传达信息。HTML 提…

校门外的树(算法:标记法)

思路实现&#xff1a; 1.利用二维数组来存储输入数据 2.开辟一个包含所有范围的数组用来做标记初始为0 3.遍历二维数组&#xff0c;取到每段区间的开始位置和结束位置&#xff0c;在标记数字组中将边界点及边界点内置1 4.遍历标记数组记录0的个数&#xff0c;即可 代码实现…

100M宽带测速只有20M

100M宽带测速只有20M的原因主要有以下几点‌&#xff1a; ‌网络设备不匹配‌&#xff1a;100兆宽带的实际使用需要全千兆路由器、超五类网线以及千兆网卡的支持。如果使用老旧的路由器、五类网线或百兆网卡&#xff0c;可能会导致网速受限。例如&#xff0c;使用普通网线可能…

二、基础语法

入门了解 注释 **作用&#xff1a;**在代码中加一些注释和说明&#xff0c;方便自己或者其他程序员阅读代码 两种格式&#xff1a; 单行注释&#xff1a;// 描述信息 通常放在一行代码的上方&#xff0c;或者一条语句的末尾&#xff0c;对该行代码进行说明 多行注释&#x…

minikube 的 Kubernetes 入门教程--(五)

本文记录 Minikube 在 Kubernetes 上安装 WordPress 和 MySQL。 这两个应用都使用 PersistentVolumes 和 PersistentVolumeClaims 保存数据。 在深入这些步骤之前&#xff0c;先分享来自kubernetes.io教程。 链接>>使用持久卷部署 WordPress 和 MySQL | Kubernetes 获…

向量数据库|第2期|pgvectorscale

向量数据库|第2期|pgvectorscale 大家都听说过pgvector&#xff0c;一个PostgreSQL存储和查询向量的扩展&#xff0c;是PG AI生态当之无愧的最受推崇的工具之一。pgvector向PG中添加了vector类型&#xff0c;以及各种搜索操作符和索引&#xff0c;使其拥有vectors和metadata的完…

【sqlmap使用】

sqlmap简介 sqlmap 目录结构 sqlmap常用参数 sqlmap实现注入 测试注入点&#xff0c;检测到注入点后&#xff0c;直接爆数据库名 python sqlmap.py –u http://172.16.12.2/7/9/strsql.php --data "usernameadmin" --dbs注意sqlmap在使用过程中可能会出现几个需要…

通过源码分析类加载器里面可以加载的类

类列表 每一个ClassLoader里面的类列表&#xff0c;类的数量都是固定的。 对上一节中的dex反编译 使用DexClassLoader类动态加载插件dex   利用jadx对dex进行反编译可以看到有哪些类 源码分析 BaseDexClassLoader 从BaseDexClassLoader类加载器开始分析 在BaseDexClassLoade…

宝塔使用clickhouse踩坑

前言 最近有个物联网项目&#xff0c;需要存储物联网终端发送过来的信息&#xff08;类似log日志&#xff0c;但又要存储在数据库里&#xff0c;方便后期聚合统计&#xff09;&#xff0c;本来想写文件的奈何客户要求聚合统计&#xff0c;所以只能用数据库才能达到更高的计算效…

parted 磁盘分区

目录 磁盘格式磁盘分区文件系统挂载使用扩展 - parted、fdisk、gdisk 区别 磁盘格式 parted /dev/vdcmklabel gpt # 设置磁盘格式为GPT p # 打印磁盘信息此时磁盘格式设置完成&#xff01; 磁盘分区 开始分区&#xff1a; mkpart data_mysql # 分区名&…

NFTScan Site:以蓝标认证与高级项目管理功能赋能 NFT 项目

自 NFTScan Site 上线以来&#xff0c;它迅速成为 NFT 市场中的一支重要力量&#xff0c;凭借对各类 NFT 集合、市场以及 NFTfi 项目的认证获得了广泛认可。这个平台帮助许多项目提升了曝光度和可见性&#xff0c;为它们在竞争激烈的 NFT 市场中创造了更大的成功机会。 在最新更…

leetcode-5-最长回文子串

题解&#xff1a; 回文串&#xff1a;如果一个字符串正着读和反着读都是一样的那这个字符串就是回文串。 对于一个子串而言&#xff0c;如果它是回文串&#xff0c;并且长度大于 2&#xff0c;那么将它首尾的两个字母去除之后&#xff0c;它仍然是个回文串。 1、初始化字典d…