Files
scylladb/streaming/stream_request.hh
Avi Kivity 844a49ed6e dht: fragment token_range_vector
token_range_vector is a linear vector containing intervals
of tokens. It can grow quite large in certain places
and so cause stalls.

Convert it to utils::chunked_vector, which prevents allocation
stalls.

It is not used in any hot path, as it usually describes
vnodes or similar things.

Fixes #3335.
2025-05-27 14:47:24 +03:00

46 lines
1.4 KiB
C++

/*
*
* Modified by ScyllaDB
* Copyright (C) 2015-present ScyllaDB
*/
/*
* SPDX-License-Identifier: (LicenseRef-ScyllaDB-Source-Available-1.0 and Apache-2.0)
*/
#pragma once
#include <seastar/core/sstring.hh>
#include "interval.hh"
#include "partition_range_compat.hh"
#include <vector>
namespace streaming {
class stream_request {
public:
using token = dht::token;
sstring keyspace;
dht::token_range_vector ranges;
// For compatibility with <= 1.5, we send wrapping ranges (though they will never wrap).
utils::chunked_vector<wrapping_interval<token>> ranges_compat() const {
return ::compat::wrap(ranges);
}
std::vector<sstring> column_families;
stream_request() = default;
stream_request(sstring _keyspace, dht::token_range_vector _ranges, std::vector<sstring> _column_families)
: keyspace(std::move(_keyspace))
, ranges(std::move(_ranges))
, column_families(std::move(_column_families)) {
}
stream_request(sstring _keyspace, utils::chunked_vector<wrapping_interval<token>> _ranges, std::vector<sstring> _column_families)
: stream_request(std::move(_keyspace), ::compat::unwrap(std::move(_ranges)), std::move(_column_families)) {
}
};
} // namespace streaming
template <> struct fmt::formatter<streaming::stream_request> : fmt::formatter<string_view> {
auto format(const streaming::stream_request&, fmt::format_context& ctx) const -> decltype(ctx.out());
};