nginx实现跨越两层的代理

1、场景描述

DMZ区一台web服务器可上外网,内网一台web服务器提供内部访问,应用服务器不需要访问外网,但是终端需要和外网对应的域名进行交互。

2、解决方案
在dmz区配置nginx实现正向代理,内网web服务器配置nginx实现tcp转发 ,允许的终端通过ie设置代理进行访问外网指定域名。
3、服务器信息
dmz区web服务器IP :192.168.6.66
内网web服务器IP : 192.168.2.6
4、dmz区(192.168.6.66)正向代理配置
server {
resolver 8.8.8.8; #指定dns服务器
listen 8888; #指定端口
server_name localhost;
proxy_connect_timeout 600;
proxy_read_timeout 600;
proxy_send_timeout 600;
#charset koi8-r;
access_log logs/nginx/access8888.log main;#指定日志路径
location / {
#判断访问的地址是否含有csdn,如果是则可访问
if ( KaTeX parse error: Expected '}', got 'EOF' at end of input: …xy_pass http://http_host$request_uri;
}
proxy_pass http://192.168.0.123; #不匹配打开不存在网站
proxy_set_header HOST $http_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;
}
重新加载nginx后,然后通过,进行验证
curl --proxy 192.168.6.66:8888 http://www.baidu.com

5、内网web服务器( 192.168.2.6)配置

需要说明的是内同nginx的需要安装负责TCP转发的模块为stream,这个需要指定安装,在configure 时,需要指定 --with-stream,然后配置如下:

stream {
    log_format tcp_proxy '$remote_addr [$time_local] '
                         '$protocol $status $bytes_sent $bytes_received '
                         '$session_time "$upstream_addr" '
                         '"$upstream_bytes_sent" "$upstream_bytes_received"           "$upstream_connect_time"';

  access_log  logs/nginx/tcpacces.log tcp_proxy;
    server {
       listen  192.168.2.6:8888;  
       proxy_connect_timeout 1s;
       proxy_timeout 3s;
       proxy_pass 192.168.6.66:8888;  
   }
}

这个配置是和http平级的。
nginx -s relaod
然后通过
curl --proxy 192.168.2.66:8888 http://www.baidu.com 看看是否可以打开网页。
6、控制终端上网
可以在服务器的防火墙上设置哪些IP可以访问本机的8888端口。
7、 终端上网,在IE设置http代理。
打开浏览器的Internet选项----连接-----设置—代理服务器
设置 192.168.2.6 8888
然后验证是否正常。

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值