How to find the TLS used for the SQL Server connection

打印 上一主题 下一主题

主题 869|帖子 869|积分 2617

本文是How to find the TLS used for the SQL Server connection这篇英语文章的翻译,此文出处请见于文章底部链接:原文出处[1]
对于客户,我做了一些研究,如何找出SQL Server数据库会话连接使用了哪一种TLS协议。唯一的方式就是创建一个扩展事件,这个扩展事件有一个很大的限制就是只有SQL Server 2016或以后的版本才有。之前的版本必须使用内置诊断(BID)跟踪。
使用SQL Server 2016的查询窗口创建一个TLS监控事件之后
  1. CREATE EVENT SESSION [TLS_monitoring] ON SERVER
  2.  
  3.              ADD EVENT sqlsni.sni_trace(
  4.  
  5.              WHERE ([sqlserver].[equal_i_sql_ansi_string]([function_name],'Ssl::Handshake') AND [sqlserver].[like_i_sql_unicode_string](,N'%TLS%')))
  6.  
  7.              ADD TARGET package0.event_file(SET filename=N'TLS_Monitoring')
  8.  
  9.              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);
复制代码
这个扩展事件运行的很正常,我得到了一些使用TLS 1.0和TLS 1.2的会话连接结果。
之后,我想在SQL Server 2019实例上也测试验证一下,我得到了下面错误:
Msg 25623, Level 16, State 1, Line 1The event name, “sqlsni.trace”, is invalid, or the object could not be found
经过google搜索后,我发现,在SQL Server 2019中,扩展事件sqlsni.trace已经被sqlsni.sni_trace给替换了。我修改了我的脚本,下面是在SQL Server 2019下运行的脚本
  1. CREATE EVENT SESSION [TLS_monitoring] ON SERVER
  2.  
  3.              ADD EVENT sqlsni.sni_trace(
  4.  
  5.              WHERE ([sqlserver].[equal_i_sql_ansi_string]([function_name],'Ssl::Handshake') AND [sqlserver].[like_i_sql_unicode_string](,N'%TLS%')))
  6.  
  7.              ADD TARGET package0.event_file(SET filename=N'TLS_Monitoring')
  8.  
  9.              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);
复制代码
在我和客户讨论过后,他要求我在每个可用扩展事件(准确的表达应该是可以使用sqlsni.trace扩展事件)的SQL Server服务器上部署这个脚本,以便在每个SQL Server上都可以用。我编写了下面这个SQL脚本,可以通过CMS在SQL Server 2014以后版本上安装部署
  1. -- Create SQL Server extended event to monitor TLS
  2.  
  3. -- Before SQL 2016, the Trace extended event is not implemented for the SNI layer. For SQL Server 2014 or 2012, you must use Built-In Diagnostics (BID) traces
  4.  
  5. IF (( CAST(SERVERPROPERTY('ProductMajorVersion') AS INT)   13))
  6.  
  7.        BEGIN
  8.  
  9.  -- Before SQL Server 2019 and after SQL Server 2016
  10.  
  11.              CREATE EVENT SESSION [TLS_monitoring] ON SERVER
  12.  
  13.              ADD EVENT sqlsni.trace(
  14.  
  15.              WHERE ([sqlserver].[equal_i_sql_ansi_string]([function_name],'Ssl::Handshake') AND [sqlserver].[like_i_sql_unicode_string](,N'%TLS%')))
  16.  
  17.              ADD TARGET package0.event_file(SET filename=N'TLS_Monitoring')
  18.  
  19.              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);
  20.  
  21.        END
  22.  
  23. ELSE
  24.  
  25.        BEGIN
  26.  
  27.  -- SQL Server 2019 and more
  28.  
  29.       CREATE EVENT SESSION [TLS_monitoring] ON SERVER
  30.  
  31.              ADD EVENT sqlsni.sni_trace(
  32.  
  33.              WHERE ([sqlserver].[equal_i_sql_ansi_string]([function_name],'Ssl::Handshake') AND [sqlserver].[like_i_sql_unicode_string](,N'%TLS%')))
  34.  
  35.              ADD TARGET package0.event_file(SET filename=N'TLS_Monitoring')
  36.  
  37.              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); 
  38.        END
  39.  
  40.  
  41.  
  42.  
  43. ALTER EVENT SESSION [TLS_monitoring] ON SERVER  STATE = START ;
  44.  
  45. GO
复制代码
我希望最后这个脚本可以帮助你找出TLS连接类型。
参考资料

[1] 原文出处: https://www.dbi-services.com/blog/how-to-find-the-tls-used-for-the-sql-server-connection/
扫描上面二维码关注我如果你真心觉得文章写得不错,而且对你有所帮助,那就不妨帮忙“推荐"一下,您的“推荐”和”打赏“将是我最大的写作动力!本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接.
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

篮之新喜

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表