Spring Boot Reactor Netty配置 | Baeldung


在本教程中,我们将在Spring Boot应用程序中查看Reactor Netty服务器的不同配置选项。最后,我们将展示一个展示不同配置方法的应用程序。

什么是Reactor Netty?
在开始之前,让我们看一下Reactor Netty是什么以及它与Spring Boot的关系。
Reactor Netty是一个异步事件驱动的网络应用程序框架。它提供非阻塞和背压就绪的TCP,HTTP和UDP客户端和服务器。顾名思义,它基于Netty框架。
现在,让我们看看Spring和Spring Boot的位置。
Spring WebFlux是Spring框架的一部分,为Web应用程序提供反应式编程支持。如果我们在Spring Boot应用程序中使用WebFlux,Spring Boot会 自动将 Reactor Netty 配置为默认服务器。除此之外,我们可以明确地将Reactor Netty添加到我们的项目中,Spring Boot应该再次自动配置它。
现在,我们将构建一个应用程序来了解如何自定义我们自动配置的Reactor Netty服务器。之后,我们将介绍一些常见的配置方案。

首先,我们将添加所需的Maven依赖项。
要使用Reactor Netty服务器,我们将在我们的pom文件中添加spring-boot-starter-webflux作为依赖项:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-webflux</artifactId>
    <version>2.1.3.RELEASE</version>
</dependency>

我们可以通过属性文件配置Netty服务器。Spring Boot公开了应用程序属性文件中的一些常见服务器配置:让我们在application.properties中定义服务器端口:
server.port=8088

除了服务器端口,Spring Boot还有许多其他可用的服务器配置选项。 以服务器  前缀开头的属性 允许我们覆盖默认服务器配置。我们可以在EMBEDDED SERVER CONFIGURATION部分的Spring文档中轻松查找这些属性。

现在,让我们看一下如何通过代码配置嵌入式Netty服务器。为此,Spring Boot为我们提供了WebServerFactoryCustomizer和NettyServerCustomizer类。
让我们使用这些类来配置Netty端口,就像我们之前使用属性文件一样:

@Component
public class NettyWebServerFactoryPortCustomizer 
  implements WebServerFactoryCustomizer<NettyReactiveWebServerFactory> {
 
    @Override
    public void customize(NettyReactiveWebServerFactory serverFactory) {
        serverFactory.setPort(8088);
    }
}

Spring Boot将在启动期间选择我们的工厂自定义程序组件,并将配置服务器端口。
或者,我们可以实现NettyServerCustomizer:

private static class PortCustomizer implements NettyServerCustomizer {
    private final int port;
 
    private PortCustomizer(int port) {
        this.port = port;
    }
    @Override
    public HttpServer apply(HttpServer httpServer) {
        return httpServer.port(port);
    }
}

并将其添加到服务器工厂:

serverFactory.addServerCustomizers(new ProtocolCustomizer(8088));

在配置嵌入式Reactor Netty服务器时,这两种方法为我们提供了很大的灵活性。
此外,我们还可以从Netty框架访问ServerBootstrap类并在那里进行自定义:

private static class EventLoopNettyCustomizer implements NettyServerCustomizer {
 
    @Override
    public HttpServer apply(HttpServer httpServer) {
        EventLoopGroup parentGroup = new NioEventLoopGroup();
        EventLoopGroup childGroup = new NioEventLoopGroup();
        return httpServer.tcpConfiguration(tcpServer -> tcpServer
          .bootstrap(serverBootstrap -> serverBootstrap
            .group(parentGroup, childGroup)
            .channel(NioServerSocketChannel.class)));
    }
}

但是,对于这种情况有一个警告。由于Spring Boot自动配置Netty服务器,我们可能需要通过显式定义NettyReactiveWebServerFactory bean 来跳过自动配置。
为此,我们应该在配置类中定义我们的bean并在那里添加我们的定制器:

@Bean
public NettyReactiveWebServerFactory nettyReactiveWebServerFactory() {
    NettyReactiveWebServerFactory webServerFactory = new NettyReactiveWebServerFactory();
    webServerFactory.addServerCustomizers(new EventLoopNettyCustomizer());
    return webServerFactory;
}

接下来,我们将继续介绍一些常见的Netty配置方案。

SSL配置
我们来看看如何配置SSL。
我们将使用SslServerCustomizer 类,它是NettyServerCustomizer的另一个实现:

@Component
public class NettyWebServerFactorySslCustomizer 
  implements WebServerFactoryCustomizer<NettyReactiveWebServerFactory> {
 
    @Override
    public void customize(NettyReactiveWebServerFactory serverFactory) {
        Ssl ssl = new Ssl();
        ssl.setEnabled(true);
        ssl.setKeyStore("classpath:sample.jks");
        ssl.setKeyAlias(
"alias");
        ssl.setKeyPassword(
"password");
        ssl.setKeyStorePassword(
"secret");
        Http2 http2 = new Http2();
        http2.setEnabled(false);
        serverFactory.addServerCustomizers(new SslServerCustomizer(ssl, http2, null));
        serverFactory.setPort(8443);
    }
}

这里我们定义了与密钥库相关的属性,禁用了HTTP / 2,并将端口设置为8443。

访问日志配置
现在,我们将了解如何使用Logback配置访问日志记录。
Spring Boot允许我们在Tomcat,Jetty和Undertow的应用程序属性文件中配置访问日志记录。但是,Netty目前还没有这种支持。
要启用Netty访问日志记录,我们应该 在运行应用程序时设置-Dreactor.netty.http.server.accessLogEnabled = true:

mvn spring-boot:run -Dreactor.netty.http.server.accessLogEnabled=true

结论
在本文中,我们已经介绍了如何在Spring Boot应用程序中配置Reactor Netty服务器。
首先,我们使用了一般的Spring Boot属性配置功能。然后,我们探讨了如何以细粒度的方式以编程方式配置Netty。
最后,本文的源代码可以在Github上找到