Skip to main content

SnapshotManager

Struct SnapshotManager 

Source
pub struct SnapshotManager { /* private fields */ }
Expand description

Manager for snapshot files using unified FileIO.

Reference: org.apache.paimon.utils.SnapshotManager.

Implementations§

Source§

impl SnapshotManager

Source

pub fn new(file_io: FileIO, table_path: String) -> Self

Create a snapshot manager for the given table path and FileIO.

Source

pub fn file_io(&self) -> &FileIO

Source

pub fn snapshot_dir(&self) -> String

Path to the snapshot directory (e.g. table_path/snapshot).

Source

pub fn snapshot_path(&self, snapshot_id: i64) -> String

Path to the snapshot file for the given id (e.g. snapshot/snapshot-1).

Source

pub fn manifest_dir(&self) -> String

Path to the manifest directory.

Source

pub fn manifest_path(&self, manifest_name: &str) -> String

Path to a manifest file.

Source

pub async fn get_latest_snapshot_id(&self) -> Result<Option<i64>>

Get the latest snapshot id.

First tries the LATEST hint file. If the hint is valid and no next snapshot exists, returns it. Otherwise falls back to listing snapshot files.

Reference: HintFileUtils.findLatest

Source

pub async fn earliest_snapshot_id(&self) -> Result<Option<i64>>

Get the earliest snapshot id.

First tries the EARLIEST hint file. If the hint is valid and the snapshot file exists, returns it. Otherwise falls back to listing snapshot files.

Reference: HintFileUtils.findEarliest

Source

pub async fn get_snapshot(&self, snapshot_id: i64) -> Result<Snapshot>

Get a snapshot by id.

Source

pub async fn get_latest_snapshot(&self) -> Result<Option<Snapshot>>

Get the latest snapshot, or None if no snapshots exist.

Source

pub async fn commit_snapshot(&self, snapshot: &Snapshot) -> Result<bool>

Atomically commit a snapshot.

Writes the snapshot JSON to the target path. Returns false if the target already exists (another writer won the race).

On file systems that support atomic rename, we write to a temp file first then rename. On backends where rename is not supported (e.g. memory, object stores), we fall back to a direct write after an existence check.

Source

pub async fn write_latest_hint(&self, snapshot_id: i64) -> Result<()>

Update the LATEST hint file.

Source

pub async fn earlier_or_equal_time_mills( &self, timestamp_millis: i64, ) -> Result<Option<Snapshot>>

Returns the snapshot whose commit time is earlier than or equal to the given timestamp_millis. If no such snapshot exists, returns None.

Uses binary search over snapshot IDs (assumes monotonically increasing commit times).

Reference: SnapshotManager.earlierOrEqualTimeMills

Trait Implementations§

Source§

impl Clone for SnapshotManager

Source§

fn clone(&self) -> SnapshotManager

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for SnapshotManager

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> MaybeSend for T
where T: Send,