Nginx配置四层、七层网络代理转发的方法示例

 更新时间:2024年03月08日 16:12:32   作者:银空飞羽  
nginx作为透明代理可以充分利用其高性能和灵活性来实现网络流量的转发和处理,本文主要介绍了Nginx配置四层、七层网络代理转发的方法示例,具有一定的参考价值,感兴趣的可以了解一下

写在前面

最近工作中有个需求,三个网络区域A、B、C。A可以和B互通,A与C不互通,B与C互通。现在需要从A区域发送数据到C区域固定地址。显而易见,搭建一个网络代理就可以了。

但是又有两种请求,一种是加密的七层GRPC协议的数据,一种是七层HTTP请求的数据。研究之后,GRPC协议的数据需要做四层透明代理转发到目的地址,HTTP就正常走七层转发。于是决定使用Nginx来满足需求。

GRPC四层代理配置

首先GPRC协议是一个基于HTTP2的七层协议,所以它是需要证书加解密的。客户端加密,服务端解密,所以在传输过程中我并不需要做什么操作,直接让数据传递过去就行了,仅仅是提供一个网络隧道。

(这里之前踩了坑,一直想通过配置GRPC协议来进行转发,实际上压根没必要)

所以,这种场景下,只需要提供一个四层的透明代理就可以了,只要让它经过代理送到目的地就行了。

在Nginx的配置文件中,与http同级别作如下配置

stream {
    log_format  proxy '$remote_addr -  [$time_local]  $status $protocol'
                      '"$upstream_addr" "$upstream_bytes_sent" "$upstream_connect_time"' ;
    #调用日志,使用proxy格式
    access_log /var/log/nginx/tcp_proxy.log proxy;

    upstream grpcservers {
            server ip1:port;
            server ip2:port;
        }
        server {
            listen 12345;
            proxy_pass grpcservers;
        }


}

http {

  ...
}

结构大概如上,如果没有http需求可以直接删掉,写出来只是为了表达与http同级别。

stream就是配置四层代理的,在例子中我通过upstream来定义多个目的server用来达到负载均衡的效果。然后在下面的server中监听了12345端口,同时通过proxy_pass指向了转发目的地址即上述的upstream的内容。

如此一来,所有发向该Nginx IP 12345端口的数据都会被转发到对应的地址,即完成了四层透明代理。

HTTP七层代理配置

七层的就相对简单多了,直接在http中添加即可

http{
	...

			server {
            listen 80;
            server_name test.example.com;
            location / {
                proxy_pass http://test.target.com ;
            }
  		}
  ...
}

如上配置,监听了80端口,同时设置了server_name,这代表来源请求Host为test.example.com的都会走下面的这层location跳转,即代理到http://test.target.com这个地址,并包含路由path。

例如:A区域的机器请求到B中的该Nginx,请求内容为GET一下http://test.target.com/admin/test ,那么相应的,经过Nginx代理之后变为http://test.target.com/admin/test

最后

本篇文章主要涉及Nginx的一些代理使用,来源于工作时,设计的一个方案中碰到的一个跨网数据传输的问题,上述方法已经满足需求。

到此这篇关于Nginx配置四层、七层网络代理转发的方法示例的文章就介绍到这了,更多相关Nginx配置四层、七层网络代理转发内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • nginx修改默认运行80端口的方法

    nginx修改默认运行80端口的方法

    这篇文章主要给大家介绍了关于nginx是如何修改默认运行80端口的方法,文中介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-04-04
  • 详解Centos7 源码编译安装 Nginx1.13

    详解Centos7 源码编译安装 Nginx1.13

    这篇文章主要介绍了详解Centos7 源码编译安装 Nginx1.13,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • 从零实现Nginx风格内存池完整代码

    从零实现Nginx风格内存池完整代码

    本文将从为什么需要内存池讲起,重点探讨内存池的设计哲学,并详细拆解其实现方案,从而搭建起读者对内存池从理论到实践的完整认知模型,感兴趣的朋友跟随小编一起看看吧
    2026-05-05
  • nginx实现tomcat动静分离详解

    nginx实现tomcat动静分离详解

    本篇文章主要介绍了nginx实现tomcat动静分离详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Nginx 反向代理配置避坑指南(proxy_pass 斜杠、502排查、CORS、文件上传)

    Nginx 反向代理配置避坑指南(proxy_pass 斜杠、502排查、CORS、文件上传)

    本文系统总结了Docker环境下Nginx反向代理配置的10个常见问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2026-03-03
  • 通过nginx代理拦截请求进行全局访问限制

    通过nginx代理拦截请求进行全局访问限制

    这篇文章主要介绍了通过nginx代理拦截请求进行全局访问限制,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • 解读Nginx和Apache的特点与区别

    解读Nginx和Apache的特点与区别

    这篇文章主要介绍了解读Nginx和Apache的特点与区别,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • Nginx性能调优与深度监控的全攻略

    Nginx性能调优与深度监控的全攻略

    本文介绍了Nginx的高性能编译安装、核心参数调优、静态资源缓存、日志切割、Gzip压缩等调优方案,并介绍了GoAccess实时日志分析和NginxVTS流量监控两大可视化监控工具,帮助大家在高并发场景下稳定、高效地运行Nginx服务,需要的朋友可以参考下
    2026-04-04
  • nginx反向代理之将80端口请求转发到8080

    nginx反向代理之将80端口请求转发到8080

    这篇文章主要介绍了nginx反向代理之将80端口请求转发到8080,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • Nginx负载均衡中的Memcached缓存模块

    Nginx负载均衡中的Memcached缓存模块

    Nginx 的 ngx_http_memcached_module 模块本身并没有提供缓存功能,它只是一个将用户请求转发到 Memcached 服务器的代理模块,这篇文章主要介绍了Nginx负载均衡之Memcached缓存模块,需要的朋友可以参考下
    2024-06-06

最新评论