Struct h2::FlowControl
source · [−]pub struct FlowControl { /* private fields */ }
Expand description
A handle to release window capacity to a remote stream.
This type allows the caller to manage inbound data flow control. The
caller is expected to call release_capacity
after dropping data frames.
Overview
Each stream has a window size. This window size is the maximum amount of inbound data that can be in-flight. In-flight data is defined as data that has been received, but not yet released.
When a stream is created, the window size is set to the connection’s initial
window size value. When a data frame is received, the window size is then
decremented by size of the data frame before the data is provided to the
caller. As the caller finishes using the data, release_capacity
must be
called. This will then increment the window size again, allowing the peer to
send more data.
There is also a connection level window as well as the stream level window.
Received data counts against the connection level window as well and calls
to release_capacity
will also increment the connection level window.
Sending WINDOW_UPDATE
frames
WINDOW_UPDATE
frames will not be sent out for every call to
release_capacity
, as this would end up slowing down the protocol. Instead,
h2
waits until the window size is increased to a certain threshold and
then sends out a single WINDOW_UPDATE
frame representing all the calls to
release_capacity
since the last WINDOW_UPDATE
frame.
This essentially batches window updating.
Scenarios
Following is a basic scenario with an HTTP/2.0 connection containing a single active stream.
- A new stream is activated. The receive window is initialized to 1024 (the value of the initial window size for this connection).
- A
DATA
frame is received containing a payload of 400 bytes. - The receive window size is reduced to 424 bytes.
release_capacity
is called with 200.- The receive window size is now 624 bytes. The peer may send no more than this.
- A
DATA
frame is received with a payload of 624 bytes. - The window size is now 0 bytes. The peer may not send any more data.
release_capacity
is called with 1024.- The receive window size is now 1024 bytes. The peer may now send more data.
Implementations
sourceimpl FlowControl
impl FlowControl
sourcepub fn stream_id(&self) -> StreamId
pub fn stream_id(&self) -> StreamId
Returns the stream ID of the stream whose capacity will
be released by this FlowControl
.
sourcepub fn available_capacity(&self) -> isize
pub fn available_capacity(&self) -> isize
Get the current available capacity of data this stream could receive.
sourcepub fn used_capacity(&self) -> usize
pub fn used_capacity(&self) -> usize
Get the currently used capacity for this stream.
This is the amount of bytes that can be released back to the remote.
sourcepub fn release_capacity(&mut self, sz: usize) -> Result<(), Error>
pub fn release_capacity(&mut self, sz: usize) -> Result<(), Error>
Release window capacity back to remote stream.
This releases capacity back to the stream level and the connection level
windows. Both window sizes will be increased by sz
.
See struct level documentation for more details.
Errors
This function errors if increasing the receive window size by sz
would
result in a window size greater than the target window size. In other
words, the caller cannot release more capacity than data has been
received. If 1024 bytes of data have been received, at most 1024 bytes
can be released.
Trait Implementations
sourceimpl Clone for FlowControl
impl Clone for FlowControl
sourcefn clone(&self) -> FlowControl
fn clone(&self) -> FlowControl
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source
. Read more
Auto Trait Implementations
impl RefUnwindSafe for FlowControl
impl Send for FlowControl
impl Sync for FlowControl
impl Unpin for FlowControl
impl UnwindSafe for FlowControl
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Instruments this type with the provided Span
, returning an
Instrumented
wrapper. Read more
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Instruments this type with the provided Span
, returning an
Instrumented
wrapper. Read more
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcepub fn to_owned(&self) -> T
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
sourcepub fn clone_into(&self, target: &mut T)
pub fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
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
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more