Nginx 正向代理和反向代理

article/2025/9/4 19:01:46

博主介绍: ✌博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家✌

Java知识图谱点击链接:体系化学习Java(Java面试专题)

💕💕 感兴趣的同学可以收藏关注下不然下次找不到哟💕💕

在这里插入图片描述

文章目录

  • 1、为什么 Nginx 性能这么高
  • 2、Nginx 正向代理和反向代理
  • 3、Nginx 有什么优缺点
  • 4、Nginx 正向代理的配置
  • 4、Nginx 配置反向代理

1、为什么 Nginx 性能这么高

Nginx性能高的原因有以下几点:

  1. Nginx是一个轻量级的Web服务器,它使用少量的系统资源来处理大量的并发连接请求。

  2. Nginx采用了事件驱动模型,它使用异步非阻塞的方式处理请求,可以更好地利用系统资源。

  3. Nginx具有高度的可扩展性和灵活性,可以通过添加模块来扩展其功能。

  4. Nginx具有出色的负载均衡和反向代理功能,可以将请求分配到多个服务器上,从而提高性能和可靠性。

总之,Nginx通过优秀的架构设计和高效的算法实现了高性能和高可靠性,成为了Web服务器领域的佼佼者。

2、Nginx 正向代理和反向代理

Nginx既可以作为正向代理,也可以作为反向代理。正向代理和反向代理的区别在于代理的对象不同。

正向代理:客户端向代理服务器发送请求,代理服务器再向目标服务器发送请求,目标服务器返回响应给代理服务器,代理服务器再将响应返回给客户端。这时,客户端并不知道请求的目标服务器是哪个,只知道代理服务器的地址。

反向代理:客户端向目标服务器发送请求,但实际上请求被发送到了反向代理服务器上,反向代理服务器会根据配置的规则将请求转发给后端的目标服务器进行处理,再将处理结果返回给客户端。这时,客户端并不知道请求的目标服务器是哪个,只知道反向代理服务器的地址。

Nginx可以通过配置文件的方式实现正向代理和反向代理的功能。在配置文件中,通过proxy_pass指令指定代理服务器的地址和端口号,即可实现代理的功能。

3、Nginx 有什么优缺点

nginx是一个开源的高性能的Web服务器和反向代理服务器。它具有以下优点:

  1. 高性能:nginx采用异步非阻塞的事件驱动模型,能够处理大量并发连接,具有出色的性能表现。

  2. 资源占用低:相比于其他Web服务器,nginx的内存占用较低,能够处理大量的并发请求。

  3. 高度可配置:nginx提供了丰富的配置选项,可以根据实际需求进行灵活的配置和定制。

  4. 反向代理和负载均衡:nginx作为反向代理服务器,能够将请求转发给后端服务器,并进行负载均衡,提高系统的稳定性和性能。

  5. 高度可扩展:nginx支持模块化的架构,可以通过添加第三方模块来扩展功能,满足不同的需求。

然而,nginx也有一些缺点:

  1. 学习曲线较陡峭:相对于一些传统的Web服务器,nginx的配置语法和理念可能对初学者来说有一定的学习难度。

  2. 不支持直接处理动态内容:nginx主要用于处理静态内容,对于动态内容的处理需要与其他后端服务器(如PHP-FPM)结合使用。

  3. Windows平台支持相对较弱:虽然nginx也可以在Windows平台上运行,但相对于Linux平台,其稳定性和性能可能稍逊一筹。

综上所述,nginx是一个高性能、资源占用低、可配置性强的Web服务器和反向代理服务器,适用于处理大量并发请求和负载均衡的场景。但在选择使用时,需要根据具体的需求和环境来权衡其优缺点。

4、Nginx 正向代理的配置

nginx.conf 配置正向代理:

http {# 定义正向代理服务器的地址和端口号upstream proxy_server {server 192.168.1.1:8080;}# 定义代理服务器的缓存proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=cache:10m inactive=60m;# 定义代理服务器的缓存时间proxy_cache_valid 200 60m;# 定义代理服务器的缓存大小proxy_cache_size 10m;# 定义代理服务器的缓存类型proxy_cache_key "$scheme$request_method$host$request_uri";# 定义代理服务器的缓存控制proxy_cache_bypass $http_pragma;proxy_cache_revalidate on;proxy_cache_min_uses 1;# 定义代理服务器的超时时间proxy_connect_timeout 30s;proxy_send_timeout 60s;proxy_read_timeout 60s;# 定义代理服务器的请求头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_hide_header X-Powered-By;proxy_hide_header Server;# 定义代理服务器的缓存控制头add_header Cache-Control "public, max-age=60, s-maxage=60";# 定义代理服务器的缓存控制头proxy_cache_lock on;# 定义代理服务器的缓存控制头proxy_cache_methods GET HEAD POST;
}
server {listen 80;server_name example.com;# 定义代理服务器的地址和端口号location / {proxy_pass http://proxy_server;proxy_cache cache;proxy_cache_key "$scheme$request_method$host$request_uri";proxy_cache_valid 200 60m;proxy_cache_bypass $http_pragma;proxy_cache_revalidate on;proxy_cache_min_uses 1;}
}

4、Nginx 配置反向代理

nginx.conf 配置反向代理:

http {# 定义后端服务器的地址和端口号upstream backend_server {server 192.168.1.1:8080;}
}
server {listen 80;server_name example.com;# 定义反向代理规则,将请求转发到后端服务器location / {proxy_pass http://backend_server;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}
}

在这里插入图片描述

💕💕 本文由激流原创,首发于CSDN博客,博客主页 https://blog.csdn.net/qq_37967783?spm=1010.2135.3001.5421
💕💕喜欢的话记得点赞收藏啊


http://chatgpt.dhexx.cn/article/nX1fa0Lj.shtml

相关文章

什么是正向代理和反向代理

什么是正向代理和反向代理 1. 正向代理2. 反向代理3. 两者的区别 1. 正向代理 正向代理隐藏真实客户端 正向代理,就是一个位于客户端和原始服务器之前的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并且指定目标(…

nginx--正向代理、反向代理及负载均衡(图解+配置)

目录 学习背景一、代理服务二、正向代理1.1 什么是正向代理?1.2 如何实现nginx正向代理?1.3 客户端访问(验证正向代理) 二、反向代理2.1 什么是反向代理?2.2 nginx实现反向代理 三、负载均衡3.1 什么是负载均衡&#x…

正向代理和反向代理详解(纯小白必看 最好懂的白话文教程)

概要 习惯性的bb几句 本文主要介绍正向代理和反向代理的区别,如何区分,各自的好处,还有一些应用场景 主要是白话文的内容,不会有太多专业术语,主要是面向纯小白,做个解疑, 部分地方稍微不严谨&…

nginx代理(正向代理和反向代理)

正向代理 是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端(目的是为了保护客户端…

反向代理是什么意思?正向代理和反向代理的区别是什么?

一文说清楚正向代理与反向代理的区别 什么是正向代理?什么是反向代理?它们的区别是什么?看完本文就清楚了… 首先,从字面上理解,代理的意思是代替办理,就是一方委托另一方办事,在计算机网络的世…

正向代理和反向代理有什么区别?什么是正向代理?什么是反向代理?正向代理和反向代理详解。

一、正向代理: 当用户想访问某一网址时,用户先访问代理服务器,然后由代理服务器向目标网址发送请求最终将数据返回代理服务器,最后代理服务器将数据返回给用户这一过程我们称之为正向代理。 正向代理它代理了客户端,相…

正向代理和反向代理的区别

套用古龙武侠小说套路来说,代理服务技术是一门很古老的技术,是在互联网早期出现就使用的技术。一般实现代理技术的方式就是在服务器上安装代理服务软件,让其成为一个代理服务器,从而实现代理技术。常用的代理技术分为正向代理、反…

详解正向代理与反向代理

1.正向代理 1.1 概念 正向代理是一个位于客户端和目标服务器之间的代理服务器(中间服务器)。为了从目标服务器取得内容,客户端向代理服务器发送一个请求,并且指定目标服务器,之后代理向目标服务器转发请求&#xff0…

二叉树-翻转二叉树

题目 思路BFS 使用BFS遍历的时候交换 只需要对原有的BFS遍历时加上交换的代码即可(老三行)。 public TreeNode invertTree(TreeNode root) {public TreeNode invertTree(TreeNode root) {//root为空的情况要进行排除否则会在交换时出现空指针异常if(r…

力扣周赛 313 反转二叉树的奇数层(dfs镜像遍历 or bfs提取层节点)

题意: 对于一颗给定的二叉树,我们的任务是反转它的所有奇数层的节点的权值 val(根节点所在层为第 0 层),操作完后返回根节点 root。 思路: 思路一: dfs 镜像遍历:左子树按照左中…

二叉树左右子树的翻转

翻转一个二叉树,直观上看,就是把二叉树的每一层左右顺序倒过来。比如问题中的例子,第三层1-3-6-9经过变换后变成了9-6-3-1,顺序反过来就对了。 再仔细观察一下,对于上面的例子,根节点(root&…

算法-树-反转二叉树

问题 Write a function that takes in a Binary Tree and inverts it. In other words, the function should swap every left node in the tree for its corresponding (mirrored) right node. Each Binary Tree node has a value stored in a property called “value” and …

算法_二叉树_翻转二叉树

文章目录 翻转二叉树1.解法2.总结算法 翻转二叉树 leetcode链接 1.解法 解法思路: 想把二叉树翻转,其实仔细一看,就是把每个二叉树的节点的左右孩子翻转,这样总体效果就是把整个二叉树翻转了。 所以只需要通过一种遍历手段把…

Java 求解翻转二叉树

文章目录 一、题目二、题目分析三、递归法四、非递归法五、层序遍历六、总结一、题目 翻转一棵二叉树。 二、题目分析 题目要求翻转二叉树,其实只需要把每一个节点左右孩子交换(孩子下面的节点是一起交换的)即可 题目使用前序遍历和后序遍历都可,但是中序遍历不可以,因…

【LeetCode 6182 反转二叉树的奇数层】

题目描述 给你一棵 完美 二叉树的根节点 root ,请你反转这棵树中每个 奇数 层的节点值。 例如,假设第 3 层的节点值是 [2,1,3,4,7,11,29,18] ,那么反转后它应该变成 [18,29,11,7,4,3,1,2] 。反转后,返回树的根节点。 完美 二叉…

js 反转二叉树

什么是反转二叉树 二叉树的每个结点至多有两颗子树,不存在大于2个的节点,二叉树有左右之分,次序不能颠倒 初始数据 let list {id: "4",left: {id: "2",left: {id: "1",left: null,right: null,},right: {id: …

层序遍历,反转二叉树,对称二叉树

1.层序遍历 leetcode 一层层遍历二叉树 &#xff0c; 是广度优先搜索 class Solution { public:vector<vector<int>> levelOrder(TreeNode* root) {queue< TreeNode* > que;vector < vector < int > > result;if ( root NULL ) return result…

力扣226:反转二叉树

翻转二叉树 题目思路①思路①代码思路②思路②代码总结 题目 给你一颗二叉树的根节点root&#xff0c;请你翻转该二叉树&#xff0c;并且返回其根节点。 思路① 如何判定二叉树是否翻转&#xff1f; 左右子树需要交换&#xff0c;左右子树内部的左右子节点也需要交换位置。…

翻转二叉树-python

leetCode第226题 翻转二叉树 链接&#xff1a;https://leetcode-cn.com/problems/invert-binary-tree 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 示例 1&#xff1a; 输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xff1a;[4,…

iOS实现反转二叉树(前序遍历二叉树)

题目: Input: Output: 首先分析下这个二叉树,从上往下看发现这个树是把树上的数据进行了交换,但是仔细一看发现最后一排的1-3反转过去后变成了3-1.所以得出结论,这道题是左右子树进行了交换,用函数递归就能很容易实现了. ## OC版本 声明节点属性&#xff1a; #import &…