Nginx正向代理使内网机器访问外网

机器详情

机器网卡
机器1(可访问外网)ens33:192.168.46.56/24 ens34:192.168.10.16/24
机器2(只能内网)ens33:192.168.10.11/24

机器1配置

下载nginx(我选择的是nginx-1.20.0)

链接:http://nginx.org/download/

下载ngx_http_proxy_connect_module (我选择的版本为0.0.5)

链接:https://github.com/chobits/ngx_http_proxy_connect_module

开始编译安装

# 两个压缩我均放置在/root/目录下
# 解压这两压缩包
tar -xvf nginx-1.20.0.tar.gz
tar -xvf ngx_http_proxy_connect_module-0.0.5.tar.gz

# 先安装编译环境
apt -y install gcc make g++ libtool-bin libexpat1-dev build-essential libpcre3 libpcre3-dev zlib1g zlib1g-dev openssl libssl-dev libxml2-dev libcurl4-openssl-dev pkg-config pkgconf

# 编译安装nginx
cd nginx-1.20.0/
# proxy_connect_rewrite_1018.patch不是一成不变的,要根据自己的nginx版本选择,GitHub链接上有讲
patch -p1 < /root/ngx_http_proxy_connect_module-0.0.5/patch/proxy_connect_rewrite_1018.patch
./configure --add-module=/root/ngx_http_proxy_connect_module-0.0.5
make && make install

# 编写nginx配置文件
# 配置在http{}内
vim /usr/local/nginx/conf/nginx.conf
server {
        resolver 114.114.114.114;
        listen 80;
        server_name  localhost;
        location / {
                proxy_pass                 http://$host$request_uri;
                proxy_set_header           HOST $host;
                proxy_buffers              256 4k;
                proxy_max_temp_file_size   0k;
                proxy_connect_timeout      30;
                proxy_send_timeout         60;
                proxy_read_timeout         60;
                proxy_next_upstream error  timeout invalid_header http_502;
        }
    }
server {
        resolver 114.114.114.114;
        listen 443;
        proxy_connect;
        proxy_connect_allow            443 563;
        proxy_connect_connect_timeout  10s;
        proxy_connect_read_timeout     10s;
        proxy_connect_send_timeout     10s;
        location / {
                proxy_pass http://$host;
                proxy_set_header Host $host;
        }
    }

# 重启nginx使配置生效
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
cd /usr/local/nginx/sbin
./nginx -t
./nginx -s reload

在这里插入图片描述

机器2测试

curl命令测试

curl http://www.baidu.com -v -x 192.168.10.16:80
curl https://www.baidu.com -v -x 192.168.10.16:443

apt测试

vim /etc/apt/apt.conf.d/proxy.conf
Acquire::http::Proxy "http://192.168.10.16:80";
Acquire::https::Proxy "https://192.168.10.16:443";

在这里插入图片描述

apt update

没有设置的效果
在这里插入图片描述
设置了的效果
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想看一次满天星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值