com.azure.cosmos.implementation.CosmosSchedulers Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-cosmos Show documentation
Show all versions of azure-cosmos Show documentation
This Package contains Microsoft Azure Cosmos SDK (with Reactive Extension Reactor support) for Azure Cosmos DB SQL API
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.cosmos.implementation;
import reactor.core.scheduler.Scheduler;
import reactor.core.scheduler.Schedulers;
public class CosmosSchedulers {
private final static String COSMOS_PARALLEL_THREAD_NAME = "cosmos-parallel";
private final static String TRANSPORT_RESPONSE_BOUNDED_ELASTIC_THREAD_NAME = "transport-response-bounded-elastic";
private final static int TTL_FOR_SCHEDULER_WORKER_IN_SECONDS = 60; // same as BoundedElasticScheduler.DEFAULT_TTL_SECONDS
// Using a custom parallel scheduler to be able to schedule retries etc.
// without being vulnerable to scenarios where applications abuse the
// Parallel scheduler and cause thread starvation on Reactor Core parallel scheduler
public final static Scheduler COSMOS_PARALLEL = Schedulers.newParallel(
COSMOS_PARALLEL_THREAD_NAME,
Schedulers.DEFAULT_POOL_SIZE,
true);
// Custom bounded elastic scheduler to switch off IO thread to process response.
public final static Scheduler TRANSPORT_RESPONSE_BOUNDED_ELASTIC = Schedulers.newBoundedElastic(
Schedulers.DEFAULT_BOUNDED_ELASTIC_SIZE,
Schedulers.DEFAULT_BOUNDED_ELASTIC_QUEUESIZE,
TRANSPORT_RESPONSE_BOUNDED_ELASTIC_THREAD_NAME,
TTL_FOR_SCHEDULER_WORKER_IN_SECONDS,
true
);
}