Skip to main content

BatchingSettingsProto

Struct BatchingSettingsProto 

Source
#[non_exhaustive]
pub struct BatchingSettingsProto { pub element_count_threshold: i32, pub request_byte_threshold: i64, pub delay_threshold: Option<Duration>, pub element_count_limit: i32, pub request_byte_limit: i32, pub flow_control_element_limit: i32, pub flow_control_byte_limit: i32, pub flow_control_limit_exceeded_behavior: FlowControlLimitExceededBehaviorProto, /* private fields */ }
Expand description

BatchingSettingsProto specifies a set of batching thresholds, each of which acts as a trigger to send a batch of messages as a request. At least one threshold must be positive nonzero.

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§element_count_threshold: i32

The number of elements of a field collected into a batch which, if exceeded, causes the batch to be sent.

§request_byte_threshold: i64

The aggregated size of the batched field which, if exceeded, causes the batch to be sent. This size is computed by aggregating the sizes of the request field to be batched, not of the entire request message.

§delay_threshold: Option<Duration>

The duration after which a batch should be sent, starting from the addition of the first message to that batch.

§element_count_limit: i32

The maximum number of elements collected in a batch that could be accepted by server.

§request_byte_limit: i32

The maximum size of the request that could be accepted by server.

§flow_control_element_limit: i32

The maximum number of elements allowed by flow control.

§flow_control_byte_limit: i32

The maximum size of data allowed by flow control.

§flow_control_limit_exceeded_behavior: FlowControlLimitExceededBehaviorProto

The behavior to take when the flow control limit is exceeded.

Implementations§

Source§

impl BatchingSettingsProto

Source

pub fn new() -> Self

Source

pub fn set_element_count_threshold<T: Into<i32>>(self, v: T) -> Self

Sets the value of element_count_threshold.

§Example
let x = BatchingSettingsProto::new().set_element_count_threshold(42);
Source

pub fn set_request_byte_threshold<T: Into<i64>>(self, v: T) -> Self

Sets the value of request_byte_threshold.

§Example
let x = BatchingSettingsProto::new().set_request_byte_threshold(42);
Source

pub fn set_delay_threshold<T>(self, v: T) -> Self
where T: Into<Duration>,

Sets the value of delay_threshold.

§Example
use wkt::Duration;
let x = BatchingSettingsProto::new().set_delay_threshold(Duration::default()/* use setters */);
Source

pub fn set_or_clear_delay_threshold<T>(self, v: Option<T>) -> Self
where T: Into<Duration>,

Sets or clears the value of delay_threshold.

§Example
use wkt::Duration;
let x = BatchingSettingsProto::new().set_or_clear_delay_threshold(Some(Duration::default()/* use setters */));
let x = BatchingSettingsProto::new().set_or_clear_delay_threshold(None::<Duration>);
Source

pub fn set_element_count_limit<T: Into<i32>>(self, v: T) -> Self

Sets the value of element_count_limit.

§Example
let x = BatchingSettingsProto::new().set_element_count_limit(42);
Source

pub fn set_request_byte_limit<T: Into<i32>>(self, v: T) -> Self

Sets the value of request_byte_limit.

§Example
let x = BatchingSettingsProto::new().set_request_byte_limit(42);
Source

pub fn set_flow_control_element_limit<T: Into<i32>>(self, v: T) -> Self

Sets the value of flow_control_element_limit.

§Example
let x = BatchingSettingsProto::new().set_flow_control_element_limit(42);
Source

pub fn set_flow_control_byte_limit<T: Into<i32>>(self, v: T) -> Self

Sets the value of flow_control_byte_limit.

§Example
let x = BatchingSettingsProto::new().set_flow_control_byte_limit(42);
Source

pub fn set_flow_control_limit_exceeded_behavior<T: Into<FlowControlLimitExceededBehaviorProto>>( self, v: T, ) -> Self

Sets the value of flow_control_limit_exceeded_behavior.

§Example
use google_cloud_api::model::FlowControlLimitExceededBehaviorProto;
let x0 = BatchingSettingsProto::new().set_flow_control_limit_exceeded_behavior(FlowControlLimitExceededBehaviorProto::ThrowException);
let x1 = BatchingSettingsProto::new().set_flow_control_limit_exceeded_behavior(FlowControlLimitExceededBehaviorProto::Block);
let x2 = BatchingSettingsProto::new().set_flow_control_limit_exceeded_behavior(FlowControlLimitExceededBehaviorProto::Ignore);

Trait Implementations§

Source§

impl Clone for BatchingSettingsProto

Source§

fn clone(&self) -> BatchingSettingsProto

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 BatchingSettingsProto

Source§

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

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

impl Default for BatchingSettingsProto

Source§

fn default() -> BatchingSettingsProto

Returns the “default value” for a type. Read more
Source§

impl Message for BatchingSettingsProto

Source§

fn typename() -> &'static str

The typename of this message.
Source§

impl PartialEq for BatchingSettingsProto

Source§

fn eq(&self, other: &BatchingSettingsProto) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for BatchingSettingsProto

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> 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<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,