{% hint style="info" %} Design document
Test Results and Performance {% endhint %}
Adaptive Server Selection is a new routing capability for Pinot Brokers where incoming queries are routed to the best available server instead of following the default round robin approach while choosing servers. With this feature, Brokers will be sensitive to changes on the Servers like GC issues, slowness, network slowness, etc. The broker will thus adaptively route more queries to faster servers and lesser queries to slower servers
There are two main components:
- Stats Collection
- Routing using Adaptive Server Selection
Each broker maintains stats individually for all servers. These stats are collected at the broker during query processing when the query is routed to the servers and after the response is received from the servers. These stats are maintained in-memory. Some of the stats collected at broker per server are as follows:
- Number of in-progress / in-flight queries
- EWMA (Exponential Weighted Moving Average) for latencies seen by queries
- EWMA (Exponential Weighted Moving Average) for number of ongoing queries at any time
When the broker receives a query, it will use the above stats to pick the best available server. This enables the broker to automatically reduces the number of queries it sends to slow servers and increase the number of queries it sends to faster servers. We currently support the following strategies:
- NO_OP : Uses the default RoundRobin approach. In other words, this will give existing behavior where stats are not used by broker when picking the servers to route the query to.
- NUM_INFLIGHT_REQ : Uses the number of in-flight requests stat to determine the best server
- LATENCY : Uses the EWMA latency stat to determine the best server
- HYBRID : Uses a combination of in-flight requests and latency to determine the best server
The above strategies works in tandem with the following available Routing mechanisms today:
- Balanced Routing
- ReplicaGroup Routing
So, a table can be configured to use Balanced or Replica group segment assignment + routing and can still leverage the adaptive server selection feature.
The configuration for enabling/disabling this feature and the knobs for performance tuning are present at the Broker instance level. The feature is currently turned off by default.
- To enable Stats Collection, set
pinot.broker.adaptive.server.selector.enable.stats.collection = true
. Note that setting this property alone will only enable stats collection and not perform Adaptive Routing - To enable an Adaptive Routing Strategy, use one of the following configs. The
HYBRID
strategy works well for most use cases. Unless you are an advanced user, we recommend using theHYBRID
strategy.pinot.broker.adaptive.server.selector.type=HYBRID
pinot.broker.adaptive.server.selector.type=NUM_INFLIGHT_REQ
pinot.broker.adaptive.server.selector.type=LATENCY
The following configs are already set to default values that work well for most usecases. For advanced users, the following knobs are available to tune Adaptive Routing Strategies
{% hint style="info" %}
Prefix all the below properties with pinot.broker.adaptive.server.selector.
{% endhint %}
Property | Description | Default Value |
---|---|---|
ewma.alpha | Alpha value for Exponential Moving Average. A higher value would provide more weightage to incoming values and lower weightage to older values | 0.666 |
autodecay.window.ms | If the EWMA value has not been updated for a while, the duration after which the value should be decayed | 10000 |
avg.initialization.val | Initial value for EWMA average | 1.0 |
stats.manager.threadpool.size | Number of threads reserved to process Adaptive Server Selection Stats. | 2 |