Почему RegisterMessageHandler не работает для определенного имени темы?


9

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

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, для которой заданы одинаковые тема и имя подписки, эта функция Azure запускается при каждом запуске теста.

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

Успешно с другим названием темы

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

[<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
    }

Вот подписка с настройкой названия темы:

[<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: введите описание изображения здесь

Нажатие темы в портале имеет разные результаты:

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


1
I don't receive any exception messagesМожет, потому что ты проглатываешь исключения? Я вижу with _блок после tryодного
user1623521

Я обнаружил исключение после того, как создал дополнительную подписку для темы, принятой курьером, запустил подписчика со значением подписки, совпадающим с тем, которое я только что зарегистрировал на портале, а затем удалил недавно созданную подписку, пока подписчик еще работает.
Скотт Нимрод

Я не могу воспроизвести вашу проблему на моей стороне, похоже, вы встретили ненормальное поведение на портале служебной шины. Может быть, вы могли бы отправить билет поддержки в команду SB.
Джей Гонг

Я отправил билет вчера.
Скотт Нимрод

Ответы:


0

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

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.