文章目录
一、简要概述
我们在开发Springboot Web工程中,一般通过在application.yml配置文件中使用server.port来指定唯一的http启动端口,那么Springboot Web工程支不支持指定多个HTTP端口启动呢,答案是肯定的!
二、Tomcat应用服务器
默认情况下,boot内置应用服务器为spring-boot-starter-tomcat
1,定义启动端口
为了跟系统配置server.port做区分,我们定义路径为server.http.ports,典型配置如下:
yaml
server:
port: 8082
servlet:
context-path: /
session:
timeout: 1800
http:
ports: 80,8085
2,编写TomcatHttp配置类
java
import java.util.Arrays;
import java.util.stream.Collectors;
import org.apache.catalina.connector.Connector;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
import org.springframework.boot.web.servlet.server.ServletWebServerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class TomcatHttpConfig
{
@Value("${server.http.ports:}")
int[] httpPorts;
/**
* 添加额外的HTTP连接器
*/
@Bean
public ServletWebServerFactory servletContainer()
{
TomcatServletWebServerFactory factory = new TomcatServletWebServerFactory();
factory.addAdditionalTomcatConnectors(httpConnectors());
return factory;
}
private Connector[] httpConnectors()
{
return Arrays.stream(httpPorts).mapToObj(p -> {
Connector connector = new Connector("HTTP/1.1");
connector.setScheme("http");
connector.setPort(p);
connector.setSecure(false);
connector.setRedirectPort(443); // 关键配置:当请求需要安全连接时,重定向到 HTTPS 端口
return connector;
}).collect(Collectors.toList()).toArray(new Connector[0]);
}
}
3,运行结果
查看日志,可以看到我们成功在 8082 (http) 80 (http) 8085 (http)启动了应用。
bash
_ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
[32m :: Spring Boot :: [39m [2m (v2.2.4.RELEASE)[0;39m
[2m2026-04-08 17:40:51.014[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.f.HttpBootApplication [0;39m [2m:[0;39m The following profiles are active: dev
[2m2026-04-08 17:40:51.958[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.c.c.s.GenericScope [0;39m [2m:[0;39m BeanFactory id=baa29068-0ad7-369f-9820-35c38d0277df
[2m2026-04-08 17:40:52.942[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.b.w.e.t.TomcatWebServer [0;39m [2m:[0;39m Tomcat initialized with port(s): 8082 (http) 80 (http) 8085 (http)
[2m2026-04-08 17:40:52.954[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.h.Http11NioProtocol [0;39m [2m:[0;39m Initializing ProtocolHandler ["http-nio-8082"]
[2m2026-04-08 17:40:52.955[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.h.Http11NioProtocol [0;39m [2m:[0;39m Initializing ProtocolHandler ["http-nio-80"]
[2m2026-04-08 17:40:52.966[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.h.Http11NioProtocol [0;39m [2m:[0;39m Initializing ProtocolHandler ["http-nio-8085"]
[2m2026-04-08 17:40:52.967[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.c.StandardService [0;39m [2m:[0;39m Starting service [Tomcat]
[2m2026-04-08 17:40:52.968[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.c.StandardEngine [0;39m [2m:[0;39m Starting Servlet engine: [Apache Tomcat/9.0.30]
[2m2026-04-08 17:40:53.072[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.c.C.[.[.[/] [0;39m [2m:[0;39m Initializing Spring embedded WebApplicationContext
[2m2026-04-08 17:40:53.072[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.w.c.ContextLoader [0;39m [2m:[0;39m Root WebApplicationContext: initialization completed in 2041 ms
[2m2026-04-08 17:40:53.150[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.f.c.u.SpringContextUtils [0;39m [2m:[0;39m ###### execute setApplicationContext ######
[2m2026-04-08 17:40:53.515[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.b.d.a.OptionalLiveReloadServer [0;39m [2m:[0;39m LiveReload server is running on port 35729
[2m2026-04-08 17:40:53.786[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.f.w.c.SimpleFileController [0;39m [2m:[0;39m #### isTomcat: false
[2m2026-04-08 17:40:53.788[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.f.w.c.SimpleFileController [0;39m [2m:[0;39m #### isJetty: false
[2m2026-04-08 17:40:54.036[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mpertySourcedRequestMappingHandlerMapping[0;39m [2m:[0;39m Mapped URL path [/v2/api-docs] onto method [springfox.documentation.swagger2.web.Swagger2ControllerWebMvc#getDocumentation(String, HttpServletRequest)]
[2m2026-04-08 17:40:54.077[0;39m [33m WARN[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.c.n.a.ArchaiusAutoConfiguration [0;39m [2m:[0;39m No spring.application.name found, defaulting to 'application'
[2m2026-04-08 17:40:54.084[0;39m [33m WARN[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.n.c.s.URLConfigurationSource [0;39m [2m:[0;39m No URLs will be polled as dynamic configuration sources.
[2m2026-04-08 17:40:54.084[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.n.c.s.URLConfigurationSource [0;39m [2m:[0;39m To enable URLs as dynamic configuration sources, define System property archaius.configurationSource.additionalUrls or make config.properties available on classpath.
[2m2026-04-08 17:40:54.090[0;39m [33m WARN[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.n.c.s.URLConfigurationSource [0;39m [2m:[0;39m No URLs will be polled as dynamic configuration sources.
[2m2026-04-08 17:40:54.091[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.n.c.s.URLConfigurationSource [0;39m [2m:[0;39m To enable URLs as dynamic configuration sources, define System property archaius.configurationSource.additionalUrls or make config.properties available on classpath.
[2m2026-04-08 17:40:54.282[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.s.c.ThreadPoolTaskExecutor [0;39m [2m:[0;39m Initializing ExecutorService 'applicationTaskExecutor'
[2m2026-04-08 17:40:54.327[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.b.a.w.s.WelcomePageHandlerMapping [0;39m [2m:[0;39m Adding welcome page: class path resource [static/index.html]
[2m2026-04-08 17:40:54.447[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.s.c.ThreadPoolTaskScheduler [0;39m [2m:[0;39m Initializing ExecutorService 'taskScheduler'
[2m2026-04-08 17:40:54.740[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36md.s.w.p.DocumentationPluginsBootstrapper[0;39m [2m:[0;39m Documentation plugins bootstrapped
[2m2026-04-08 17:40:54.743[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36md.s.w.p.DocumentationPluginsBootstrapper[0;39m [2m:[0;39m Found 1 custom documentation plugin(s)
[2m2026-04-08 17:40:54.785[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36ms.d.s.w.s.ApiListingReferenceScanner [0;39m [2m:[0;39m Scanning for api listing references
[2m2026-04-08 17:40:54.947[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36m.d.s.w.r.o.CachingOperationNameGenerator[0;39m [2m:[0;39m Generating unique operation named: uploadUsingPOST_1
[2m2026-04-08 17:40:54.960[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36m.d.s.w.r.o.CachingOperationNameGenerator[0;39m [2m:[0;39m Generating unique operation named: backDownUploadUsingGET_1
[2m2026-04-08 17:40:54.994[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.h.Http11NioProtocol [0;39m [2m:[0;39m Starting ProtocolHandler ["http-nio-8082"]
[2m2026-04-08 17:40:55.002[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.h.Http11NioProtocol [0;39m [2m:[0;39m Starting ProtocolHandler ["http-nio-80"]
[2m2026-04-08 17:40:55.004[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.a.c.h.Http11NioProtocol [0;39m [2m:[0;39m Starting ProtocolHandler ["http-nio-8085"]
[2m2026-04-08 17:40:55.014[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.b.w.e.t.TomcatWebServer [0;39m [2m:[0;39m Tomcat started on port(s): 8082 (http) 80 (http) 8085 (http) with context path ''
[2m2026-04-08 17:40:55.102[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.f.HttpBootApplication [0;39m [2m:[0;39m Started HttpBootApplication in 5.126 seconds (JVM running for 6.249)
[2m2026-04-08 17:40:55.353[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[nio-8082-exec-2][0;39m [36mo.a.c.c.C.[.[.[/] [0;39m [2m:[0;39m Initializing Spring DispatcherServlet 'dispatcherServlet'
[2m2026-04-08 17:40:55.354[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[nio-8082-exec-2][0;39m [36mo.s.w.s.DispatcherServlet [0;39m [2m:[0;39m Initializing Servlet 'dispatcherServlet'
[2m2026-04-08 17:40:55.369[0;39m [32m INFO[0;39m [35m5024[0;39m [2m---[0;39m [2m[nio-8082-exec-2][0;39m [36mo.s.w.s.DispatcherServlet [0;39m [2m:[0;39m Completed initialization in 15 ms
三、Jetty应用服务器
1,修改工程依赖文件
pom.xml
xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
<!-- 异步日志,需要加入disruptor依赖 -->
<dependency>
<groupId>com.lmax</groupId>
<artifactId>disruptor</artifactId>
<version>3.4.2</version>
</dependency>
<!-- Provided -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
2,定义启动端口
yaml
server:
port: 443
ssl:
key-store: classpath:xxxxxxx.pfx
key-store-password: xxxxxxx
keyStoreType: PKCS12
servlet:
context-path: /
session:
timeout: 1800
http:
ports: 80,8081
3,编写JettyHttp配置类
java
import java.util.Arrays;
import org.eclipse.jetty.server.HttpConfiguration;
import org.eclipse.jetty.server.HttpConnectionFactory;
import org.eclipse.jetty.server.ServerConnector;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.embedded.jetty.JettyServletWebServerFactory;
import org.springframework.boot.web.servlet.server.ServletWebServerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class JettyHttpConfig
{
@Value("${server.http.ports:}")
int[] httpPorts;
/**
* 添加额外的HTTP连接器
*/
@Bean
public ServletWebServerFactory servletContainer()
{
HttpConfiguration httpConfig = new HttpConfiguration();
httpConfig.setSecureScheme("https");
httpConfig.setSecurePort(443);
// 添加多个额外的HTTP连接器
JettyServletWebServerFactory factory = new JettyServletWebServerFactory();
Arrays.stream(httpPorts).forEach(port -> {
factory.addServerCustomizers(server -> {
ServerConnector httpConnector = new ServerConnector(server, new HttpConnectionFactory(httpConfig));
httpConnector.setPort(port);
server.addConnector(httpConnector);
});
});
return factory;
}
}
4,运行结果
查看日志,可以看到我们成功在 port(s) 443 (ssl, http/1.1), 80 (http/1.1), 8081 (http/1.1)启动了应用。
bash
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
[32m :: Spring Boot :: [39m [2m (v2.2.4.RELEASE)[0;39m
[2m2026-04-08 17:45:45.859[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.f.HttpsApplication [0;39m [2m:[0;39m Starting HttpsApplication on 10_0_16_11 with PID 6000 (C:\gitee\effict-side\springboot-ssl\target\classes started by Administrator in C:\gitee\effict-side\springboot-ssl)
[2m2026-04-08 17:45:45.871[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mc.f.HttpsApplication [0;39m [2m:[0;39m The following profiles are active: prod
[2m2026-04-08 17:45:45.921[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36m.e.DevToolsPropertyDefaultsPostProcessor[0;39m [2m:[0;39m Devtools property defaults active! Set 'spring.devtools.add-properties' to 'false' to disable
[2m2026-04-08 17:45:45.922[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36m.e.DevToolsPropertyDefaultsPostProcessor[0;39m [2m:[0;39m For additional web related logging consider setting the 'logging.level.web' property to 'DEBUG'
[2m2026-04-08 17:45:46.623[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.u.log [0;39m [2m:[0;39m Logging initialized @2312ms to org.eclipse.jetty.util.log.Slf4jLog
[2m2026-04-08 17:45:46.856[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.b.w.e.j.JettyServletWebServerFactory[0;39m [2m:[0;39m Server initialized with port: 443
[2m2026-04-08 17:45:46.872[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.Server [0;39m [2m:[0;39m jetty-9.4.25.v20191220; built: 2019-12-20T17:00:00.294Z; git: a9729c7e7f33a459d2616a8f9e9ba8a90f432e95; jvm 1.8.0_202-b08
[2m2026-04-08 17:45:46.900[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.h.C.application [0;39m [2m:[0;39m Initializing Spring embedded WebApplicationContext
[2m2026-04-08 17:45:46.901[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.w.c.ContextLoader [0;39m [2m:[0;39m Root WebApplicationContext: initialization completed in 979 ms
[2m2026-04-08 17:45:47.147[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.session [0;39m [2m:[0;39m DefaultSessionIdManager workerName=node0
[2m2026-04-08 17:45:47.147[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.session [0;39m [2m:[0;39m No SessionScavenger set, using defaults
[2m2026-04-08 17:45:47.148[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.session [0;39m [2m:[0;39m node0 Scavenging every 660000ms
[2m2026-04-08 17:45:47.159[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.h.ContextHandler [0;39m [2m:[0;39m Started o.s.b.w.e.j.JettyEmbeddedWebAppContext@7f09c304{application,/,[file:///C:/Users/Administrator/AppData/Local/Temp/2/jetty-docbase.7882543093635305757.443/],AVAILABLE}
[2m2026-04-08 17:45:47.159[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.Server [0;39m [2m:[0;39m Started @2848ms
[2m2026-04-08 17:45:47.251[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.s.c.ThreadPoolTaskExecutor [0;39m [2m:[0;39m Initializing ExecutorService 'applicationTaskExecutor'
[2m2026-04-08 17:45:47.314[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.b.a.w.s.WelcomePageHandlerMapping [0;39m [2m:[0;39m Adding welcome page: class path resource [static/index.html]
[2m2026-04-08 17:45:47.405[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.b.d.a.OptionalLiveReloadServer [0;39m [2m:[0;39m LiveReload server is running on port 35729
[2m2026-04-08 17:45:47.431[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.h.C.application [0;39m [2m:[0;39m Initializing Spring DispatcherServlet 'dispatcherServlet'
[2m2026-04-08 17:45:47.431[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.w.s.DispatcherServlet [0;39m [2m:[0;39m Initializing Servlet 'dispatcherServlet'
[2m2026-04-08 17:45:47.436[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.w.s.DispatcherServlet [0;39m [2m:[0;39m Completed initialization in 4 ms
[2m2026-04-08 17:45:47.621[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.u.s.SslContextFactory [0;39m [2m:[0;39m x509=X509@1b40392c(00fly.online,h=[00fly.online, www.00fly.online],w=[]) for Server@5eee0143[provider=null,keyStore=file:///C:/gitee/effict-side/springboot-ssl/target/classes/data/ssl/00fly.online.pfx,trustStore=null]
[2m2026-04-08 17:45:47.671[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.AbstractConnector [0;39m [2m:[0;39m Started ServerConnector@31a907ff{SSL,[ssl, http/1.1]}{0.0.0.0:443}
[2m2026-04-08 17:45:47.673[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.AbstractConnector [0;39m [2m:[0;39m Started ServerConnector@45a4bdf2{HTTP/1.1,[http/1.1]}{0.0.0.0:80}
[2m2026-04-08 17:45:47.675[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.e.j.s.AbstractConnector [0;39m [2m:[0;39m Started ServerConnector@c2ae8e{HTTP/1.1,[http/1.1]}{0.0.0.0:8081}
[2m2026-04-08 17:45:47.676[0;39m [32m INFO[0;39m [35m6000[0;39m [2m---[0;39m [2m[ restartedMain][0;39m [36mo.s.b.w.e.j.JettyWebServer [0;39m [2m:[0;39m Jetty started on port(s) 443 (ssl, http/1.1), 80 (http/1.1), 8081 (http/1.1) with context path '/'
四、源码放送
http://118.178.86.130:8081/git/down?name=springboot-ssl
有任何问题和建议,都可以向我提问讨论,大家一起进步,谢谢!
-over-