pub struct ConcurrentMultiPartsUploaderScheduler<M: MultiPartsUploader> { /* private fields */ }
Expand description
并行分片上传调度器
在阻塞模式下创建线程池负责上传分片,在异步模式下使用 async-std 的线程池负责上传分片。
§用并行分片上传调度器上传文件
§阻塞代码示例
use qiniu_upload_manager::{
apis::credential::Credential, prelude::*, ConcurrentMultiPartsUploaderScheduler,
FileSystemResumableRecorder, MultiPartsV2Uploader, ObjectParams, UploadManager,
UploadTokenSigner,
};
use std::time::Duration;
use sha1::Sha1;
let bucket_name = "test-bucket";
let object_name = "test-object";
let upload_manager = UploadManager::builder(UploadTokenSigner::new_credential_provider(
Credential::new("abcdefghklmnopq", "1234567890"),
bucket_name,
Duration::from_secs(3600),
))
.build();
let params = ObjectParams::builder().object_name(object_name).file_name(object_name).build();
let mut scheduler = ConcurrentMultiPartsUploaderScheduler::new(MultiPartsV2Uploader::new(
upload_manager,
FileSystemResumableRecorder::<Sha1>::default(),
));
scheduler.upload_path("/home/qiniu/test.png", params)?;
§异步代码示例
use qiniu_upload_manager::{
apis::credential::Credential, prelude::*, ConcurrentMultiPartsUploaderScheduler,
FileSystemResumableRecorder, MultiPartsV2Uploader, ObjectParams, UploadManager,
UploadTokenSigner,
};
use std::time::Duration;
use sha1::Sha1;
let bucket_name = "test-bucket";
let object_name = "test-object";
let upload_manager = UploadManager::builder(UploadTokenSigner::new_credential_provider(
Credential::new("abcdefghklmnopq", "1234567890"),
bucket_name,
Duration::from_secs(3600),
))
.build();
let params = ObjectParams::builder().object_name(object_name).file_name(object_name).build();
let mut scheduler = ConcurrentMultiPartsUploaderScheduler::new(MultiPartsV2Uploader::new(
upload_manager,
FileSystemResumableRecorder::<Sha1>::default(),
));
scheduler.async_upload_path("/home/qiniu/test.png", params).await?;
Implementations§
Source§impl<M: MultiPartsUploader> ConcurrentMultiPartsUploaderScheduler<M>
impl<M: MultiPartsUploader> ConcurrentMultiPartsUploaderScheduler<M>
Sourcepub fn concurrency_provider(&self) -> &dyn ConcurrencyProvider
pub fn concurrency_provider(&self) -> &dyn ConcurrencyProvider
获取并发数提供者
Sourcepub fn data_partition_provider(&self) -> &dyn DataPartitionProvider
pub fn data_partition_provider(&self) -> &dyn DataPartitionProvider
获取分片大小提供者
Trait Implementations§
Source§impl<M: Clone + MultiPartsUploader> Clone for ConcurrentMultiPartsUploaderScheduler<M>
impl<M: Clone + MultiPartsUploader> Clone for ConcurrentMultiPartsUploaderScheduler<M>
Source§fn clone(&self) -> ConcurrentMultiPartsUploaderScheduler<M>
fn clone(&self) -> ConcurrentMultiPartsUploaderScheduler<M>
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<M: Debug + MultiPartsUploader> Debug for ConcurrentMultiPartsUploaderScheduler<M>
impl<M: Debug + MultiPartsUploader> Debug for ConcurrentMultiPartsUploaderScheduler<M>
Source§impl<M: MultiPartsUploader + 'static> MultiPartsUploaderScheduler<<M as MultiPartsUploader>::HashAlgorithm> for ConcurrentMultiPartsUploaderScheduler<M>
impl<M: MultiPartsUploader + 'static> MultiPartsUploaderScheduler<<M as MultiPartsUploader>::HashAlgorithm> for ConcurrentMultiPartsUploaderScheduler<M>
Source§fn set_concurrency_provider(
&mut self,
concurrency_provider: Box<dyn ConcurrencyProvider>,
)
fn set_concurrency_provider( &mut self, concurrency_provider: Box<dyn ConcurrencyProvider>, )
设置并发数提供者
Source§fn set_data_partition_provider(
&mut self,
data_partition_provider: Box<dyn DataPartitionProvider>,
)
fn set_data_partition_provider( &mut self, data_partition_provider: Box<dyn DataPartitionProvider>, )
设置分片大小提供者
Source§fn upload(
&self,
source: Box<dyn DataSource<M::HashAlgorithm>>,
params: ObjectParams,
) -> ApiResult<Value>
fn upload( &self, source: Box<dyn DataSource<M::HashAlgorithm>>, params: ObjectParams, ) -> ApiResult<Value>
上传数据源 Read more
Source§fn async_upload(
&self,
source: Box<dyn AsyncDataSource<M::HashAlgorithm>>,
params: ObjectParams,
) -> BoxFuture<'_, ApiResult<Value>>
fn async_upload( &self, source: Box<dyn AsyncDataSource<M::HashAlgorithm>>, params: ObjectParams, ) -> BoxFuture<'_, ApiResult<Value>>
Available on crate feature
async
only.异步上传数据源
Auto Trait Implementations§
impl<M> Freeze for ConcurrentMultiPartsUploaderScheduler<M>where
M: Freeze,
impl<M> !RefUnwindSafe for ConcurrentMultiPartsUploaderScheduler<M>
impl<M> Send for ConcurrentMultiPartsUploaderScheduler<M>
impl<M> Sync for ConcurrentMultiPartsUploaderScheduler<M>
impl<M> Unpin for ConcurrentMultiPartsUploaderScheduler<M>where
M: Unpin,
impl<M> !UnwindSafe for ConcurrentMultiPartsUploaderScheduler<M>
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,
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> 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<A, T> MultiPartsUploaderSchedulerExt<A> for T
impl<A, T> MultiPartsUploaderSchedulerExt<A> for T
Source§fn upload_path(
&self,
path: impl AsRef<Path>,
params: ObjectParams,
) -> ApiResult<Value>
fn upload_path( &self, path: impl AsRef<Path>, params: ObjectParams, ) -> ApiResult<Value>
上传指定路径的文件
Source§fn upload_reader<R: Read + Debug + Send + Sync + 'static>(
&self,
reader: R,
params: ObjectParams,
) -> ApiResult<Value>
fn upload_reader<R: Read + Debug + Send + Sync + 'static>( &self, reader: R, params: ObjectParams, ) -> ApiResult<Value>
上传输入流的数据
Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Pipes by value. This is generally the method you want to use. Read more
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
Borrows
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
Mutably borrows
self
and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
Borrows
self
, then passes self.as_ref()
into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
Mutably borrows
self
, then passes self.as_mut()
into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
Borrows
self
, then passes self.deref()
into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Immutable access to the
Borrow<B>
of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
Mutable access to the
BorrowMut<B>
of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
Immutable access to the
AsRef<R>
view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
Mutable access to the
AsMut<R>
view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Immutable access to the
Deref::Target
of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Mutable access to the
Deref::Target
of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
Calls
.tap()
only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
Calls
.tap_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
Calls
.tap_borrow()
only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
Calls
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
Calls
.tap_ref()
only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
Calls
.tap_ref_mut()
only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
Calls
.tap_deref()
only in debug builds, and is erased in release
builds.