Почему RegisterMessageHandler не работает для указанного c topi c имени? - PullRequest
9 голосов
/ 09 марта 2020

Я не понимаю, почему следующий обработчик ( processMessageAsyn c), указанный ниже, не запускается для указанного имени c topi c, но успешно выполняется для других имен topi c :

subscriptionClient.RegisterMessageHandler(processMessageAsync, msgOptions)

Ниже мой подписчик класс:

open System
open System.Linq
open System.Threading
open System.Text
open System.Threading.Tasks
open Microsoft.Azure.ServiceBus

type Subscriber(connectionString:string, topic:string, subscription:string) =

    let mutable subscriptionClient : SubscriptionClient = null

    let exceptionReceivedHandler (args:ExceptionReceivedEventArgs) =
        printfn "Got an exception: %A" args.Exception
        Task.CompletedTask

    let processMessageAsync (message:Message) (_:CancellationToken) = 

        try

            let _ = Encoding.UTF8.GetString(message.Body)
            subscriptionClient.CompleteAsync(message.SystemProperties.LockToken) |> Async.AwaitTask |> Async.RunSynchronously

            Task.CompletedTask

        with
            _ -> Task.CompletedTask

    member x.Listen() =

        async {

            subscriptionClient <- new SubscriptionClient(connectionString, topic, subscription)
            subscriptionClient.OperationTimeout <- TimeSpan.FromMinutes(3.0)

            let! rulesFound     = subscriptionClient.GetRulesAsync() |> Async.AwaitTask
            let  hasDefaultRule = rulesFound.Any(fun r -> r.Name = RuleDescription.DefaultRuleName)

            if hasDefaultRule then
                do! subscriptionClient.RemoveRuleAsync(RuleDescription.DefaultRuleName) |> Async.AwaitTask

            let msgOptions = MessageHandlerOptions(fun args -> exceptionReceivedHandler(args))
            msgOptions.AutoComplete         <- false
            msgOptions.MaxAutoRenewDuration <- TimeSpan.FromMinutes(1.0)
            msgOptions.MaxConcurrentCalls   <- 1

            subscriptionClient.RegisterMessageHandler(processMessageAsync, msgOptions)
        }

    member x.CloseAsync() =

        async {

            do! subscriptionClient.CloseAsync() |> Async.AwaitTask
        }

Вот как я пытаюсь запустить подписчика :

open System
open Subscription.Console

let connectionString = <connection_string>

[<EntryPoint>]
let main argv =

    printfn "Welcome to Subscription.Console"

    let topic,subscription = "Topic.courier-accepted","Subscription.all-messages"
    let subscriber = Subscriber(connectionString, topic, subscription)

    async { do! subscriber.Listen()
          } |> Async.RunSynchronously

    Console.ReadKey() |> ignore

    async { do! subscriber.CloseAsync()
          } |> Async.RunSynchronously

    0 // return an integer exit code 

Следующий код публикует сообщение, которое мой подписчик должен получить (но не получает):

[<Fact>]
let ``Publish courier-accepted to servicebus``() =

    async {

        // Setup
        let  client    = TopicClient(sbConnectionstring, "Topic.courier-accepted")
        let! requestId = requestId()

        let updated = requestId |> modifyRequestId someCourierResponse
        let json    = JsonConvert.SerializeObject(updated)
        let message = Message(Encoding.UTF8.GetBytes(json))

        message.Label <- sprintf "request-id(%s)" (requestId.ToString())

        // Test
        do! client.SendAsync(message) |> Async.AwaitTask

        // Teardown
        do! client.CloseAsync()       |> Async.AwaitTask
    }

ПРИМЕЧАНИЕ:

Что интересно Приведенный выше код заключается в том, что когда у меня Azure Функция работает с ServiceBusTrigger, установленным на тот же topi c и имя подписки, Azure Функция запускается каждый раз, когда я запускаю тест.

  • Я не получаю никаких сообщений об исключениях
  • exceptionReceivedHandler Функция никогда не запускается на моем экземпляре подписчика
  • Я не вижу никаких ошибок пользователя на моем Azure панель инструментов для ресурса сервисной шины

Успешно с другими topi c name

Если я изменю имя topi c на «запрос курьера», то экземпляр подписчика получает сообщения:

[<Fact>]
let ``Publish courier-requested to servicebus topic``() =

    // Setup
    let client    = TopicClient(sbConnectionstring, "Topic.courier-requested")
    let message   = Message(Encoding.UTF8.GetBytes(JsonFor.courierRequest))
    message.Label <- sprintf "courier-id(%s)" "b965f552-31a4-4644-a9c6-d86dd45314c4"

    // Test
    async {

        do! client.SendAsync(message) |> Async.AwaitTask
        do! client.CloseAsync()       |> Async.AwaitTask
    }

Вот подписка с настройкой имени topi c:

[<EntryPoint>]
let main argv =

    printfn "Welcome to Subscription.Console"

    let topic,subscription = "Topic.courier-requested","Subscription.all-messages"
    let subscriber = Subscriber(connectionString, topic, subscription)

    async { do! subscriber.Listen()
          } |> Async.RunSynchronously

    Console.ReadKey() |> ignore

    async { do! subscriber.CloseAsync()
          } |> Async.RunSynchronously

    0 // return an integer exit code

Вот две темы на моем портале Azure: enter image description here

При щелчке по темам на портале результаты разные:

Я заметил, что мне нужно дважды щелкнуть «принято курьером», чтобы просмотреть его подписки. Тем не менее, я могу один раз нажать «Запрос курьера» и сразу же просмотреть его подписки.

1 Ответ

0 голосов
/ 28 марта 2020

Если я правильно понимаю, что вы пытались удалить проблематику c topi c и воссоздать ее, это звучит для меня как сбой в Azure. Вы не должны получить описанное выше поведение, когда нужно щелкнуть дважды. Иногда я создавал вещи в Azure, где-то внизу по течению в их инфраструктуре возникала проблема, и запрос в службу поддержки - единственный способ решить эту проблему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...