Dropwizard - 多个端口上的资源

问题描述 投票:8回答:1

我有一个基于Jersey REST服务的Dropwizard(v 0.7.1)。目前我使用一个应用程序连接器端口(8810),我有两个资源(比如“/ path1”,“/ path2”)。

我将能够分别以http:\\ localhost:8810 \ path1和http:\\ localhost:8810 \ path2访问这些资源。我们想要实现的是每个资源都有一个单独的端口。 (例如http:\\ localhost:8810 \ path1和http:\\ localhost:8820 \ path2)。我调整了yaml文件以具有以下配置,当我启动应用程序时,两个端口都可以使用这两个资源,并且不确定如何配置这些资源以使用特定端口,或者甚至可以使用Dropwizard?

server:   
  applicationConnectors:
   - 
     type: http 
     port: 8810
   - 
     type: http 
     port: 8820

感谢有人可以启发。

谢谢

java jersey dropwizard
1个回答
4
投票

您的问题是DefaultServerFactory将所有applicationConntectors添加到同一个Handler,请参阅DefaultServerFactory #build:

@Override
public Server build(Environment environment) {
    printBanner(environment.getName());
    final ThreadPool threadPool = createThreadPool(environment.metrics());
    final Server server = buildServer(environment.lifecycle(), threadPool);

    LOGGER.info("Registering jersey handler with root path prefix: {}", applicationContextPath);
    environment.getApplicationContext().setContextPath(applicationContextPath);
    final Handler applicationHandler = createAppServlet(server,
                                                        environment.jersey(),
                                                        environment.getObjectMapper(),
                                                        environment.getValidator(),
                                                        environment.getApplicationContext(),
                                                        environment.getJerseyServletContainer(),
                                                        environment.metrics());

    LOGGER.info("Registering admin handler with root path prefix: {}", adminContextPath);
    environment.getAdminContext().setContextPath(adminContextPath);
    final Handler adminHandler = createAdminServlet(server,
                                                    environment.getAdminContext(),
                                                    environment.metrics(),
                                                    environment.healthChecks());
    final RoutingHandler routingHandler = buildRoutingHandler(environment.metrics(),
                                                              server,
                                                              applicationHandler,
                                                              adminHandler);
    server.setHandler(addStatsHandler(addRequestLog(server, routingHandler, environment.getName())));
    return server;
}

您需要做的是实现自己的ServerFactory。

您可以扩展DefaultServerFactory并覆盖构建方法,以按照您希望的方式设置连接器。大概你会想要添加一些更多的配置来指示它们在哪里,因为就你的yaml来说,将资源映射到特定的连接器是不可能的。 dropwizard怎么会知道这件事。

为了覆盖dropwizard的行为(添加一个新的ServerFactory),你可以看到我写的关于添加日志的帖子:Dropwizard doesn't log custom loggers to file

它主要涉及实现类并使其可以被dropwizard发现。之后,您需要做的就是将yaml文件更改为指向正确的ServerFactory。

如果您不喜欢这种方法,则可以覆盖配置上的get / set方法以返回您的类。为此,您的类必须扩展DefaultServerFactory,否则yaml映射将不再起作用。但是,无论如何都可以覆盖构建方法。

更新:

更详细地看一下,你会遇到第二个问题:

您的环境只有一个可以使用的平针织环境。您将需要配置第二个球衣环境,因为默认情况下,每个Handler将获得传递给它的相同Jersey配置(唯一存在的配置)。这就是为什么它可用于您的所有http配置。总结如下:

  1. 创建支持多种平针配置的新环境
  2. 创建一个服务器工厂,知道什么样的泽西配置属于哪个Handler并实例化该表单中的处理程序。

我认为这两个步骤是必需的。

在环境方面,您必须创建自己的ServerCommand(即启动dropwizard服务器的命令)。查看EnvironmentCommand#run,您可以看到环境的创建位置。这是唯一可以覆盖默认环境的地方(据我所知),这是你需要做的,以支持多个球衣配置。

老实说,看着这个,我不相信这就是那些傻瓜家伙的想法。

© www.soinside.com 2019 - 2024. All rights reserved.