java - 如何使用 Executor 创建 Jersey 2 客户端

标签 java rest glassfish jersey-2.0 jersey-client

我用下面的代码创建了一个 jersey 2 客户端,

ClientConfig clientConfig = new ClientConfig();
clientConfig.property(ClientProperties.READ_TIMEOUT, 5000);
clientConfig.property(ClientProperties.CONNECT_TIMEOUT, 10000);
Client client =  ClientBuilder.newClient(clientConfig);       

我可以提出请求,一切正常。但是我想控制客户端执行线程的数量。在 jersey 1 中,我们可以有如下相同的实现,

Client client =  Client.create();
client.setConnectTimeout(5000);
client.setReadTimeout(10000);
client.setExecutorService(Executors.newFixedThreadPool(10));

我想复制同样的东西,

client.setExecutorService(Executors.newFixedThreadPool(10))

与 jersey 2 客户端。

经过一番搜索,我找到了 this对于 Jersey 2。但是它是可用的 在最新版本的 Jersey 2 (2.26) 中。我正在使用 2.25.1 Jersey 版本。如何为 2.25.1 版本实现相同的功能?

最佳答案

我只是在挖掘源代码并找到了 ExecutorServiceProvider@ClientAsyncExecutor .如果你实现前者并用后者注释,只要请求是异步就应该使用你的执行器(我注意到在你编辑之前你正在寻找同步) 然后您向客户端注册提供程序。

@ClientAsyncExecutor
static class MyExecutorServiceProvider implements ExecutorServiceProvider {

    @Override
    public ExecutorService getExecutorService() {
        System.out.println("Calling getExecutorService()");
        return Executors.newFixedThreadPool(10);
    }

    @Override
    public void dispose(ExecutorService executorService) {
        executorService.shutdown();
    }
}

Client client = ClientBuilder.newClient()
client.register(new MyExecutorServiceProvider());

Future<Response> res = client.target("test").async().get()

关于java - 如何使用 Executor 创建 Jersey 2 客户端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45769779/

相关文章:

java - 将 join 放在主线程上意外行为

java - 允许一定数量的用户连接到服务器[JAVA]

javascript - Selenium 测试 - 事件似乎没有被触发

java - CharacterData00.class java 中的 digit()

Java 程序适用于大多数但并非所有计算机

java - 从数据库模式生成基于 REST 的服务

java - 如何使用 URL 参数使用 servlet ClientResource?

rest - 无法使用 RestResponse 接收 contentType "application/pdf"

Glassfish war 生命周期问题

java - Java应用服务器线程池配置