我有将消息发送到服务队列的源代码,由于连接时间,其保持失败的问题。此连接时间异常的原因可能是什么?
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Azure.ServiceBus;
namespace AzureServiceBusApplication
{
class Program
{
static IQueueClient queueClient;
static void Main(string[] args)
{
string ServiceBusConnectionString = "Endpoint=sb://enstaservicebus.servicebus.windows.net/;SharedAccessKeyName=RootManageSharedAccessKey;SharedAccessKey=*****=";
string QueueName = "entsaqueuename";
for(int i = 0; i < args.Length; i++)
{
var p = new Program();
if(args[i] == "--ConnectionString")
{
Console.WriteLine($"ConnectionString:{args[i+1]}");
ServiceBusConnectionString = args[i + 1];
}else if(args[i] == "--QueueName")
{
Console.WriteLine($"QueueName:{args[i+1]}");
QueueName = args[i + 1];
}
}
if(ServiceBusConnectionString != "" && QueueName!= "")
{
MainAsync(ServiceBusConnectionString, QueueName).GetAwaiter().GetResult();
}
else
{
Console.WriteLine("Specify - ConnectionString and -QueueName to execute the example");
Console.ReadKey();
}
}
static async Task MainAsync(string ServiceBusConnectionString, string QueueName)
{
const int numberOfMessages = 10;
queueClient = new QueueClient(ServiceBusConnectionString, QueueName);
Console.WriteLine("=====================================================");
Console.WriteLine("Press any key to exit after receiving all the messages");
Console.WriteLine("=======================================================");
RegisterOnMessageHandlerAndReceiverMessages();
await SendMessagesAsync(numberOfMessages);
Console.ReadKey();
}
static void RegisterOnMessageHandlerAndReceiverMessages()
{
var messageHandlerOptions = new MessageHandlerOptions(ExceptionReceiveHandler)
{
MaxConcurrentCalls = 1,
AutoComplete = false
};
queueClient.RegisterMessageHandler(ProcessMessageAsync, messageHandlerOptions);
}
static async Task ProcessMessageAsync(Message message, CancellationToken token)
{
Console.WriteLine($"Received message: SequenceNumber:{message.SystemProperties.SequenceNumber} Body:{Encoding.UTF8.GetString(message.Body)}");
await queueClient.CompleteAsync(message.SystemProperties.LockToken);
}
static Task ExceptionReceiveHandler(ExceptionReceivedEventArgs exceptionReceivedEventArgs)
{
Console.WriteLine("");
var context = exceptionReceivedEventArgs.ExceptionReceivedContext;
Console.WriteLine("Exception context for troubleshooting");
Console.WriteLine($"- Endpoint:{context.Endpoint}");
Console.WriteLine($"- Entitypoint:{context.EntityPath}");
Console.WriteLine($"- Executing Action:{context.Action}");
return Task.CompletedTask;
}
static async Task SendMessagesAsync(int numberOfMessagesToSend)
{
try
{
for(var i = 0; i < numberOfMessagesToSend; i++)
{
string messageBody = $"Message{i}";
var message = new Message(Encoding.UTF8.GetBytes(messageBody));
Console.WriteLine($"Sending message:{messageBody}");
await queueClient.SendAsync(message);
}
}
catch (Exception exception)
{
Console.WriteLine($"{DateTime.Now}:: Exception:{exception.Message}");
}
}
}
}
请随时为我的团队提供帮助,因为我无法确定确切的异常发生位置,并且我进行了一些故障排除。但是在捕获异常后在SendMessageAsycn上将其从正文中抛出,我是否需要deviceExplore来测试是否发送此消息?