使用Nginx正向代理让内网主机通过外网主机访问互联网

目录

环境概述

流程说明

在外网服务器上安装部署nginx 

安装前准备

下载nginx

 编译安装nginx

开始配置正向代理

创建systemd服务单元文件,用于管理Nginx服务的启动、停止和重新加载

启动nginx

 代理服务器本地验证

 内网服务器验证

 将代理地址添加到环境变量中直接使用


环境概述

        在企业网络环境中,通常会存在内网与外网的隔离,内网机器无法直接访问外部Internet。而外网机器具有访问互联网的能力。为了让内网机器能够通过外网机器访问互联网,我们可以配置Nginx正向代理来实现。

(代理服务器为linux系统,Windows系统中nginx中默认不包含proxy_connect模块,Windows编译proxy_connect模块比较麻烦,可以使用CCProxy代理软件实现,参考外网主机使用CCProxy代理使内网主机上网)

  • 内网主机:172.211.216.242  (无法直接访问外部Internet)
  • 外网主机:192.168.0.97 (可以访问Internet,并充当代理服务器)
  • 前置条件:内网主机和外网主机虽然不是在同一网段,但是可以互相访问,正向代理的端口需要互通,这里用的8080

流程说明

  1.  内网服务器发送请求:内网服务器通过HTTP或HTTPS发送请求到外网代理服务器的8080端口。

  2.   代理服务器接收请求:外网代理服务器接收到请求后,根据请求的协议(HTTP或HTTPS)使用proxy_pass将请求转发到目标互联网服务器。

  3.   互联网服务器处理请求:目标互联网服务器接收到请求后处理并生成响应。

  4.   代理服务器返回响应:互联网服务器将响应发送回外网代理服务器,然后代理服务器将响应转发回内网服务器。

 代理流程:

 A[内网主机 172.211.216.242] -- 请求 --> B[Nginx代理 192.168.0.97:8080]
 B -- 转发请求 --> C[目标服务器]
 C -- 返回响应 --> B
 B -- 返回响应 --> A



+----------------------+             +------------------------+             +---------------------+
|     内网服务器      |             |    外网代理服务器       |             |   互联网服务器     |
| 172.211.216.242     | -------->  |  192.168.0.97:8080     | -------->   |  www.example.com    |
|                      |           |                        |             |                     |
| 发送HTTP/HTTPS请求   |            | 接收并转发请求          |             | 处理请求并返回响应  |
+----------------------+             +------------------------+             +---------------------+
       ^                                      |                                       |
       |                                      v                                       |
       +----------------------<----------------+-----------------------<--------------+



在外网服务器上安装部署nginx 

安装前准备

由于Nginx默认不支持HTTPS代理,我们需要额外添加模块。使用的模块是ngx_http_proxy_connect_module。使用模块前需请确保模块和Nginx版本匹配。如图:

我这里有用的是1.20.2版本所以使用proxy_connect_rewrite_1018.patch


可以直接通过下载压缩包,解压之后通过patch命令打入补丁。

#安装patch:
yum install patch -y
cd /root
wget https://github.com/chobits/ngx_http_proxy_connect_module/archive/refs/tags/v0.0.2.zip
unzip v0.0.2.zip
下载nginx
cd /root
wget http://nginx.org/download/nginx-1.20.2.tar.gz
#解压
tar xf nginx-1.20.2.tar.gz 

#进入nginx目录
cd nginx-1.20.2/

#使用patch命令导入补丁 注意路径是否一致 我是直接在根目录操作的
patch -p1 < /root/ngx_http_proxy_connect_module-0.0.2/patch/proxy_connect_rewrite_1018.patch

 编译安装nginx
#安装编译工具和库 
yum install gcc cmake make cmake unzip ncurses-devel gcc gcc-c++ -y

#配置Nginx编译选项,使其在编译Nginx时包含ngx_http_proxy_connect_module-0.0.2模块
./configure --prefix=/usr/local/nginx --add-module=/root/ngx_http_proxy_connect_module-0.0.2

#编译和安装Nginx
make && make install
开始配置正向代理
cd /usr/local/nginx/conf/

#习惯性备份
cp nginx.conf nginx.conf.bak

#编辑
vi  nginx.conf

可以直接参考这个 (可以直接拷贝使用)

# 设置Nginx主进程数量为1,通常在单核服务器上只需要一个主进程
worker_processes  1;

# 每个工作进程能够同时处理的最大连接数
events {
    worker_connections  1024;
}


http {
    # 引入mime.types文件,定义文件扩展名和对应的MIME类型
    include       mime.types;

    # 设置默认的MIME类型为application/octet-stream
    default_type  application/octet-stream;

    # 使用sendfile系统调用来发送文件,提高性能
    sendfile        on;

    # HTTP连接的超时时间,这里是65秒
    keepalive_timeout  65;

    server {
    # 服务器监听的端口号为8080
    listen                           8080;

    # 服务器名称为localhost
    server_name                      localhost;

    # 指定DNS服务器地址为114.114.114.114,禁用IPv6解析
    resolver                         114.114.114.114 ipv6=off;

    # 开启HTTP CONNECT方法支持,用于建立与后端服务器的TCP连接
    proxy_connect;

    # 允许通过代理的端口,这里允许443和80端口
    proxy_connect_allow              443 80;

    # 建立连接的超时时间为10秒
    proxy_connect_connect_timeout    10s;

    # 读取数据的超时时间为10秒
    proxy_connect_read_timeout       10s;

    location / {
        # 将请求转发到代理目标
        proxy_pass $scheme://$http_host$request_uri;
    }
}

}
创建systemd服务单元文件,用于管理Nginx服务的启动、停止和重新加载
echo "[Unit]
Description=The NGINX HTTP and reverse proxy server
After=network.target
Wants=network.target

[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStartPre=/usr/local/nginx/sbin/nginx -t
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s stop
PrivateTmp=true

[Install]
WantedBy=multi-user.target" | sudo tee /etc/systemd/system/nginx.service
启动nginx
systemctl daemon-reload

systemctl start nginx

systemctl enable nginx

 代理服务器本地验证

 curl -I https://blog.csdn.net/ -v -x 127.0.0.1:8080

如图 出现"HTTP/1.1 200 Connection Established" 表示代理服务器已经成功建立了连接

  内网服务器验证

curl -I https://blog.csdn.net/ -v -x 192.168.0.97:8080

如图 直接curl不通,加上代理地址端口是通的

(这一步要确保内网主机和外网服务器之间端口互通) 可以使用telnet测试

 将代理地址添加到环境变量中直接使用

vi /etc/profile

#编辑/etc/profile文件 在最后一行加入

export http_proxy=192.168.0.97:8080
export https_proxy=192.168.0.97:8080
 
#192.168.0.97:8080 为你的代理服务器ip和端口

注意 使用source命令使其生效

 source /etc/profile

直接curl https://blog.csdn.net/  成功访问到  代理成功

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

38. 【Java教程】日期和时间处理

本小节我们将学习 Java 中的日期和时间&#xff0c;日期和时间在我们的实际开发中非常常用&#xff0c;例如用户的注册、数据的增删改、对敏感信息的操作等等都需要记录下日期和时间。通过本小节的学习&#xff0c;你将了解到什么是日期、什么是时间、什么是时区&#xff0c;Ja…

查看云是基于openstack是哪一个版本开发的?

进入版本发行网站&#xff1a; OpenStack Releases: OpenStack Releases 进入云的后台&#xff0c;查看例如nova的版本号 rpm -qa | grep nova 查看到nova的版本号是21版本&#xff0c;点开releases中例如Ussuri查看nova的版本号&#xff0c;是21&#xff0c;则该云是基于U…

数据分析技术---对比K-means,密度分析和层次聚类性能

一、数据集选择&#xff1a; Iris数据集。 二、实验代码&#xff1a; #对比k-means、密度聚类和层次聚类性能import matplotlib.pyplot as pltfrom sklearn import datasetsfrom sklearn.cluster import KMeans, DBSCAN, AgglomerativeClusteringfrom sklearn.preprocessing i…

STM32自己从零开始实操04:显示电路原理图

一、TFT-LCD 屏接口 1.1指路 以下是该部分的设计出来后的实物图&#xff0c;我觉得看到实物图可能更方便理解这部分的设计。 图1 实物图 这部分设计的是一个屏幕的接口&#xff0c;很简单。使用的屏幕是&#xff1a;2.8inch 16BIT Module MRB2801。 1.2数据手册 &#xff0…

metasploit上线之后可以使用的命令

1. 通用控制命令 meterpreter > essions -k 1 # 通过ID号杀死一个会话 meterpreter > background # 将会话放入后台 meterpreter > getuid/getpid # 查询用户权限与PID meterpreter > sysinfo # 查看目标…

智慧校园教学模式的崛起:优化学习体验

在当今数字化时代&#xff0c;智慧校园教学模式正在成为教育界的热门话题。随着科技的不断发展&#xff0c;传统的教学方式已经无法满足现代学生的需求。智慧校园教学模式以其灵活性、互动性和个性化的特点&#xff0c;正逐渐改变着教育的面貌。 首先&#xff0c;智慧校园教学模…

R_AARCH64_ADR_PREL_PG_HI21问题说明

目录 问题现象&#xff1a; 问题原因 问题机理 问题现象&#xff1a; 客户现场加载out文件出现如下问题&#xff1a; 打印“Relocation of type ‘R_AARCH64_ADR_PREL_PG_HI22…..’”,明确是ARDP指令引起的问题 问题原因 ARDP的寻址范围是4GB范围&#xff0c;加载的位置…

Tomcat概述及部署

目录 一、Tomcat概述 1.Tomcat的简介 2.Tomcat 核心的三个组件 3.应用场景 4.Tomcat 请求过程 二、部署安装Tomcat 三、Tomcat 虚拟主机配置 四、Tomcat多实例部署 一、Tomcat概述 1.Tomcat的简介 Tomcat 是 Java 语言开发的&#xff0c;Tomcat 服务器是一个免费的开…

经验分享,超声波车位引导系统和视频车位引导系统有哪些区别

随着城市化进程的加速和汽车保有量的持续增长&#xff0c;停车难已成为城市交通管理的一大挑战。车位引导系统作为解决这一问题的有效工具&#xff0c;其重要性日益凸显。它不仅能够提升停车场的运营效率&#xff0c;还能显著改善驾驶者的停车体验。目前市场上主要有两种车位引…

颠沛流离学二叉树(完结撒花篇)

本篇会加入个人的所谓鱼式疯言 ❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言 而是理解过并总结出来通俗易懂的大白话, 小编会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的. &#x1f92d;&#x1f92d;&#x1f92d;可能说的不是那么严谨.但小编初心是能让更多人…

mac M1下安装PySide2

在M1下装不了PySide2, 是因为PySide2没有arm架构的包 1 先在M1上装qt5 安装qt主要是为了能用里面的Desinger, uic, rcc brew install qt5 我装完的路径在/opt/homebrew/opt/qt5 其中Designer就是用来设计界面的 rcc用resource compiler, 编绎rc资源文件的, 生成对应的py文件…

使用pexpect检查SSH上的文件是否存在

使用 pexpect 模块可以在 Python 中执行命令并检查其输出。你可以使用 ssh 命令连接到远程服务器&#xff0c;并执行 ls 命令检查文件是否存在。下面我就列举几个我经常遇到的几个错误并做个详细的解决方案。 1、问题背景 用户需要编写一个 Python 脚本&#xff0c;以检查一个…

编制教师违约金一般是多少钱

老师们&#xff0c;你们在签订合同时&#xff0c;对合同中提到的违约金条款感到疑惑&#xff1f;那么&#xff0c;编制教师的违约金一般是多少呢&#xff1f;可能很多老师在签订合同时都没有一个明确的答案。 违约金的设定是为了保障双方的权益&#xff0c;当一方违反合同约定时…

有极性电容器的引脚极性怎么判别?

由于有极性电容器有正、负之分&#xff0c;在电路中又不能乱接&#xff0c;所以在使用有极性电容器前需要先判别出正、负极。有极性电容器的正、负极判别方法如图2—9&#xff5e;图2—11所示。 方法一&#xff1a;对于未使用过的新电容&#xff0c;可以根据引脚长短来判别。引…

【阿里前端面试题】聊聊前端性能优化的方案,解决过什么样的性能问题?

大家好&#xff0c;我是“寻找DX3906”。每天进步一点。日积月累&#xff0c;有朝一日定会厚积薄发&#xff01; 前言&#xff1a; 前面已经和大家分享了4篇面试题&#xff1a; 《【阿里前端面试题】浏览器的加载渲染过程》 《【阿里前端面试题】客户端和服务器交互&#xff…

VUE3 学习笔记(12):对比Vuex与Pinia状态管理的基本理解

在组件传值中&#xff0c;当嵌套关系越来越复杂的时候必然会将混乱&#xff0c;是否可以把一些值存在一个公共位置&#xff0c;无须传值直接调用呢&#xff1f;VUEX应运而生&#xff0c;但是从VUE3开始对VUEX的支持就不那么高了&#xff0c;官方推荐使用Pinia。 Vuex配置 ST1:…

NGINX之location和rewrite

一.NGINX常用的正则表达式 二.Location location作用:对访问的路径做访问控制或者代理转发 1.location 常用的匹配规则&#xff1a; 进行普通字符精确匹配&#xff0c;也就是完全匹配^~ / 表示普通字符匹配。使用前缀匹配。如果匹配成功&#xff0c;则不再匹配其它 …

场外个股期权的杠杆率有多大?

场外个股期权作为金融衍生品的一种&#xff0c;为投资者在个股交易中提供了显著的杠杆效应。这种杠杆效应&#xff0c;简单来说&#xff0c;就是投资者通过较少的资金控制更大金额的投资&#xff0c;从而放大了投资收益的可能性&#xff0c;但同时也伴随着风险的增加。 文章来…

算法基础之哈希表

大家好&#xff0c;这里是教授.F 什么是哈希表&#xff1a; 哈希表其实就是数组的pro版本。数组有下标&#xff0c;每个下标对应着一个值。哈希表也类似&#xff0c;哈希表有很多哈希值&#xff0c;然后每一个哈希值都会对应着一个值。就是这样&#xff1a;hash(key) 哈希表的…

这个高考作文满分的极客,想和你聊聊新媒体写作

计育韬 曾为上海市高考作文满分考生 微信官方 SVG AttributeName 开发者 新榜 500 强运营人 复旦大学青年智库讲师 浙江传媒学院客座导师 上海团市委新媒体顾问 上海市金山区青联副主席 文案能力&#xff0c;从来就不是一蹴而就的。今天&#xff0c;来和大家聊聊当年我的…