共计 2147 个字符,预计需要花费 6 分钟才能阅读完成。
一次 nginx 实现根据 URL 转发请求的经历
因为这久完成了一个分布式文件系统的内网外穿部署,使用 fastdfs,该应用部署到 8088 端口,它的后台管理系统部署在 8089 端口(同一个内网服务器),该后台管理系统的服务要请求 fastdfs 服务,可以直接请求(同一个服务器的资源),但是我们现在只外穿了后台管理系统(Springboot 项目),不通过公网分配的 IP 只能访问到后台管理系统,要直接访问 fastdfs 服务的接口的话必须连接服务器公网,但是这限制了我们用户的访问(我没办法每次都去你的服务器的地方访问,我想在其他地方也可以访问)
代理服务器:SockerServer 监听某个端口,根据 http 报文连接到指定服务器端口,进行数据请求
- HTTP 代理
http 请求经过代理服务器,代理服务器只要负责转发相应的 http 响应体就可以了。
- HTTPS 代理
https 请求经过代理服务器, 会发送一个 CONNECT 报文,用于和代理服务器建立隧道,如果代理服务器返回 HTTP 200, 则建立成功,后续代理服务器只要负责转发数据就行,实际上 SSL/TLS 握手还是发生在客户端和真实服务器。
ProxyServlet
- 因为该后台项目 8089 端口可以访问服务器 fastdfs 服务,所以我首先想到的是使用 Springboot 的
ProxyServlet
把指定请求代理到服务器 8088 端口
Spring boot 的主 Servlet 为 SpringMVC 的 DispatcherServlet,其默认的 url-pattern 为“/”,如果我们想要为某个 url 添加不同的调用 (其他服务器接口),则需要创建新的代理 servlet,会使用到
ServletRegistrationBean
,创建一个新的ProxyServlet
来处理不同端口的监听和数据的发送,并将它注册到 springboot 管理的servletContext
中(设置指定服务器和端口,请求转发的接口)
依赖
<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;
}
更改 config 添加
@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 这样的专业代理服务器强
nginx—代理转发
- 这个时候我想到了服务器之间添加一层 nginx,来把不同的服务请求转发到不同的端口 api 去处理
把需要请求的外网的请求转到同一服务器内网端口
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/wohaqiy…
https://juejin.im/entry/58e8b…