使用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 …

第 十 章 积极性,培训以及经验(程序员开发心理学)

1&#xff09;无论我们如何精心地为学习建立一个最佳的物理环境&#xff0c;如果不懂如何利用所有可能的信息来帮助学习&#xff0c;再好的环境也不可能保证手们能够成功地完成学习任务 2&#xff09;为了能够对信息的这种损失有所认识&#xff0c;请看这样一个例子 - 在一次测…

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

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

(自用复习题)常微分方程08

题目来源 常微分方程(第四版) (王高雄,周之铭,朱思铭,王寿松) 高等教育出版社 书中习题4.1 对应知识 非齐次线性微分方程 3.已知齐次线性微分方程的基本解组 x 1 , x 2 x_1,x_2 x1​,x2​&#xff0c;求下列方程对应的非齐次线性微分方程的通解 三道题都是常数变易法 (1)…

CSRF初级靶场

靶场 针对DVWA么有防御 源码&#xff1a; <?phpif( isset( $_GET[ Change ] ) ) {// Get input$pass_new $_GET[ password_new ];$pass_conf $_GET[ password_conf ];// Do the passwords match?if( $pass_new $pass_conf ) {// They do!$pass_new ((isset($GLOBA…

图解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;可选&…

AI 编译器学习笔记之十 -- 基于atc工具进行onnx到om转换

1、input_shape 获取&#xff1f; atc --modelmodelTTS5_32.onnx --framework5 --outputmodelTTS5_32 --soc_versionAscend910B4 --input_shape"x:1,-1;x_lengths:1;sid:1;tone:1,-1;language:1,-1;bert:1,1024,-1;ja_bert:1,768,-1" --precision_mode_v2origin a)…

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

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

Apache 负载均衡详细配置步骤

一、引言 在当今的互联网时代&#xff0c;随着业务的不断增长和用户量的增加&#xff0c;单一服务器往往难以满足高并发的请求。为了提高系统的可用性、可靠性和性能&#xff0c;负载均衡技术应运而生。Apache HTTP Server&#xff08;以下简称 Apache&#xff09;作为一款广泛…

《功能高分子学报》

《功能高分子学报》 中国标准连续出版物号:CN 31-1633/O6&#xff0c;国际标准连续出版物号&#xff1a;ISSN 1008-9357&#xff0c;邮发代号&#xff1a;4-629&#xff0c;刊期&#xff1a;双月刊。 《功能高分子学报》主要刊登功能高分子和其他高分子领域具有创新意义的学术…

Pandas进行数据查看与检查

在数据分析的工作流中,数据的初步查看与检查是非常重要的步骤。通过这一步,可以快速了解数据的结构、属性以及一些关键的统计信息,确保数据符合预期,或者发现数据中的潜在问题。 借助 pandas 库中的常用方法,如 DataFrame.head()、DataFrame.tail()、DataFrame.info() 和…

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

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

docker配置与基础操作

docker 是什么? 一个开源应用容器引擎, 用于build,share, run应用程序的平台 docker与主机连接使用的是docker自己的虚拟网卡, 类似于虚拟机使用NAT模式连接主机 docker的优点: 快捷, 轻量(占用内存小) 对docker的基本命令 apt install docker.io systemctl start docker sys…

详解SQL单表查询

SQL单表查询 1. SELECT 语句的基本结构2. 查询所有列和指定列查询所有列查询特定列 3. WHERE 条件筛选比较运算符多条件查询&#xff1a;使用 AND 和 ORNOT 操作符 4. ORDER BY 进行排序多列排序 5. LIMIT 限制返回行数只获取前N行数据使用 LIMIT 和 OFFSET 进行分页查询 6. 常…

C++编程法则365天一天一条(27)std::initializer_list 轻量级初始化列表

std::initializer_list是一个模板类&#xff0c;是一个轻量级的 const T 类型对象数组的代理对象。这意味着通过 initializer_list 访问的元素是只读的&#xff0c;你无法修改这些元素的值。可以简单理解为一个常量数组。 它主要用于在构造函数中接收可变数量的同类型参数&…