pub struct HummockStorageReadSnapshot {
raw_epoch: u64,
table_id: TableId,
recent_versions: Arc<ArcSwap<RecentVersions>>,
hummock_version_reader: HummockVersionReader,
read_version_mapping: ReadOnlyReadVersionMapping,
backup_reader: BackupReaderRef,
hummock_meta_client: Arc<dyn HummockMetaClient>,
simple_time_travel_version_cache: Arc<SimpleTimeTravelVersionCache>,
}
Fields§
§raw_epoch: u64
§table_id: TableId
§recent_versions: Arc<ArcSwap<RecentVersions>>
§hummock_version_reader: HummockVersionReader
§read_version_mapping: ReadOnlyReadVersionMapping
§backup_reader: BackupReaderRef
§hummock_meta_client: Arc<dyn HummockMetaClient>
§simple_time_travel_version_cache: Arc<SimpleTimeTravelVersionCache>
Implementations§
Source§impl HummockStorageReadSnapshot
impl HummockStorageReadSnapshot
Sourceasync fn get_inner(
&self,
key: TableKey<Bytes>,
read_options: ReadOptions,
) -> StorageResult<Option<StateStoreKeyedRow>>
async fn get_inner( &self, key: TableKey<Bytes>, read_options: ReadOptions, ) -> StorageResult<Option<StateStoreKeyedRow>>
Gets the value of a specified key
in the table specified in read_options
.
The result is based on a snapshot corresponding to the given epoch
.
if key
has consistent hash virtual node value, then such value is stored in value_meta
If Ok(Some())
is returned, the key is found. If Ok(None)
is returned,
the key is not found. If Err()
is returned, the searching for the key
failed due to other non-EOF errors.
async fn iter_inner( &self, key_range: TableKeyRange, read_options: ReadOptions, ) -> StorageResult<HummockStorageIterator>
async fn rev_iter_inner( &self, key_range: TableKeyRange, read_options: ReadOptions, ) -> StorageResult<HummockStorageRevIterator>
async fn get_time_travel_version( &self, epoch: u64, table_id: TableId, ) -> StorageResult<PinnedVersion>
async fn build_read_version_tuple( &self, epoch: u64, key_range: TableKeyRange, read_options: &ReadOptions, ) -> StorageResult<(TableKeyRange, ReadVersionTuple)>
async fn build_read_version_tuple_from_backup( &self, epoch: u64, table_id: TableId, key_range: TableKeyRange, ) -> StorageResult<(TableKeyRange, ReadVersionTuple)>
async fn build_read_version_tuple_from_committed( &self, epoch: u64, table_id: TableId, key_range: TableKeyRange, ) -> StorageResult<(TableKeyRange, ReadVersionTuple)>
fn build_read_version_tuple_from_all( &self, epoch: u64, table_id: TableId, key_range: TableKeyRange, ) -> StorageResult<(TableKeyRange, ReadVersionTuple)>
Trait Implementations§
Source§impl Clone for HummockStorageReadSnapshot
impl Clone for HummockStorageReadSnapshot
Source§fn clone(&self) -> HummockStorageReadSnapshot
fn clone(&self) -> HummockStorageReadSnapshot
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl StateStoreRead for HummockStorageReadSnapshot
impl StateStoreRead for HummockStorageReadSnapshot
type Iter = HummockStorageIteratorInner<'static>
type RevIter = HummockStorageRevIteratorInner<'static>
Source§fn get_keyed_row(
&self,
key: TableKey<Bytes>,
read_options: ReadOptions,
) -> impl Future<Output = StorageResult<Option<StateStoreKeyedRow>>> + Send + '_
fn get_keyed_row( &self, key: TableKey<Bytes>, read_options: ReadOptions, ) -> impl Future<Output = StorageResult<Option<StateStoreKeyedRow>>> + Send + '_
Point gets a value from the state store.
The result is based on a snapshot corresponding to the given
epoch
.
Both full key and the value are returned.Source§fn iter(
&self,
key_range: TableKeyRange,
read_options: ReadOptions,
) -> impl Future<Output = StorageResult<Self::Iter>> + '_
fn iter( &self, key_range: TableKeyRange, read_options: ReadOptions, ) -> impl Future<Output = StorageResult<Self::Iter>> + '_
Opens and returns an iterator for given
prefix_hint
and full_key_range
Internally, prefix_hint
will be used to for checking bloom_filter
and
full_key_range
used for iter. (if the prefix_hint
not None, it should be be included
in key_range
) The returned iterator will iterate data based on a snapshot
corresponding to the given epoch
.fn rev_iter( &self, key_range: TableKeyRange, read_options: ReadOptions, ) -> impl Future<Output = StorageResult<Self::RevIter>> + '_
Source§fn get(
&self,
key: TableKey<Bytes>,
read_options: ReadOptions,
) -> impl StorageFuture<'_, Option<Bytes>>
fn get( &self, key: TableKey<Bytes>, read_options: ReadOptions, ) -> impl StorageFuture<'_, Option<Bytes>>
Point gets a value from the state store.
The result is based on a snapshot corresponding to the given
epoch
.
Only the value is returned.Auto Trait Implementations§
impl Freeze for HummockStorageReadSnapshot
impl !RefUnwindSafe for HummockStorageReadSnapshot
impl Send for HummockStorageReadSnapshot
impl Sync for HummockStorageReadSnapshot
impl Unpin for HummockStorageReadSnapshot
impl !UnwindSafe for HummockStorageReadSnapshot
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
, which can then be
downcast
into Box<dyn ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
, which can then be further
downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSend for T
impl<T> DowncastSend for T
§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request
§impl<T> IntoResult<T> for T
impl<T> IntoResult<T> for T
type Err = Infallible
fn into_result(self) -> Result<T, <T as IntoResult<T>>::Err>
Creates a shared type from an unshared type.
§impl<M> MetricVecRelabelExt for M
impl<M> MetricVecRelabelExt for M
§fn relabel(
self,
metric_level: MetricLevel,
relabel_threshold: MetricLevel,
) -> RelabeledMetricVec<M>
fn relabel( self, metric_level: MetricLevel, relabel_threshold: MetricLevel, ) -> RelabeledMetricVec<M>
Equivalent to [
RelabeledMetricVec::with_metric_level
].§fn relabel_n(
self,
metric_level: MetricLevel,
relabel_threshold: MetricLevel,
relabel_num: usize,
) -> RelabeledMetricVec<M>
fn relabel_n( self, metric_level: MetricLevel, relabel_threshold: MetricLevel, relabel_num: usize, ) -> RelabeledMetricVec<M>
Equivalent to [
RelabeledMetricVec::with_metric_level_relabel_n
].§fn relabel_debug_1(
self,
relabel_threshold: MetricLevel,
) -> RelabeledMetricVec<M>
fn relabel_debug_1( self, relabel_threshold: MetricLevel, ) -> RelabeledMetricVec<M>
Equivalent to [
RelabeledMetricVec::with_metric_level_relabel_n
] with metric_level
set to
MetricLevel::Debug
and relabel_num
set to 1.