abhishekrb19 commented on code in PR #19537:
URL: https://github.com/apache/druid/pull/19537#discussion_r3471503533
##########
server/src/main/java/org/apache/druid/client/selector/ServerSelector.java:
##########
@@ -190,16 +191,123 @@ public List<DruidServerMetadata>
getAllServers(CloneQueryMode cloneQueryMode)
}
@Nullable
- public <T> QueryableDruidServer pick(@Nullable Query<T> query,
CloneQueryMode cloneQueryMode)
+ public <T> QueryableDruidServer pick(@Nullable final Query<T> query, final
CloneQueryMode cloneQueryMode)
+ {
+ return pick(query, cloneQueryMode, getQueryableHistoricalTiers(query));
+ }
+
+ @Nullable
+ public <T> QueryableDruidServer pick(
+ @Nullable final Query<T> query,
+ final CloneQueryMode cloneQueryMode,
+ @Nullable final Set<String> queryableHistoricalTiers
+ )
{
synchronized (this) {
- if (!historicalServers.isEmpty()) {
- return historicalTierStrategy.pick(query,
filter.getQueryableServers(historicalServers, cloneQueryMode), segment.get());
+ if (queryableHistoricalTiers != null &&
queryableHistoricalTiers.isEmpty()) {
+ return null;
+ }
+ if (!historicalServers.isEmpty() || queryableHistoricalTiers != null) {
+ final Int2ObjectRBTreeMap<Set<QueryableDruidServer>>
queryableHistoricalServers =
+ getQueryableHistoricalServers(
+ filter.getQueryableServers(historicalServers, cloneQueryMode),
+ queryableHistoricalTiers
+ );
+ return historicalTierStrategy.pick(query, queryableHistoricalServers,
segment.get());
}
return realtimeTierStrategy.pick(query, realtimeServers, segment.get());
}
}
+ public <T> boolean hasQueryableServer(@Nullable final Query<T> query, final
CloneQueryMode cloneQueryMode)
+ {
+ return hasQueryableServer(getQueryableHistoricalTiers(query),
cloneQueryMode);
+ }
+
+ public boolean hasQueryableServer(
+ @Nullable final Set<String> queryableHistoricalTiers,
+ final CloneQueryMode cloneQueryMode
+ )
+ {
+ synchronized (this) {
+ if (queryableHistoricalTiers != null) {
+ return !queryableHistoricalTiers.isEmpty()
+ && !historicalServers.isEmpty()
+ && hasQueryableHistoricalServer(
+ filter.getQueryableServers(historicalServers,
cloneQueryMode),
+ queryableHistoricalTiers
+ );
+ }
+ if (!historicalServers.isEmpty()) {
+ return hasServers(filter.getQueryableServers(historicalServers,
cloneQueryMode));
+ }
+ return hasServers(realtimeServers);
+ }
+ }
+
+ @Nullable
+ private static <T> Set<String> getQueryableHistoricalTiers(@Nullable final
Query<T> query)
+ {
+ if (query == null) {
+ return null;
+ }
+
+ final QueryContext queryContext = query.context();
+ return queryContext == null ? null :
queryContext.getQueryableHistoricalTiers();
+ }
+
+ private Int2ObjectRBTreeMap<Set<QueryableDruidServer>>
getQueryableHistoricalServers(
+ final Int2ObjectRBTreeMap<Set<QueryableDruidServer>> queryableServers,
+ @Nullable final Set<String> queryableHistoricalTiers
+ )
+ {
+ if (queryableHistoricalTiers == null) {
+ return queryableServers;
+ }
+
+ final Int2ObjectRBTreeMap<Set<QueryableDruidServer>> filteredServers =
+ new Int2ObjectRBTreeMap<>(historicalTierStrategy.getComparator());
+ for (final int priority : queryableServers.keySet()) {
+ final Set<QueryableDruidServer> priorityServers = new HashSet<>();
+ for (final QueryableDruidServer server : queryableServers.get(priority))
{
Review Comment:
Since this is a tree map, you could avoid the double lookup by iterating on
the `queryableServers.int2ObjectEntrySet()` once as you go instead of getting
the priority and then looking it up again with it
Would likely require a small restructure here.
##########
server/src/main/java/org/apache/druid/client/CachingClusteredClient.java:
##########
@@ -604,10 +611,15 @@ private SortedMap<DruidServer, List<SegmentDescriptor>>
groupSegmentsByServer(
CloneQueryMode cloneQueryMode
)
{
+ final Set<String> queryableHistoricalTiers =
query.context().getQueryableHistoricalTiers();
Review Comment:
Similar to `cloneQueryMode`, it'll be good to get the historical tiers once
and pass it to both `computeResultLevelCachingEtag()` and `pick()` to avoid
getting the tiers from parsing the context unnecessarily
--
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
To unsubscribe, e-mail: [email protected]
For queries about this service, please contact Infrastructure at:
[email protected]
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]