HdfsObjectStore

Struct HdfsObjectStore 

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

Implementations§

Source§

impl HdfsObjectStore

Source

pub fn new(client: Client) -> Self

Creates a new HdfsObjectStore from an existing hdfs-native Client

use hdfs_native::ClientBuilder;
let client = ClientBuilder::new().with_url("hdfs://127.0.0.1:9000").build().unwrap();
let store = HdfsObjectStore::new(client);
Source

pub fn with_url(url: &str) -> Result<Self>

👎Deprecated since 0.15.0: Use HdfsObjectStoreBuilder instead

Creates a new HdfsObjectStore using the specified URL

Connect to a NameNode

let store = HdfsObjectStore::with_url("hdfs://127.0.0.1:9000")?;
Source

pub fn with_config(url: &str, config: HashMap<String, String>) -> Result<Self>

👎Deprecated since 0.15.0: Use HdfsObjectStoreBuilder instead

Creates a new HdfsObjectStore using the specified URL and Hadoop configs.

Connect to a NameService

let config = HashMap::from([
    ("dfs.ha.namenodes.ns".to_string(), "nn1,nn2".to_string()),
    ("dfs.namenode.rpc-address.ns.nn1".to_string(), "nn1.example.com:9000".to_string()),
    ("dfs.namenode.rpc-address.ns.nn2".to_string(), "nn2.example.com:9000".to_string()),
]);
let store = HdfsObjectStore::with_config("hdfs://ns", config)?;

Trait Implementations§

Source§

impl Clone for HdfsObjectStore

Source§

fn clone(&self) -> HdfsObjectStore

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 HdfsObjectStore

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Display for HdfsObjectStore

Source§

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

Formats the value using the given formatter. Read more
Source§

impl From<Client> for HdfsObjectStore

Source§

fn from(value: Client) -> Self

Converts to this type from the input type.
Source§

impl ObjectStore for HdfsObjectStore

Source§

fn put_opts<'life0, 'life1, 'async_trait>( &'life0 self, location: &'life1 Path, payload: PutPayload, opts: PutOptions, ) -> Pin<Box<dyn Future<Output = Result<PutResult>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Save the provided bytes to the specified location

To make the operation atomic, we write to a temporary file .{filename}.tmp.{i} and rename on a successful write, where i is an integer that is incremented until a non-existent file is found.

Source§

fn put_multipart_opts<'life0, 'life1, 'async_trait>( &'life0 self, location: &'life1 Path, _opts: PutMultipartOpts, ) -> Pin<Box<dyn Future<Output = Result<Box<dyn MultipartUpload>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Create a multipart writer that writes to a temporary file in a background task, and renames to the final destination on complete.

Source§

fn get_opts<'life0, 'life1, 'async_trait>( &'life0 self, location: &'life1 Path, options: GetOptions, ) -> Pin<Box<dyn Future<Output = Result<GetResult>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Reads data for the specified location.

Source§

fn delete_stream( &self, locations: BoxStream<'static, Result<Path>>, ) -> BoxStream<'static, Result<Path>>

Delete a stream of objects.

Source§

fn list(&self, prefix: Option<&Path>) -> BoxStream<'static, Result<ObjectMeta>>

List all the objects with the given prefix.

Prefixes are evaluated on a path segment basis, i.e. foo/bar/ is a prefix of foo/bar/x but not of foo/bar_baz/x.

Note: the order of returned ObjectMeta is not guaranteed

Source§

fn list_with_delimiter<'life0, 'life1, 'async_trait>( &'life0 self, prefix: Option<&'life1 Path>, ) -> Pin<Box<dyn Future<Output = Result<ListResult>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

List objects with the given prefix and an implementation specific delimiter. Returns common prefixes (directories) in addition to object metadata.

Prefixes are evaluated on a path segment basis, i.e. foo/bar/ is a prefix of foo/bar/x but not of foo/bar_baz/x.

Source§

fn copy_opts<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, from: &'life1 Path, to: &'life2 Path, options: CopyOptions, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Copy an object from one path to another with options.

Source§

fn rename_opts<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, from: &'life1 Path, to: &'life2 Path, options: RenameOptions, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Move an object from one path to another in the same object store. Read more
Source§

fn get_ranges<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, location: &'life1 Path, ranges: &'life2 [Range<u64>], ) -> Pin<Box<dyn Future<Output = Result<Vec<Bytes>, Error>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, Self: 'async_trait,

Return the bytes that are stored at the specified location in the given byte ranges
Source§

fn list_with_offset( &self, prefix: Option<&Path>, offset: &Path, ) -> Pin<Box<dyn Stream<Item = Result<ObjectMeta, Error>> + Send>>

List all the objects with the given prefix and a location greater than offset 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, 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> ObjectStoreExt for T
where T: ObjectStore + ?Sized,

Source§

async fn put( &self, location: &Path, payload: PutPayload, ) -> Result<PutResult, Error>

Save the provided bytes to the specified location Read more
Source§

async fn put_multipart( &self, location: &Path, ) -> Result<Box<dyn MultipartUpload>, Error>

Perform a multipart upload Read more
Source§

async fn get(&self, location: &Path) -> Result<GetResult, Error>

Return the bytes that are stored at the specified location. Read more
Source§

async fn get_range( &self, location: &Path, range: Range<u64>, ) -> Result<Bytes, Error>

Return the bytes that are stored at the specified location in the given byte range. Read more
Source§

async fn head(&self, location: &Path) -> Result<ObjectMeta, Error>

Return the metadata for the specified location
Source§

async fn delete(&self, location: &Path) -> Result<(), Error>

Delete the object at the specified location.
Source§

async fn copy(&self, from: &Path, to: &Path) -> Result<(), Error>

Copy an object from one path to another in the same object store. Read more
Source§

async fn copy_if_not_exists(&self, from: &Path, to: &Path) -> Result<(), Error>

Copy an object from one path to another, only if destination is empty. Read more
Source§

async fn rename(&self, from: &Path, to: &Path) -> Result<(), Error>

Move an object from one path to another in the same object store. Read more
Source§

async fn rename_if_not_exists( &self, from: &Path, to: &Path, ) -> Result<(), Error>

Move an object from one path to another in the same object store. 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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> ErasedDestructor for T
where T: 'static,