nginx反向代理内外网通过不同端口号访问的配置场景
场景描述
1 内网一个web应用,通过nginx反向代理到后端的tomcat,nginx监听在80端口,tomcat监听在8080端口。
2 在防火墙上做了地址转换,映射成了一个公网地址的4380端口
想实现外网通过 公网ip+4380端口 访问,内网通过 内网IP+80端口 访问。
思路
查了一下nginx的官方手册,好像没法把客户请求时写的端口号传递到后端服务器。于是就自己启用了一个变量,通过if语句做判断,把变量传递给location。变量的值根据请求的IP地址来确定。内网地址访问时,变量的值是80。外网地址访问时,变量是4380。
配置##
if ($remote_addr ~* ^10\.(.*?)\.(.*?)\.(.*?)$)
{
set $port 80;
}
if ($remote_addr !~* ^10\.(.*?)\.(.*?)\.(.*?)$)
{
set $port 4380;
}