nginx实现根据URL转发请求的实战经历

  

  

因为这久完成了一个分布式文件系统的内网外穿部署,使用fastdfs,该应用部署8088年到端口,它的后台管理系统部署在8089端口(同一个内网服务器),该后台管理系统的服务要请求fastdfs服务,可以直接请求(同一个服务器的资源),但是我们现在只外穿了后台管理系统(Springboot项目),不通过公网分配的IP只能访问到后台管理系统,要直接访问fastdfs服务的接口的话必须连接服务器公网,但是这限制了我们用户的访问(我没办法每次都去你的服务器的地方访问,我想在其他地方也可以访问)

  
  

代理服务器:SockerServer监听某个端口,根据http报文连接到指定服务器端口,进行数据请求
  - - - - - - HTTP代理
  http请求经过代理服务器,代理服务器只要负责转发相应的http响应体就可以了。
  ——HTTPS代理
  https请求经过代理服务器,会发送一个连接报文,用于和代理服务器建立隧道,如果代理服务器返回HTTP 200,则建立成功,后续代理服务器只要负责转发数据就行,实际上SSL/TLS握手还是发生在客户端和真实服务器。

     

  

因为该后台项目8089端口可以访问服务器fastdfs服务,所以我首先想到的是使用Springboot的ProxyServlet把指定请求代理到服务器8088端口

  
  

春季启动的主Servlet为SpringMVC的DispatcherServlet,其默认的url模式为“/?如果我们想要为某个url添加不同的调用(其他服务器接口),则需要创建新的代理Servlet,会使用到ServletRegistrationBean,创建一个新的ProxyServlet来处理不同端口的监听和数据的发送,并将它注册到springboot管理的servletContext中(设置指定服务器和端口,请求转发的接口)

     

<强>依赖

        & lt; dependency>   & lt; groupId> org.mitre.dsmiley.httpproxy   & lt; artifactId> smiley-http-proxy-servlet   & lt; version> 1.7 & lt;/version>   & lt;/dependency>      

<>强配置

        # # #配置代理   #请求资源时代理转发到端口8088项目中   proxy.test。servlet_url_one=/资源/*   proxy.test。target_url_one=https://localhost: 8088            @ component   @ data   公开课ProxyFilterServlet {   @ value (" $ {proxy.test.target_url_one} ")   私人字符串targetUrl;   @ value (" $ {proxy.test.servlet_url_one} ")   私人字符串servletUrl;   }      

<强>更改配置添加

        @ configuration   公开课ProxyServletConfig {   @ autowired   私人ProxyFilterServlet ProxyFilterServlet;//多个代理servlet可以配置多个bean   @ bean   公共ServletRegistrationBean ServletRegistrationBean () {   ServletRegistrationBean ServletRegistrationBean=new ServletRegistrationBean(新ProxyServlet (), proxyFilterServlet.getServletUrl ());//这个setName必须要设置,并且多个的时候,名字需要不一样   servletRegistrationBean.setName (“go_backend”);   servletRegistrationBean。addInitParameter (“targetUri proxyFilterServlet.getTargetUrl ());   servletRegistrationBean.addInitParameter (ProxyServlet。P_LOG,“假”);   返回servletRegistrationBean;   }   }      
  

通过servlet容器来建立与目标服务器连接,毕竟没有nginx这样的专业代理服务器强

     

<强> nginx -代理转发

  
      <李>这个时候我想到了服务器之间添加一层nginx,来把不同的服务请求转发到不同的端口api去处理李   
  

把需要请求的外网的请求转到同一服务器内网端口
  

        服务器{   听80;   server_name 127.0.0.1;      位置/{   proxy_pass http://127.0.0.1:3000;   }      位置~/api/{   proxy_pass http://172.30.1.123:8081;   }   }      

参考博文:
  

  

https://www.jb51.net/article/174382.htm
  

  https://www.jb51.net/article/174383.htm

  

  

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。

nginx实现根据URL转发请求的实战经历