使用 Nginx 搭建代理服务器(正向代理 HTTPS 网站)指南

在网络应用中,代理服务器是用于中转用户请求和服务端响应的工具。正向代理主要用于客户端与外部服务器之间的访问代理,帮助客户端隐藏其 IP 地址或访问受限资源。本文将详细介绍如何使用 Nginx 搭建正向代理服务器,特别是针对 HTTPS 网站的代理。

一、正向代理与反向代理的区别

1.1 正向代理

正向代理位于客户端和服务器之间,代表客户端向服务器发起请求。其主要功能是隐藏客户端信息,代理客户端进行网络访问,尤其是访问某些受限资源时。

1.2 反向代理

反向代理位于服务器端,接收来自客户端的请求,然后转发给内部的服务器处理。其主要功能是隐藏服务器信息,在负载均衡、缓存等方面应用广泛。

二、环境准备

  • Nginx:我们将使用 Nginx 作为代理服务器。Nginx 是一个高效的反向代理服务器,也可以充当正向代理服务器。
  • 操作系统:本文以 Ubuntu 为例进行演示。
  • SSL 证书:Nginx 支持 HTTPS 代理,因此需要处理 SSL/TLS。
2.1 安装 Nginx

在 Ubuntu 系统中,Nginx 可以通过 APT 包管理器安装:

sudo apt update
sudo apt install nginx

安装完成后,可以通过以下命令启动 Nginx:

sudo systemctl start nginx
2.2 验证 Nginx 安装

通过访问 http://<你的服务器 IP>,若能看到 Nginx 欢迎页面,说明安装成功。

三、Nginx 配置正向代理服务器

Nginx 默认情况下是作为反向代理服务器使用的。为了让其充当正向代理,我们需要通过配置文件进行修改。

3.1 配置文件路径

Nginx 的默认配置文件位于 /etc/nginx/nginx.conf,我们可以在该文件中添加代理配置。

sudo nano /etc/nginx/nginx.conf
3.2 启用 HTTP 正向代理

在 Nginx 配置中,新增代理服务器相关的配置。以下是一个配置正向代理的代码示例:

http {server {listen 8888;  # 代理服务器监听端口resolver 8.8.8.8;  # DNS 解析器location / {proxy_pass $scheme://$host$request_uri;  # 转发请求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;# 代理连接超时设置proxy_connect_timeout 60;proxy_send_timeout 60;proxy_read_timeout 60;}}
}
说明:
  • listen 8888;:代理服务器监听的端口号,客户端需要通过该端口访问代理服务器。
  • resolver 8.8.8.8;:使用 Google 的公共 DNS 服务器进行域名解析。
  • proxy_pass $scheme://$host$request_uri;:通过代理服务器将请求转发给目标服务器。
  • proxy_set_header:设置请求头,传递客户端的原始信息。

保存并退出配置文件后,重启 Nginx 使配置生效:

sudo systemctl restart nginx
3.3 测试 HTTP 正向代理

在配置好正向代理服务器后,可以通过以下方式在本地测试 HTTP 请求:

使用 cURL 测试
curl -x http://<你的服务器IP>:8888 https://www.example.com

-x 参数表示使用代理服务器访问目标网站。若能成功返回目标网站的内容,则正向代理配置成功。

四、配置 HTTPS 正向代理

4.1 添加 HTTPS 支持

由于 HTTPS 传输数据是加密的,Nginx 需要通过 CONNECT 方法来代理 HTTPS 请求。我们可以在 Nginx 的配置文件中加入以下代码以支持 HTTPS。

修改 /etc/nginx/nginx.conf 文件,新增以下内容:

server {listen 8888;  # 监听端口resolver 8.8.8.8 valid=300s;resolver_timeout 10s;# 配置代理 CONNECT 请求location / {proxy_pass $scheme://$host$request_uri;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;# 代理 HTTPS 请求的 CONNECT 方法proxy_connect_timeout 600;proxy_send_timeout 600;proxy_read_timeout 600;proxy_http_version 1.1;proxy_set_header Connection "";# 允许 CONNECT 请求if ($request_method = CONNECT) {proxy_pass http://$host:443;}}
}
解释:
  • proxy_http_version 1.1;:使用 HTTP 1.1,支持长连接。
  • proxy_pass http://$host:443;:针对 HTTPS 的 CONNECT 请求,转发到目标主机的 443 端口(HTTPS)。
4.2 重新启动 Nginx

保存配置文件后,使用以下命令重新启动 Nginx:

sudo systemctl restart nginx
4.3 测试 HTTPS 正向代理

使用 cURL 测试代理 HTTPS 网站请求:

curl -x http://<你的服务器IP>:8888 https://www.example.com

如果能正确返回 www.example.com 的内容,则说明 HTTPS 正向代理配置成功。

五、代理日志与错误排查

在代理配置过程中,查看 Nginx 日志是排查问题的重要手段。默认情况下,日志文件存放在 /var/log/nginx/access.log/var/log/nginx/error.log

# 查看访问日志
tail -f /var/log/nginx/access.log# 查看错误日志
tail -f /var/log/nginx/error.log

六、代理服务器的优化

正向代理服务器可能需要处理大量的客户端请求,因此在生产环境下可以对 Nginx 进行一些优化配置。

6.1 设置代理缓存

可以启用 Nginx 的缓存功能来减轻目标服务器的压力:

proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m max_size=1g inactive=60m use_temp_path=off;server {location / {proxy_cache my_cache;proxy_cache_valid 200 302 10m;proxy_cache_valid 404 1m;proxy_pass $scheme://$host$request_uri;}
}
6.2 增加并发请求数量

Nginx 的默认并发连接数限制较低,可以通过以下方式调整:

worker_processes auto;
events {worker_connections 10240;
}

七、总结

本文介绍了如何使用 Nginx 搭建正向代理服务器,支持 HTTP 和 HTTPS 网站代理,并提供了详细的代码和配置示例。通过本文的学习,您可以掌握搭建正向代理的基础知识,并能在实际项目中应用。

代理服务器是一种非常强大的工具,能够帮助我们隐藏客户端信息、绕过 IP 限制等。合理的配置和优化可以提升代理服务器的性能,从而满足实际应用中的需求。

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

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

相关文章

arduino扩展:Arduino Mega 控制 32 个舵机(参考表情机器人)

参考&#xff1a;表情机器人中使用22个舵机的案例 引言 在电子制作与自动化控制领域&#xff0c;Arduino 凭借其易用性和强大的扩展性备受青睐。Arduino Mega 作为其中功能较为强大的一款开发板&#xff0c;具备丰富的引脚资源&#xff0c;能够实现复杂的控制任务。舵机作为常…

PyQt学习记录03——批量设置水印

0. 目录 PyQt学习记录01——加法计算器 PyQt学习记录02——串口助手 1. 前言 本次主要是为了学习Qt中的 QFileDialog 函数&#xff0c; QFileDialog.getExistingDirectory&#xff1a;用于选择文件夹&#xff0c;返回的是一个文件夹路径。 QFileDialog.getOpenFileName&…

Visual Studio 使用 “Ctrl + /”键设置注释和取消注释

问题&#xff1a;在默认的Visual Studio中&#xff0c;选择单行代码后&#xff0c;按下Ctrl /键会将代码注释掉&#xff0c;但再次按下Ctrl /键时&#xff0c;会进行双重注释&#xff0c;这不是我们想要的。 实现效果&#xff1a;当按下Ctrl /键会将代码注释掉&#xff0c;…

社区版IDEA中配置TomCat(详细版)

文章目录 1、下载Smart TomCat2、配置TomCat3、运行代码 1、下载Smart TomCat 由于小编的是社区版&#xff0c;没有自带的tomcat server&#xff0c;所以在设置的插件里面搜索&#xff0c;安装第一个&#xff08;注意&#xff1a;安装时一定要关闭外网&#xff0c;小编因为这个…

利用kali linux 进行自动化渗透测试

本方案旨在自动化创建渗透测试全流程 一、架构 1.智能信息收集体系 class IntelligentOSINT:def __init__(self, target):self.target targetself.intelligence_sources [OSINT_Platforms,DeepWeb_Crawlers, SocialMedia_Trackers,ML_Correlation_Engine]def advanced_col…

Flink-DataStream API

一、什么样的数据可以用于流式传输 Flink的DataStream API 允许流式传输他们可以序列化的任何内容。Flink自己的序列化程序用于 基本类型&#xff1a;即字符串、长、整数、布尔值、数组复合类型&#xff1a;元组、POJO和Scala样例类 基本类型我们已经很熟悉了&#xff0c;下…

渗透利器:Burp Suite 联动 XRAY 图形化工具.(主动扫描+被动扫描)

Burp Suite 联动 XRAY 图形化工具.&#xff08;主动扫描被动扫描&#xff09; Burp Suite 和 Xray 联合使用&#xff0c;能够将 Burp 的强大流量拦截与修改功能&#xff0c;与 Xray 的高效漏洞检测能力相结合&#xff0c;实现更全面、高效的网络安全测试&#xff0c;同时提升漏…

AI时代,职场人如何开启学习之旅

为什么要学习 AI 在当今数字化时代&#xff0c;AI 正以前所未有的速度改变着我们的工作和生活方式。从智能客服到自动化生产&#xff0c;从数据分析到个性化推荐&#xff0c;AI 已经广泛渗透到各个行业和领域。学习 AI&#xff0c;对于工作人员来说&#xff0c;不仅是提升工作…

2.3 Transformer架构革命:从自注意力到万亿参数大模型的演进之路

Transformer架构革命&#xff1a;从自注意力到万亿参数大模型的演进之路 一、Transformer核心突破&#xff1a;彻底颠覆序列建模范式 1.1 传统序列模型的致命瓶颈 # RNN/LSTM的串行计算缺陷示例 hidden_state torch.zeros(seq_len, batch_size, hidden_dim) for t in ra…

Java 大视界 -- 深入剖析 Java 在大数据内存管理中的优化策略(49)

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

JVM ②-双亲委派模型 || 垃圾回收GC

这里是Themberfue 在上节课对内存区域划分以及类加载的过程有了简单的了解后&#xff0c;我们再了解其他两个较为重要的机制&#xff0c;这些都是面试中常考的知识点&#xff0c;有必要的话建议背出来&#xff0c;当然不是死记硬背&#xff0c;而是要有理解的背~~~如果对 JVM …

html文件怎么转换成pdf文件,2025最新教程

将HTML文件转换成PDF文件&#xff0c;可以采取以下几种方法&#xff1a; 一、使用浏览器内置功能 打开HTML文件&#xff1a;在Chrome、Firefox、IE等浏览器中打开需要转换的HTML文件。打印对话框&#xff1a;按下CtrlP&#xff08;Windows&#xff09;或CommandP&#xff08;M…

【Redis】 - Redis的Bitmap实现用户签到

Redis的Bitmap实现用户签到 使用Redis的Bitmap数据结构来记录用户的每日签到状态是一种高效且节省空间的方法。通过将用户ID和日期结合生成动态Key&#xff0c;可以轻松管理不同用户在不同日期的签到情况。下面详细介绍如何设计这一方案。 设计思路 动态Key生成&#xff1a;根…

系统开发:大文件下载报错问题

问题描述&#xff1a;在个人开发文件上传管理系统时&#xff0c;遇到小文件可以直接下载&#xff0c;遇到大文件只能在刚登陆成功时下载一次&#xff0c;再次下载别的大文件就会报错&#xff0c;具体错误信息是这样&#xff1a; AxiosError {message: Network Error, name: Ax…

蓝桥杯备赛笔记(二)

这里的笔记是关于蓝桥杯关键知识点的记录&#xff0c;有别于基础语法&#xff0c;很多内容只要求会用就行&#xff0c;无需深入掌握。 文章目录 前言一、时间复杂度1.1 时间复杂度⭐1.2 空间复杂度1.3 分析技巧 总结 前言 持续更新&#xff0c;千里之行始于足下 一、时间复杂度…

2025 西湖论剑wp

web Rank-l 打开题目环境&#xff1a; 发现一个输入框&#xff0c;看一下他是用上面语言写的 发现是python&#xff0c;很容易想到ssti 密码随便输&#xff0c;发现没有回显 但是输入其他字符会报错 确定为ssti注入 开始构造payload&#xff0c; {{(lipsum|attr(‘global…

Web前端开发--HTML

HTML快速入门 1.新建文本文件&#xff0c;后缀名改为.html 2.编写 HTML结构标签 3.在<body>中填写内容 HTML结构标签 特点 1.HTML标签中不区分大小写 2.HTML标签属性值中可以使用单引号也可使用双引号 3.HTML语法结构比较松散&#xff08;但在编写时要严格一点&…

加油口,电梯门的对称性对 TCP/IP 传输协议的启示

春节期间河南穷游屡次加油站排队加油之启示。 不考虑有意的设计因素&#xff0c;汽车加油口概率性分布在车身的左边或者右边&#xff0c;这个偶然的小细节让加油机同时为两辆车加油而无需额外的加油管。 如果所有车辆加油口都在同一侧&#xff0c;加油站的加油机就只能给一边的…

网络工程师 (30)以太网技术

一、起源与发展 以太网技术起源于20世纪70年代&#xff0c;最初由Xerox公司的帕洛阿尔托研究中心&#xff08;PARC&#xff09;开发。最初的以太网采用同轴电缆作为传输介质&#xff0c;数据传输速率为2.94Mbps&#xff08;后发展为10Mbps&#xff09;&#xff0c;主要用于解决…

ONES 功能上新|ONES Copilot、ONES TestCase、ONES Wiki 新功能一览

ONES Copilot 支持基于当前查看的工作项相关信息&#xff0c;利用 AI 模型&#xff0c;在系统中进行相似工作项的查找&#xff0c;包括基于已关联工作项的相似数据查找。 应用场景&#xff1a; 在查看工作项时&#xff0c;可利用 AI 模型&#xff0c;基于语义相似度&#xff0c…