C# Класс RabbitMQ.Client.Framing.Impl.Connection

Наследование: IConnection
Показать файл Открыть проект Примеры использования класса

Private Properties

Свойство Тип Описание
IDisposable void
MaybeDisposeTimer void
NegotiatedMaxValue uint

Открытые методы

Метод Описание
Abort ( ) : void

API-side invocation of connection abort.

Abort ( int timeout ) : void

API-side invocation of connection abort with timeout.

Abort ( ushort reasonCode, string reasonText ) : void

API-side invocation of connection abort.

Abort ( ushort reasonCode, string reasonText, ShutdownInitiator initiator, int timeout ) : void
Abort ( ushort reasonCode, string reasonText, int timeout ) : void

API-side invocation of connection abort with timeout.

Close ( ) : void

API-side invocation of connection.close.

Close ( ShutdownEventArgs reason ) : void
Close ( ShutdownEventArgs reason, bool abort, int timeout ) : void

Try to close connection in a graceful way

Shutdown reason contains code and text assigned when closing the connection, as well as the information about what initiated the close

Abort flag, if true, signals to close the ongoing connection immediately and do not report any errors if it was already closed.

Timeout determines how much time internal close operations should be given to complete. Negative or Timeout.Infinite value mean infinity.

Close ( int timeout ) : void

API-side invocation of connection.close with timeout.

Close ( ushort reasonCode, string reasonText ) : void

API-side invocation of connection.close.

Close ( ushort reasonCode, string reasonText, int timeout ) : void

API-side invocation of connection.close with timeout.

ClosingLoop ( ) : void Loop only used while quiescing. Use only to cleanly close connection
Connection ( IConnectionFactory factory, bool insist, IFrameHandler frameHandler, string clientProvidedName = null ) : System.Threading.Tasks
ConnectionCloseWrapper ( ushort reasonCode, string reasonText ) : Command
CreateModel ( ) : IModel
CreateSession ( ) : ISession
CreateSession ( int channelNumber ) : ISession
DefaultClientProperties ( ) : object>.IDictionary
EnsureIsOpen ( ) : void
FinishClose ( ) : void
HandleApplicationSuspend ( object sender, SuspendingEventArgs suspendingEventArgs ) : void We need to close the socket, otherwise suspending the application will take the maximum time allowed
HandleConnectionBlocked ( string reason ) : void
HandleConnectionUnblocked ( ) : void
HandleDomainUnload ( object sender, EventArgs ea ) : void We need to close the socket, otherwise attempting to unload the domain could cause a CannotUnloadAppDomainException
HandleMainLoopException ( ShutdownEventArgs reason ) : void
HardProtocolExceptionHandler ( RabbitMQ.Client.Impl.HardProtocolException hpe ) : bool
HeartbeatReadTimerCallback ( object state ) : void
HeartbeatWriteTimerCallback ( object state ) : void
InternalClose ( ShutdownEventArgs reason ) : void
LogCloseError ( String error, Exception ex ) : void
MainLoop ( ) : void
MainLoopIteration ( ) : void
MaybeStartHeartbeatTimers ( ) : void
NotifyHeartbeatListener ( ) : void
NotifyReceivedCloseOk ( ) : void
OnCallbackException ( RabbitMQ.Client.Events.CallbackExceptionEventArgs args ) : void
OnConnectionBlocked ( RabbitMQ.Client.Events.ConnectionBlockedEventArgs args ) : void
OnConnectionUnblocked ( ) : void
OnShutdown ( ) : void

Broadcasts notification of the final shutdown of the connection.

Open ( bool insist ) : void
PrettyPrintShutdownReport ( ) : void
QuiesceChannel ( RabbitMQ.Client.Impl.SoftProtocolException pe ) : void

Sets the channel named in the SoftProtocolException into "quiescing mode", where we issue a channel.close and ignore everything except for subsequent channel.close messages and the channel.close-ok reply that should eventually arrive.

Since a well-behaved peer will not wait indefinitely before issuing the close-ok, we don't bother with a timeout here; compare this to the case of a connection.close-ok, where a timeout is necessary.

We need to send the close method and politely wait for a reply before marking the channel as available for reuse.

As soon as SoftProtocolException is detected, we should stop servicing ordinary application work, and should concentrate on bringing down the channel as quickly and gracefully as possible. The way this is done, as per the close-protocol, is to signal closure up the stack *before* sending the channel.close, by invoking ISession.Close. Once the upper layers have been signalled, we are free to do what we need to do to clean up and shut down the channel.

SetCloseReason ( ShutdownEventArgs reason ) : bool
StartMainLoop ( bool useBackgroundThread ) : void
TerminateMainloop ( ) : void May be called more than once. Should therefore be idempotent.
ToString ( ) : string
WriteFrame ( Frame f ) : void
WriteFrameSet ( IList f ) : void

Защищенные методы

Метод Описание
ChannelCloseWrapper ( ushort reasonCode, string reasonText ) : Command
MaybeStopHeartbeatTimers ( ) : void
StartAndTune ( ) : void

Приватные методы

Метод Описание
IDisposable ( ) : void
MaybeDisposeTimer ( Timer &timer ) : void
NegotiatedMaxValue ( uint clientValue, uint serverValue ) : uint

Описание методов

Abort() публичный Метод

API-side invocation of connection abort.
public Abort ( ) : void
Результат void

Abort() публичный Метод

API-side invocation of connection abort with timeout.
public Abort ( int timeout ) : void
timeout int
Результат void

Abort() публичный Метод

API-side invocation of connection abort.
public Abort ( ushort reasonCode, string reasonText ) : void
reasonCode ushort
reasonText string
Результат void

Abort() публичный Метод

public Abort ( ushort reasonCode, string reasonText, ShutdownInitiator initiator, int timeout ) : void
reasonCode ushort
reasonText string
initiator ShutdownInitiator
timeout int
Результат void

Abort() публичный Метод

API-side invocation of connection abort with timeout.
public Abort ( ushort reasonCode, string reasonText, int timeout ) : void
reasonCode ushort
reasonText string
timeout int
Результат void

ChannelCloseWrapper() защищенный Метод

protected ChannelCloseWrapper ( ushort reasonCode, string reasonText ) : Command
reasonCode ushort
reasonText string
Результат RabbitMQ.Client.Impl.Command

Close() публичный Метод

API-side invocation of connection.close.
public Close ( ) : void
Результат void

Close() публичный Метод

public Close ( ShutdownEventArgs reason ) : void
reason ShutdownEventArgs
Результат void

Close() публичный Метод

Try to close connection in a graceful way

Shutdown reason contains code and text assigned when closing the connection, as well as the information about what initiated the close

Abort flag, if true, signals to close the ongoing connection immediately and do not report any errors if it was already closed.

Timeout determines how much time internal close operations should be given to complete. Negative or Timeout.Infinite value mean infinity.

public Close ( ShutdownEventArgs reason, bool abort, int timeout ) : void
reason ShutdownEventArgs
abort bool
timeout int
Результат void

Close() публичный Метод

API-side invocation of connection.close with timeout.
public Close ( int timeout ) : void
timeout int
Результат void

Close() публичный Метод

API-side invocation of connection.close.
public Close ( ushort reasonCode, string reasonText ) : void
reasonCode ushort
reasonText string
Результат void

Close() публичный Метод

API-side invocation of connection.close with timeout.
public Close ( ushort reasonCode, string reasonText, int timeout ) : void
reasonCode ushort
reasonText string
timeout int
Результат void

ClosingLoop() публичный Метод

Loop only used while quiescing. Use only to cleanly close connection
public ClosingLoop ( ) : void
Результат void

Connection() публичный Метод

public Connection ( IConnectionFactory factory, bool insist, IFrameHandler frameHandler, string clientProvidedName = null ) : System.Threading.Tasks
factory IConnectionFactory
insist bool
frameHandler IFrameHandler
clientProvidedName string
Результат System.Threading.Tasks

ConnectionCloseWrapper() публичный Метод

public ConnectionCloseWrapper ( ushort reasonCode, string reasonText ) : Command
reasonCode ushort
reasonText string
Результат RabbitMQ.Client.Impl.Command

CreateModel() публичный Метод

public CreateModel ( ) : IModel
Результат IModel

CreateSession() публичный Метод

public CreateSession ( ) : ISession
Результат ISession

CreateSession() публичный Метод

public CreateSession ( int channelNumber ) : ISession
channelNumber int
Результат ISession

DefaultClientProperties() публичный статический Метод

public static DefaultClientProperties ( ) : object>.IDictionary
Результат object>.IDictionary

EnsureIsOpen() публичный Метод

public EnsureIsOpen ( ) : void
Результат void

FinishClose() публичный Метод

public FinishClose ( ) : void
Результат void

HandleApplicationSuspend() публичный Метод

We need to close the socket, otherwise suspending the application will take the maximum time allowed
public HandleApplicationSuspend ( object sender, SuspendingEventArgs suspendingEventArgs ) : void
sender object
suspendingEventArgs Windows.ApplicationModel.SuspendingEventArgs
Результат void

HandleConnectionBlocked() публичный Метод

public HandleConnectionBlocked ( string reason ) : void
reason string
Результат void

HandleConnectionUnblocked() публичный Метод

public HandleConnectionUnblocked ( ) : void
Результат void

HandleDomainUnload() публичный Метод

We need to close the socket, otherwise attempting to unload the domain could cause a CannotUnloadAppDomainException
public HandleDomainUnload ( object sender, EventArgs ea ) : void
sender object
ea System.EventArgs
Результат void

HandleMainLoopException() публичный Метод

public HandleMainLoopException ( ShutdownEventArgs reason ) : void
reason ShutdownEventArgs
Результат void

HardProtocolExceptionHandler() публичный Метод

public HardProtocolExceptionHandler ( RabbitMQ.Client.Impl.HardProtocolException hpe ) : bool
hpe RabbitMQ.Client.Impl.HardProtocolException
Результат bool

HeartbeatReadTimerCallback() публичный Метод

public HeartbeatReadTimerCallback ( object state ) : void
state object
Результат void

HeartbeatWriteTimerCallback() публичный Метод

public HeartbeatWriteTimerCallback ( object state ) : void
state object
Результат void

InternalClose() публичный Метод

public InternalClose ( ShutdownEventArgs reason ) : void
reason ShutdownEventArgs
Результат void

LogCloseError() публичный Метод

public LogCloseError ( String error, Exception ex ) : void
error String
ex System.Exception
Результат void

MainLoop() публичный Метод

public MainLoop ( ) : void
Результат void

MainLoopIteration() публичный Метод

public MainLoopIteration ( ) : void
Результат void

MaybeStartHeartbeatTimers() публичный Метод

public MaybeStartHeartbeatTimers ( ) : void
Результат void

MaybeStopHeartbeatTimers() защищенный Метод

protected MaybeStopHeartbeatTimers ( ) : void
Результат void

NotifyHeartbeatListener() публичный Метод

public NotifyHeartbeatListener ( ) : void
Результат void

NotifyReceivedCloseOk() публичный Метод

public NotifyReceivedCloseOk ( ) : void
Результат void

OnCallbackException() публичный Метод

public OnCallbackException ( RabbitMQ.Client.Events.CallbackExceptionEventArgs args ) : void
args RabbitMQ.Client.Events.CallbackExceptionEventArgs
Результат void

OnConnectionBlocked() публичный Метод

public OnConnectionBlocked ( RabbitMQ.Client.Events.ConnectionBlockedEventArgs args ) : void
args RabbitMQ.Client.Events.ConnectionBlockedEventArgs
Результат void

OnConnectionUnblocked() публичный Метод

public OnConnectionUnblocked ( ) : void
Результат void

OnShutdown() публичный Метод

Broadcasts notification of the final shutdown of the connection.
public OnShutdown ( ) : void
Результат void

Open() публичный Метод

public Open ( bool insist ) : void
insist bool
Результат void

PrettyPrintShutdownReport() публичный Метод

public PrettyPrintShutdownReport ( ) : void
Результат void

QuiesceChannel() публичный Метод

Sets the channel named in the SoftProtocolException into "quiescing mode", where we issue a channel.close and ignore everything except for subsequent channel.close messages and the channel.close-ok reply that should eventually arrive.

Since a well-behaved peer will not wait indefinitely before issuing the close-ok, we don't bother with a timeout here; compare this to the case of a connection.close-ok, where a timeout is necessary.

We need to send the close method and politely wait for a reply before marking the channel as available for reuse.

As soon as SoftProtocolException is detected, we should stop servicing ordinary application work, and should concentrate on bringing down the channel as quickly and gracefully as possible. The way this is done, as per the close-protocol, is to signal closure up the stack *before* sending the channel.close, by invoking ISession.Close. Once the upper layers have been signalled, we are free to do what we need to do to clean up and shut down the channel.

public QuiesceChannel ( RabbitMQ.Client.Impl.SoftProtocolException pe ) : void
pe RabbitMQ.Client.Impl.SoftProtocolException
Результат void

SetCloseReason() публичный Метод

public SetCloseReason ( ShutdownEventArgs reason ) : bool
reason ShutdownEventArgs
Результат bool

StartAndTune() защищенный Метод

protected StartAndTune ( ) : void
Результат void

StartMainLoop() публичный Метод

public StartMainLoop ( bool useBackgroundThread ) : void
useBackgroundThread bool
Результат void

TerminateMainloop() публичный Метод

May be called more than once. Should therefore be idempotent.
public TerminateMainloop ( ) : void
Результат void

ToString() публичный Метод

public ToString ( ) : string
Результат string

WriteFrame() публичный Метод

public WriteFrame ( Frame f ) : void
f RabbitMQ.Client.Impl.Frame
Результат void

WriteFrameSet() публичный Метод

public WriteFrameSet ( IList f ) : void
f IList
Результат void