Files
scylladb/dht/auto_refreshing_sharder.hh
Avi Kivity 0ae22a09d4 LICENSE: Update to version 1.1
Updated terms of non-commercial use (must be a never-customer).
2026-04-12 19:46:33 +03:00

54 lines
1.9 KiB
C++

/*
* Copyright (C) 2023-present ScyllaDB
*/
/*
* SPDX-License-Identifier: LicenseRef-ScyllaDB-Source-Available-1.1
*/
#pragma once
#include "dht/token-sharding.hh"
#include "locator/abstract_replication_strategy.hh"
#include <seastar/core/abort_source.hh>
#include <seastar/core/shared_ptr.hh>
namespace replica {
class table;
}
namespace dht {
/// A sharder which uses table's most up to date effective_replication_map in each invocation.
/// As a result, the time during which a single token metadata version is kept is reduced.
/// The purpose of this class is having a sharder which can be passed to long-running processes
/// which do not need a single view on replication for the whole duration of the process,
/// and do not need to block topology change barriers.
///
/// No guarantees are made about how long token metadata version is kept alive.
/// It may be released before the next call.
class auto_refreshing_sharder : public dht::sharder {
lw_shared_ptr<replica::table> _table;
locator::effective_replication_map_ptr _erm;
const dht::sharder* _sharder;
optimized_optional<seastar::abort_source::subscription> _callback;
std::optional<write_replica_set_selector> _sel;
private:
void refresh();
public:
auto_refreshing_sharder(lw_shared_ptr<replica::table> table, std::optional<write_replica_set_selector> sel = std::nullopt);
virtual ~auto_refreshing_sharder();
virtual std::optional<unsigned> try_get_shard_for_reads(const token& t) const override;
virtual dht::shard_replica_set shard_for_writes(const token& t, std::optional<write_replica_set_selector> sel) const override;
virtual std::optional<dht::shard_and_token> next_shard_for_reads(const dht::token& t) const override;
virtual dht::token token_for_next_shard_for_reads(const dht::token& t, shard_id shard, unsigned spans = 1) const override;
};
} // namespace dht