前言
因為這久完成了一個分布式文件系統的內網外穿部署,使用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://www.jb51.net/article/174382.htm
https://www.jb51.net/article/174383.htm
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。