由于这久完成了一个分布式文件系统的内网外穿部署,使用fastdfs,该应用部署到8088端口,它的后台管理系统部署在8089端口(同一个内网服务器),该后台管理系统的服务要请求fastdfs服务,能够直接请求(同一个服务器的资源),可是咱们如今只外穿了后台管理系统(Springboot项目),不经过公网分配的IP只能访问到后台管理系统,要直接访问fastdfs服务的接口的话必须链接服务器公网,可是这限制了咱们用户的访问(我没办法每次都去你的服务器的地方访问,我想在其余地方也能够访问)nginx
代理服务器:SockerServer监听某个端口,根据http报文链接到指定服务器端口,进行数据请求spring
- HTTP代理api
http请求通过代理服务器,代理服务器只要负责转发相应的http响应体就能够了。springboot
- HTTPS代理服务器
https请求通过代理服务器,会发送一个CONNECT报文,用于和代理服务器创建隧道,若是代理服务器返回HTTP 200,则创建成功,后续代理服务器只要负责转发数据就行,实际上SSL/TLS握手仍是发生在客户端和真实服务器。分布式
ProxyServlet
把指定请求代理到服务器8088端口 Spring boot 的主 Servlet 为 SpringMVC的DispatcherServlet,其默认的url-pattern为“/”,若是咱们想要为某个url添加不一样的调用(其余服务器接口),则须要建立新的代理servlet,会使用到
ServletRegistrationBean
,建立一个新的ProxyServlet
来处理不一样端口的监听和数据的发送,并将它注册到springboot管理的servletContext
中(设置指定服务器和端口,请求转发的接口)url
<dependency>
<groupId>org.mitre.dsmiley.httpproxy</groupId>
<artifactId>smiley-http-proxy-servlet</artifactId>
<version>1.7</version>
</dependency>复制代码
### 配置代理
#请求resource时代理转发到端口8088项目中
proxy.test.servlet_url_one= /resource/*
proxy.test.target_url_one= https://localhost:8088复制代码
@Component
@Data
public class ProxyFilterServlet {
@Value("${proxy.test.target_url_one}")
private String targetUrl;
@Value("${proxy.test.servlet_url_one}")
private String servletUrl;
}
复制代码
@Configuration
public class ProxyServletConfig {
@Autowired
private ProxyFilterServlet proxyFilterServlet;
//多个代理servlet能够配置多个bean
@Bean
public ServletRegistrationBean servletRegistrationBean(){
ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new ProxyServlet(), proxyFilterServlet.getServletUrl());
//这个setName必需要设置,而且多个的时候,名字须要不同
servletRegistrationBean.setName("go_backend");
servletRegistrationBean.addInitParameter("targetUri", proxyFilterServlet.getTargetUrl());
servletRegistrationBean.addInitParameter(ProxyServlet.P_LOG, "false");
return servletRegistrationBean;
}
}复制代码
经过servlet容器来创建与目标服务器链接,毕竟没有nginx这样的专业代理服务器强spa
把须要请求的外网的请求转到同一服务器内网端口.net
server {
listen 80;
server_name 127.0.0.1;
location / {
proxy_pass http://127.0.0.1:3000;
}
location ~ /api/ {
proxy_pass http://172.30.1.123:8081;
}
}复制代码
参考博文:代理
https://blog.csdn.net/wohaqiyi/article/details/81327512
https://juejin.im/entry/58e8b6f344d904006d43360f