簡體   English   中英

如何在SQL Service Broker中監視消息的使用期限?

[英]How do I monitor the age of messages in SQL Service Broker?

我有一個SQL Server 2008 Service Broker隊列,該隊列通過調用CLR存儲過程來處理消息(該存儲過程又通過HTTP將消息傳輸到第三方的REST API)。 我需要了解“如何備份?” 或“落后多遠?” 這個隊列是。 雖然我知道隊列中的消息總數可以很好地指示進度,但是我感興趣的是“隊列中等待處理的最近處理的消息等待了多長時間?” 盡我所知,從隊列中進行選擇會為您提供其中的所有消息,但不會給出消息的期限。 例如:

SELECT TOP 100 *, casted_message_body = 
CASE message_type_name WHEN 'X' 
  THEN CAST(message_body AS NVARCHAR(MAX)) 
  ELSE message_body 
END 
FROM [SyncReadTargetQueue] WITH(NOLOCK)

但是,沒有任何列指示年齡。

有任何想法嗎?

要獲取消息到達的時間,您可以在sys.conversation_endpoints中使用“ security_timestamp”。

如何監控服務經紀人-也許會有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM