Spring Boot,在多个端口上启用压缩

时间:2018-03-15 18:53:03

标签: spring-boot

在我们的春季启动应用程序中,我们需要一个安全且不安全的端口。我已经通过application.properties文件将端口3000配置为安全的:

# Override default port setting
server.port=3000

# Enable SSL
server.ssl.key-store=classpath:keystore.p12
server.ssl.key-store-password=#####
server.ssl.keyStoreType=PKCS12
server.ssl.keyAlias=tomcat

在某些代码中将端口8080设置为非安全:

@Bean
public EmbeddedServletContainerFactory servletContainer() {
    TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory();
    Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
    connector.setScheme("http");
    connector.setPort(8080);
    tomcat.addAdditionalTomcatConnectors(connector);
    return tomcat;
}

现在,我想启用压缩传递,因此在application.properties中我添加了:

# Embedded Server Compression
server.compression.enabled=true
server.compression.mime-types=text/html,text/xml,text/plain,text/css,text/javascript,application/javascript,image/svg+xml,application/json
server.compression.min-response-size=2048

这似乎是服务器范围的设置,但8080端口不提供压缩数据,而3000确实没问题。如果我理解正确,创建8080连接器的bean正在使用主服务器。我尝试了几种设置组合,例如使用旧属性在8080连接器上启用压缩,但无济于事。所以我要求大师帮忙来解决这个问题。

提前谢谢。

1 个答案:

答案 0 :(得分:2)

您可以在协议级别设置压缩,如下所示。

@Bean public EmbeddedServletContainerFactory servletContainer() {

    TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory();

    Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");

    Http11NioProtocol protocol = (Http11NioProtocol) connector.getProtocolHandler();
    protocol.setCompressibleMimeType("text/html,text/xml,text/plain,text/css,text/javascript,application/javascript,image/svg+xml,application/json");
    protocol.setCompression("on");
    protocol.setCompressionMinSize(2048);

    connector.setScheme("http");
    connector.setPort(8080);
    connector.setSecure(false);

    tomcat.addAdditionalTomcatConnectors(connector);
    return tomcat;
}