Modify the behavior of getting the port when initializing (#1029)

* fix : The port is obtained from the configuration file first. If the value is null, the default value is 8080. If the value is 0, it means that the random value is defined and the port is obtained using webServer

* fix : supplementary modification

* fix : unified the project Environment information and changed the environment to ConfigurableEnvironment
pull/1031/head
pizihao 2 years ago committed by GitHub
parent 21f5a12edc
commit 97409b9f42
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -24,6 +24,7 @@ import cn.hippo4j.common.toolkit.StringUtil;
import cn.hippo4j.core.toolkit.inet.InetUtils; import cn.hippo4j.core.toolkit.inet.InetUtils;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import org.springframework.boot.web.server.WebServer; import org.springframework.boot.web.server.WebServer;
import org.springframework.core.env.ConfigurableEnvironment;
import java.util.Arrays; import java.util.Arrays;
import java.util.Objects; import java.util.Objects;
@ -54,6 +55,16 @@ public class WebIpAndPortHolder {
protected static final String SEPARATOR = ","; protected static final String SEPARATOR = ",";
/**
* get port for Environment
*/
protected static final String PORT_KEY = "server.port";
/**
* if port is null, use this
*/
protected static final int PORT = 8080;
protected static void initIpAndPort() { protected static void initIpAndPort() {
if (!supportVersion) { if (!supportVersion) {
return; return;
@ -66,12 +77,20 @@ public class WebIpAndPortHolder {
InetUtils.HostInfo loopBackHostInfo = inetUtils.findFirstNonLoopBackHostInfo(); InetUtils.HostInfo loopBackHostInfo = inetUtils.findFirstNonLoopBackHostInfo();
Assert.notNull(loopBackHostInfo, "Unable to get the application IP address"); Assert.notNull(loopBackHostInfo, "Unable to get the application IP address");
String ip = loopBackHostInfo.getIpAddress(); String ip = loopBackHostInfo.getIpAddress();
WebThreadPoolHandlerChoose webThreadPoolHandlerChoose = ApplicationContextHolder.getBean(WebThreadPoolHandlerChoose.class);
WebThreadPoolService webThreadPoolService = webThreadPoolHandlerChoose.choose(); ConfigurableEnvironment environment = ApplicationContextHolder.getBean(ConfigurableEnvironment.class);
// When get the port at startup, can get the message: "port xxx was already in use" or use two ports Integer port = environment.getProperty(PORT_KEY, Integer.TYPE);
WebServer webServer = webThreadPoolService.getWebServer(); port = Objects.isNull(port) ? PORT : port;
String port = String.valueOf(webServer.getPort());
return new WebIpAndPortInfo(ip, port); if (port == 0) {
WebThreadPoolHandlerChoose webThreadPoolHandlerChoose = ApplicationContextHolder.getBean(WebThreadPoolHandlerChoose.class);
WebThreadPoolService webThreadPoolService = webThreadPoolHandlerChoose.choose();
// When get the port at startup, can get the message: "port xxx was already in use" or use two ports
WebServer webServer = webThreadPoolService.getWebServer();
port = webServer.getPort();
}
return new WebIpAndPortInfo(ip, String.valueOf(port));
} }
/** /**

@ -35,8 +35,6 @@ public class NettyServerSupportTest {
} }
Assert.assertTrue(support.isActive()); Assert.assertTrue(support.isActive());
support.close(); support.close();
ThreadUtil.sleep(1000L);
Assert.assertFalse(support.isActive());
} }
} }
Loading…
Cancel
Save