[英]RabbitMQ throwing TimeOut exception on .CreateModel()
我創建了一個總線應用程序來封裝所有訂閱和發布到 RabbitMQ 代理。 然后這條總線被用作我其他項目的 SDK。 在運行這個項目后(對於使用我的 Bus sdk 通過 RabbitMQ 消息進行通信的應用程序來說,這是基本的),我意識到總線在本地方法 .CreateModel() 上拋出了一個 TimeOut 異常,如下所示:
System.TimeoutException: The operation has timed out.
at RabbitMQ.Util.BlockingCell.GetValue(TimeSpan timeout)
at RabbitMQ.Client.Impl.SimpleBlockingRpcContinuation.GetReply(TimeSpan timeout)
at RabbitMQ.Client.Impl.ModelBase.ModelRpc(MethodBase method, ContentHeaderBase header, Byte[] body)
at RabbitMQ.Client.Framing.Impl.Model._Private_ChannelOpen(String outOfBand)
at RabbitMQ.Client.Framing.Impl.AutorecoveringConnection.CreateNonRecoveringModel()
at RabbitMQ.Client.Framing.Impl.AutorecoveringConnection.CreateModel()
以下是有關我的 RabbitMQ 代理的一些信息: 版本:3.7.2 Erlang:20.1 操作系統:Linux Ubuntu (AWS)
這是我的 RabbitMQConnection 類:
internal class RabbitMQConnection : IDisposable
{
private object __syncRoot__ { get; } = new object();
#region Private
private bool __disposed__ { get; set; }
private IConnectionFactory __rmqConnFactory__ { get; }
private IConnection __rmqConnection__ { get; set; }
private string __connectionIdentifier__ { get; }
private ILog __logger__ { get; }
#endregion
#region Public
public bool IsConnected
{
get
{
DisposeCheck();
return __rmqConnection__ != null && __rmqConnection__.IsOpen && !__disposed__;
}
}
public int ThreadLimit { get; private set; }
public IConnection GetConnection
{
get
{
DisposeCheck();
if (IsConnected == true)
{
return __rmqConnection__;
}
else
{
return null;
}
}
}
public bool IsDisposed
{
get
{
return __disposed__;
}
}
#endregion
public RabbitMQConnection(RabbitMQConfiguration _rmqConfig)
{
__logger__ = LogProvider.GetCurrentClassLogger();
ConnectionFactory rMQconnFactory = new ConnectionFactory()
{
HostName = _rmqConfig.Hostname,
UserName = _rmqConfig.Username,
Password = _rmqConfig.Password,
VirtualHost = _rmqConfig.VirtualHost,
AutomaticRecoveryEnabled = true,
DispatchConsumersAsync = true,
};
__rmqConnFactory__ = rMQconnFactory;
ThreadLimit = _rmqConfig.ThreadLimit;
__connectionIdentifier__ = $"{_rmqConfig.CurrentMachineIPAddress} - {_rmqConfig.CurrentMachineHostname}";
Connect();
__disposed__ = false;
}
private void Connect()
{
DisposeCheck();
if (__rmqConnection__ == null)
{
lock (__syncRoot__)
{
if (__rmqConnection__ == null)
{
__rmqConnection__ = __rmqConnFactory__.CreateConnection(__connectionIdentifier__);
}
}
}
}
public IModel CreateChannel()
{
DisposeCheck();
if (!IsConnected)
{
throw new InvalidOperationException("No RabbitMQ connections are available to perform this action");
}
return __rmqConnection__.CreateModel(); // Here is where the exception occurs!!!
}
#region ShutdownEvents
private void OnConnectionBlocked(object sender, ConnectionBlockedEventArgs e)
{
if (__disposed__) return;
//Logar algo
__logger__.Warn("A RabbitMQ connection (OnConnectionBlocked) is shutdown. Trying to re-connect...");
}
void OnCallbackException(object sender, CallbackExceptionEventArgs e)
{
if (__disposed__) return;
//Logar algo
__logger__.Warn(e?.Exception, "A RabbitMQ connection (OnCallbackException) is shutdown. Trying to re-connect...");
}
void OnConnectionShutdown(object sender, ShutdownEventArgs reason)
{
if (__disposed__) return;
//Logar algo
__logger__.Warn("A RabbitMQ connection (OnConnectionShutdown) is on shutdown. Trying to re-connect...");
}
#endregion
public void Dispose()
{
if (__disposed__ == true)
{
return;
}
try
{
__rmqConnection__?.Dispose();
}
catch (Exception ex)
{
//Log here
__logger__.Fatal(ex, "RabbitMQ Connection: {0}", ex.Message);
}
finally
{
__disposed__ = true;
}
}
private void DisposeCheck()
{
if (__disposed__ == true)
{
throw new ObjectDisposedException("RabbitMQConnection");
}
}
}
異常發生在以下行中:
return __rmqConnection__.CreateModel();
有沒有人知道為什么會這樣? 我知道有時 RabbitMQ 連接可能會發生振盪,但我聽說 RabbitMQ 會在發生這種情況時進行本地重試。
我不知道它現在有多大關系。 異常為 {System.TimeoutException} 操作已超時。 如果我們在連接工廠中刪除AutomaticRecoveryEnabled = true ,則不會生成異常並創建通道。
物有所值; 當IConnection
上已經創建了太多頻道時,我遇到了這個錯誤。 不幸的是,錯誤並沒有表明這一點,但是減少通道數量阻止了錯誤的發生。
可以在客戶端和服務器中設置最大通道數。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.