AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / dba / 问题 / 144534
Accepted
Michael Cherevko
Michael Cherevko
Asked: 2016-07-22 03:33:13 +0800 CST2016-07-22 03:33:13 +0800 CST 2016-07-22 03:33:13 +0800 CST

使用配置表过滤扩展事件

  • 772

我已经创建了 EE 会话来审核登录,但是我需要过滤掉很多登录。我想知道,是否有比通过 gui\script 将它们一一添加
更好的选择(比如使用不需要的登录名创建 conf.table 并使用这些值进行过滤)。sqlserver.username

sql-server-2014 extended-events
  • 2 2 个回答
  • 457 Views

2 个回答

  • Voted
  1. wBob
    2016-07-22T07:19:01+08:002016-07-22T07:19:01+08:00

    我会说收集信息然后在报告时过滤掉更好,因为那样至少你拥有它。不断更新会话似乎很繁琐,其他人也许可以利用它:“哦,我听说你在跟踪登录,你跟踪登录 X 吗?”

    另外,您是否考虑过使用直方图目标?这可能是一个很好的用例。每个登录将有一个条目,其中包含一个count属性,指示该登录在该扩展事件会话期间登录了多少次。您必须记录扩展事件 (XE) 会话的开始和结束时间才能使其有意义,但这是一个简单的示例:

    IF EXISTS ( SELECT * from sys.server_event_sessions WHERE name = 'xe_watchLogins' )
    DROP EVENT SESSION [xe_watchLogins] ON SERVER 
    GO
    
    CREATE EVENT SESSION [xe_watchLogins] ON SERVER 
    ADD EVENT sqlserver.login ( 
        ACTION ( sqlserver.username ) 
    )
    ADD TARGET package0.histogram ( SET filtering_event_name = N'sqlserver.login', source = N'sqlserver.username' )
    WITH ( MAX_MEMORY = 4096 KB, EVENT_RETENTION_MODE = ALLOW_SINGLE_EVENT_LOSS, MAX_DISPATCH_LATENCY = 30 SECONDS, MAX_EVENT_SIZE = 0 KB, MEMORY_PARTITION_MODE = NONE, TRACK_CAUSALITY = OFF, STARTUP_STATE = OFF )
    GO
    
    
    ALTER EVENT SESSION [xe_watchLogins]
    ON SERVER
    STATE = START;
    GO
    
    /* Sample output from the histogram
    <HistogramTarget truncated="0" buckets="256">
        <Slot count="4">
            <value>someDomain\bob</value>
        </Slot>
        <Slot count="1">
            <value>someSqlUser</value>
        </Slot>
    </HistogramTarget>
    */
    
    SELECT IDENTITY( INT, 1, 1 ) AS rowId, GETDATE() AS dateCreated, CAST( st.target_data AS XML ) XEhistogramData
    INTO #tmp
    FROM sys.dm_xe_sessions s
        INNER JOIN sys.dm_xe_session_targets st ON s.[address] = st.event_session_address 
    WHERE st.target_name = 'histogram' 
      AND s.name = 'xe_watchLogins'
    
    
    -- Optionally create xml index
    ALTER TABLE #tmp ADD PRIMARY KEY ( rowId );
    CREATE PRIMARY XML INDEX _pxmlidx_tmp ON #tmp ( XEhistogramData );
    GO
    
    SELECT
        h.c.value('(value/text())[1]', 'SYSNAME') AS loginName,
        h.c.value('@count', 'INT') AS logins
    FROM #tmp t
        CROSS APPLY t.XEhistogramData.nodes('HistogramTarget/Slot') AS h(c)
    -- WHERE NOT EXISTS ( ... )
    

    在此示例中,直方图默认为 256 个桶或不同的登录名。

    • 1
  2. Best Answer
    spaghettidba
    2016-07-22T05:21:03+08:002016-07-22T05:21:03+08:00

    sqlserver.username IN (SELECT name FROM sometable)不允许使用的过滤器。

    您可以使用动态 SQL 构建过滤器字符串并将其连接到您的CREATE SESSION语句。考虑到值列表的长度是有限制的。我记得那是因为我前段时间尝试过同样的事情,但我不记得限制是多少。

    • 0

相关问题

  • 在 SQL Server 查询中放置 ASSERT

  • 如何在 SQL Server 升级搞砸数据库快照后“hack-drop”它

  • 多语句事务中不允许使用 ALTER DATABASE 语句

  • 默认情况下,我可以从 SQL Server 获取哪些事件信息?

  • 在 SQL Server 2008 中查询扩展事件

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目

    • 12 个回答
  • Marko Smith

    如何让sqlplus的输出出现在一行中?

    • 3 个回答
  • Marko Smith

    选择具有最大日期或最晚日期的日期

    • 3 个回答
  • Marko Smith

    如何列出 PostgreSQL 中的所有模式?

    • 4 个回答
  • Marko Smith

    列出指定表的所有列

    • 5 个回答
  • Marko Smith

    如何在不修改我自己的 tnsnames.ora 的情况下使用 sqlplus 连接到位于另一台主机上的 Oracle 数据库

    • 4 个回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Martin Hope
    Jin 连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane 如何列出 PostgreSQL 中的所有模式? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh 为什么事务日志不断增长或空间不足? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland 列出指定表的所有列 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney MySQL 能否合理地对数十亿行执行查询? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx 如何监控大型 .sql 文件的导入进度? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve