获取azure deadletter信息并保存到cosmos db中

时间:2017-12-27 11:22:31

标签: c# asp.net .net azure asp.net-core

在一个项目中,我的要求是计算azure deadletter。如果计数大于0,那么我必须得到每个死信信息的详细信息,如描述或死信的原因并保存到cosmos db中。 为了获得死信计数我正在使用代码:

NamespaceManager namespaceManager=Microsoft.ServiceBus.NamespaceManager.CreateFromConnectionString(sbConnectionString);    
var abc = namespaceManager.GetQueue("").MessageCountDetails;        
var deadLetterCount = messageDetails.DeadLetterMessageCount;    

并保存到cosmos db中,代码为:

 DocumentDBModel objItem = new DocumentDBModel();    
                objItem.DeadLetterReason = "TestReason";    
                objItem.DeadLetterDescription = "TestDescription";   
                objItem.DeadLetterDate = DateTime.Now;    
                objItem.Body = "TestBody";    
                DbSettings objSettings = new DbSettings();    
                objSettings.Uri = "";    
                objSettings.Key = "";    
                objSettings.DatabaseId = "TestDB";    
                objSettings.Collection = "TestCollection";        
                DocumentDBRepository<DocumentDBModel> abc = new  
       DocumentDBRepository<DocumentDBModel>(objSettings);    
                abc.CreateAsync(objItem).Wait();    

但是当我在代码上面运行时,我会遇到异常:

var abc = namespaceManager.GetQueue("").MessageCountDetails;    


<b> Method not found: 'Void System.Runtime.Serialization.DataContractSerializer..ctor(System.Type, System.Collections.Generic.IEnumerable`1<System.Type>, Int32, Boolean, Boolean, System.Runtime.Serialization.IDataContractSurrogate)'.
   at Microsoft.ServiceBus.Messaging.MessagingDescriptionSerializer`1.CreateSerializer[T]()
   at Microsoft.ServiceBus.Messaging.MessagingDescriptionSerializer`1..ctor()
   at Microsoft.ServiceBus.Messaging.ServiceBusResourceOperations.GetAsyncResult`1..ctor(TrackingContext trackingContext, IResourceDescription[] collectionDescriptions, String[] collectionResourceNames, IEnumerable`1 managementAddresses, NamespaceManagerSettings settings, TimeSpan timeout, AsyncCallback callback, Object state)
   at Microsoft.ServiceBus.NamespaceManager.OnBeginGetQueue(String path, AsyncCallback callback, Object state)
   at Microsoft.ServiceBus.NamespaceManager.GetQueue(String path)
   at WebApplication2.Controllers.ValuesController.Get() </b>

请说明这个问题可能是什么原因。 - 列出项目

1 个答案:

答案 0 :(得分:1)

WindowsAzure.ServiceBus所述:

  

请注意,此软件包需要.Net Framework 4.5.2完整配置文件。

此外,我可能会遇到与您在使用WIndowsAzure.ServiceBus 2.1.0时提到的问题相同的问题。另外,我检查了其他版本,但最终失败了。

enter image description here

对于NetCore 2.0,您可以利用.NET Standard client library for Azure Service Bus并引用包Microsoft.Azure.ServiceBus。要检索死信队列,您可以按照此tutorial

  

我的要求是计算azure deadletter。如果计数大于0,那么我必须得到每个死信信息的详细信息,如描述或死信的原因并保存到cosmos db。

我注意到您在WebAPI端点中处理此处理。我建议您注册DeadletterQueue/Program.cs下提到的MessageReceiver.RegisterMessageHandler回调,然后将其作为.NET Core 2.x中的后台任务实现。您可以关注的详细信息here

此外,您可以从Web应用程序中分发此处理。您可以利用WebJob来触发servicebus deadletter队列(例如,特定队列的死信队列名称如下:$"{your-queue-name}/$DeadLetterQueue")并使用DocumentDB绑定将死信队列信息保存到您的cosmos db中。详细信息,您可以参考How to use Azure Service Bus with the WebJobs SDKAzure WebJobs SDK Extensions