編集:この回答はまだ正しいですが、より簡単な解決策については受け入れられた回答を参照してください。
EmbeddedTomcatConfiguration.java
package ...
import java.util.ArrayList;
import java.util.List;
import org.apache.catalina.connector.Connector;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.embedded.EmbeddedServletContainerFactory;
import org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class EmbeddedTomcatConfiguration {
@Value("${server.additionalPorts}")
private String additionalPorts;
@Bean
public EmbeddedServletContainerFactory servletContainer() {
TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory();
Connector[] additionalConnectors = this.additionalConnector();
if (additionalConnectors != null && additionalConnectors.length > 0) {
tomcat.addAdditionalTomcatConnectors(additionalConnectors);
}
return tomcat;
}
private Connector[] additionalConnector() {
if (StringUtils.isBlank(this.additionalPorts)) {
return null;
}
String[] ports = this.additionalPorts.split(",");
List<Connector> result = new ArrayList<>();
for (String port : ports) {
Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
connector.setScheme("http");
connector.setPort(Integer.valueOf(port));
result.add(connector);
}
return result.toArray(new Connector[] {});
}
}
アプリケーション.yml
server:
port: ${appPort:8800}
additionalPorts: 8880,8881
アプリケーション.java
@SpringBootApplication
@ComponentScan(...)
@Import(EmbeddedTomcatConfiguration.class)
public Application {
public static void main(String[] args) {
SpringApplication.run(Application .class, args);
}
}
特定のポートからの javamelody へのアクセスを制限するための私の提案は、javamelody フィルターを拡張し、特定のポートからのものである場合はリクエストをチェーンすることです。それ以外の場合は 404 を送り返します。
ログから:
INFO TomcatEmbeddedServletContainer:185 - Tomcat started on port(s): 8800 (http) 8880 (http) 8881 (http)
ところで、このアプローチは、これらのポートで他のエンドポイントを公開します。これを解決し、javamelody フィルター (/monitoring) を特定のポートに制限するには、これらのフィルターの順序が重要であることを念頭に置いて、許可されたポートから要求されているパス (サーブレットとフィルター パス) を検証するフィルターを作成する必要があります。
この回答と、この質問に回答したときにすでに入手していた部分的なソース コードに基づいて、このトピックに関するブログ投稿をhttp://tech.asimio.net/2016/12/15/Configuring-Tomcat-toで公開しました。 -Listen-on-Multiple-ports-using-Spring-Boot.html