配置Nginx TCP转发

Nginx一般用在HTTP的转发,TCP的转发大都会使用HAProxy。工作中遇到一个需求,用到了Nginx服务作为TCP转发。场景是这样,数据采集设备通过公网将数据推送到后端应用服务,服务部署在业主的IDC中,不能对外暴露,有现成的Nginx服务器部署在DMZ中,充当数据转发服务,拓扑如下:

Nginx的配置如下:

stream {
    upstream backend {
        server 10.0.0.2:8000 weight=1 max_fails=2 fail_timeout=60s;
    }
    server {
        listen 6020;
        proxy_connect_timeout 1s;
        proxy_pass backend;
    }
}

其中10.0.0.2是后端应用服务器的IP地址。这样推送服务器就可以使用Nginx服务器的公网地址+6020端口访问到后端应用服务器。

上面的配置对于后端应用服务是非HTTP的TCP服务和HTTP服务都适合。如果后端服务是HTTP服务,也可以使用下面的配置,

http {
  ......
      server {
          listen 6020;
          server_name           proxy.example.com;

          location / {
              proxy_pass http://backend.example.com;
              proxy_redirect off;
          }
       }
}

这里有个问题,当推送服务器使用proxy.example.com这个域名访问进来的时候,后端应用服务器看到的是哪个主机头呢?答案是backend.example.com,如果这不是你想要的,可以使用Nginx的“proxy_set_header”指令。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值