异常连接尝试失败,因为一段时间后连接方未正确响应

时间:2019-09-20 09:12:54

标签: azureservicebus azure-servicebus-queues

我有将消息发送到服务队列的源代码,由于连接时间,其保持失败的问题。此连接时间异常的原因可能是什么?

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来测试是否发送此消息?

0 个答案:

没有答案