首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Service Broker -测量消息在sys.transmission_queue中保留的时间

Service Broker -测量消息在sys.transmission_queue中保留的时间
EN

Stack Overflow用户
提问于 2018-04-10 19:45:52
回答 1查看 292关注 0票数 0

有没有什么办法我可以测量消息在sys.transmission_queue中停留的时间,例如给定时间段的平均值?

EN

回答 1

Stack Overflow用户

发布于 2018-04-12 00:42:54

更多的活动来拯救我们!首先,定义以下会话:

代码语言:javascript
复制
CREATE EVENT SESSION [broker_transmission_queue] ON SERVER 
ADD EVENT sqlserver.broker_dialog_transmission_queue_dequeue,
ADD EVENT sqlserver.broker_dialog_transmission_queue_enqueue
ADD TARGET package0.ring_buffer
GO

让它在service broker工作负载运行时运行一段时间。然后,运行以下查询:

代码语言:javascript
复制
WITH e AS (
    SELECT e.query('.') AS event
    FROM (
        select CAST(dxst.target_data AS XML) AS target_data
        FROM sys.dm_xe_session_targets AS dxst
        JOIN sys.dm_xe_sessions AS dxs
            ON dxst.event_session_address = dxs.address
        WHERE dxs.name = 'broker_transmission_queue'
            AND dxst.target_name = 'ring_buffer'
    ) AS t
    CROSS APPLY t.target_data.nodes('/RingBufferTarget/event') AS tgt(e)
), parsed AS (
    SELECT event.value('(event/data[@name="dialog_id"])[1]', 'uniqueidentifier') AS dialog_id, 
    event.value('(event/data[@name="message_sequence_number"])[1]', 'bigint') AS message_sequence_number,
    event.value('(event/@timestamp)[1]', 'datetime2') AS timestamp,
    event.value('(event/@name)[1]', 'sysname') AS event_name
    FROM e
)
SELECT b.timestamp, e.timestamp, DATEDIFF(MILLISECOND, b.timestamp, e.timestamp )
FROM parsed AS b
JOIN parsed AS e
    ON e.dialog_id = b.dialog_id
    AND e.message_sequence_number = b.message_sequence_number
    AND b.event_name = 'broker_dialog_transmission_queue_enqueue'
    AND e.event_name = 'broker_dialog_transmission_queue_dequeue'

本质上,我们在入队和出队事件之间匹配(conversation_handle,sequence_number)元组。一旦你有了匹配,你就可以做任何你想要的数学运算(计数,平均值,等等)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49752805

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档