開啓兩個相同trace引起的性能問題

  當我們需要對數據庫操作進行監控時,我們可以採用t-sql或profiler進行監控。profiler可以提供圖形界面,但耗用資源也多。採用t-sql方式,可以將捕獲到的事件記錄到.trc文件中。<br />  mssqlserver2005中,可以採用sp_trace_create建立一個trace,同時通過sp_trace_setevent 指定需要監控的事件及事件列,並通過sp_trace_setfilter指定篩選條件,從而實現profiler一樣的監控。<br />  我們在用t-sql的方式啓動一個trace時,必須先關閉掉原有的採用profiler方式的監控,否則兩個相同的trace一起運行,且這兩個trace都包含篩選條件時,將在幾分鐘內引用cpu性能問題,即cpu的綜合使用率高居100%,從而導致整個系統癱瘓.<br /> 
  但監控事件相同,一個含有篩選條件,一個不含有篩選條件時,不會產生cpu性能問題,所以mssqlserver2005 sp3在多個相同trace的運行應該並沒有優化,從而造成性能問題 。

 

  以下爲自建trace腳本,用於監控事件:20 audit login failed,12 SQL: batch completed,10 RPC:Completed

  當同時運行以下兩個trace時,cpu將出現的性能問題,所以在開啓一個trace時,注意是否已存在一個相同的trace.

  以下爲cpu綜合使用記錄,由40%直至提高到96%: 

record_id  EventTime  CPU%  SystemIdle   OtherProcessUtilization

         7   2009-06-01 14:52:34.480   99   0
         6   2009-06-01 14:53:34.473   97   0

   5   2009-06-01 14:52:34.470   87   9 4
   4   2009-06-01 14:51:34.463   96   0 4
   3   2009-06-01 14:50:34.447   83   13 4
   2   2009-06-01 14:49:34.443   50   47 3
   1  2009-06-01 14:48:34.440    40   57 3

  


 

    代碼:

 USE [LCHSTUDY]
GO

--trace屬性配置表

CREATE TABLE [dbo].[trace_confg](
 [directory] [nvarchar](200) NULL,
 [options] [int] NULL,
 [maxfileSize] [bigint] NULL,
 [filecount] [int] NULL,
 [traceID] [int] NULL
) ON [PRIMARY]

 

--sp:spb_trace_createAndRun
/****** Object:  StoredProcedure [dbo].[spb_trace_createAndRun]    Script Date: 06/01/2009 16:16:03 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE  PROCEDURE [dbo].[spb_trace_createAndRun]       
AS       
DECLARE @traceID int   
,@tracefile  nvarchar(200)   
,@options  int   
,@maxfileSize  bigint   
,@filecount  int   
declare @retcode int   
   
--讀trace配置表   
SELECT TOP 1 @tracefile=directory,@options=options   
  ,@maxfileSize=maxfileSize,@filecount=filecount    
FROM trace_confg   
   
IF @tracefile IS NULL   
  BEGIN    
    PRINT 'ERROR: 表TRACE_CONFG未配置,無法生成trace'   
    RETURN 2   
   END    
IF @maxfileSize IS NULL OR @maxfileSize=0   
set @maxfilesize = 2    
IF CAST(@filecount AS INT)<=0 or CAST(@filecount AS INT) >100   
 set @filecount=40   
   
--生成tracefile名稱:'實例名'+'-lchstudy'   
SELECT @tracefile=@tracefile+'/'+REPLACE(@@SERVERNAME,'/','-')+'-lchstudy'   
SELECT @tracefile=replace(@tracefile,'//','/')   
--print @tracefile   
   
--據配置表建立一個trace    
exec @retcode=sp_trace_create  @traceid=@traceID output   
        ,@optins=@options   
        ,@trace_file=@tracefile --N'e:/lch_test/traceFiles/120.trc'   
        ,@maxfile=@maxfileSize,@stoptime=NULL   
        ,@filecount=@filecount    
IF(@retcode!=0)   
  BEGIN        
    PRINT 'ERROR:無法建立trace,ErrorCode:'+CAST(@retcode AS INT)   
    return @retcode --error   
  END   
   
--增加監控事件及列 Set the events   
declare @on bit   
set @on = 1   
exec sp_trace_setevent @TraceID, 20, 8, @on   
exec sp_trace_setevent @TraceID, 20, 12, @on   
exec sp_trace_setevent @TraceID, 20, 1, @on   
exec sp_trace_setevent @TraceID, 20, 9, @on   
exec sp_trace_setevent @TraceID, 20, 6, @on   
exec sp_trace_setevent @TraceID, 20, 10, @on   
exec sp_trace_setevent @TraceID, 20, 14, @on   
exec sp_trace_setevent @TraceID, 20, 11, @on   
exec sp_trace_setevent @TraceID, 10, 15, @on   
exec sp_trace_setevent @TraceID, 10, 8, @on   
exec sp_trace_setevent @TraceID, 10, 16, @on   
exec sp_trace_setevent @TraceID, 10, 1, @on   
exec sp_trace_setevent @TraceID, 10, 9, @on   
exec sp_trace_setevent @TraceID, 10, 17, @on   
exec sp_trace_setevent @TraceID, 10, 10, @on   
exec sp_trace_setevent @TraceID, 10, 18, @on   
exec sp_trace_setevent @TraceID, 10, 11, @on   
exec sp_trace_setevent @TraceID, 10, 12, @on   
exec sp_trace_setevent @TraceID, 10, 13, @on   
exec sp_trace_setevent @TraceID, 10, 6, @on   
exec sp_trace_setevent @TraceID, 10, 14, @on   
exec sp_trace_setevent @TraceID, 12, 15, @on   
exec sp_trace_setevent @TraceID, 12, 8, @on   
exec sp_trace_setevent @TraceID, 12, 16, @on   
exec sp_trace_setevent @TraceID, 12, 1, @on   
exec sp_trace_setevent @TraceID, 12, 9, @on   
exec sp_trace_setevent @TraceID, 12, 17, @on   
exec sp_trace_setevent @TraceID, 12, 6, @on   
exec sp_trace_setevent @TraceID, 12, 10, @on   
exec sp_trace_setevent @TraceID, 12, 14, @on   
exec sp_trace_setevent @TraceID, 12, 18, @on   
exec sp_trace_setevent @TraceID, 12, 11, @on   
exec sp_trace_setevent @TraceID, 12, 12, @on   
exec sp_trace_setevent @TraceID, 12, 13, @on   
   
-- Set the Filters   
declare @intfilter int   
declare @bigintfilter bigint   
exec sp_trace_setfilter @TraceID, 1, 0, 7, N'%insert bulk CounterData%'   
exec sp_trace_setfilter @TraceID, 1, 0, 7, N'%update DisplayToID%'   
exec sp_trace_setfilter @TraceID, 1, 0, 7, N'%sp_MSget_repl_commands%'   
exec sp_trace_setfilter @TraceID, 1, 0, 7, N'%sp_MShelp_distribution_agentid%'   
exec sp_trace_setfilter @TraceID, 1, 0, 7, N'%sp_MSget_subscription_guid%'   
exec sp_trace_setfilter @TraceID, 1, 0, 7, N'%sp_MSsubscription_status%'   
exec sp_trace_setfilter @TraceID, 10, 0, 7, N'%SQL Server Profiler%'   
exec sp_trace_setfilter @TraceID, 10, 0, 7, N'%repl%'   
exec sp_trace_setfilter @TraceID, 10, 0, 7, N'%sqlagent%'   
exec sp_trace_setfilter @TraceID, 10, 0, 7, N'%Activitymanager%'   
exec sp_trace_setfilter @TraceID, 10, 0, 7, N'%SQL Litespeed%' 
exec sp_trace_setfilter @TraceID, 10, 0, 7, N'Queue Reader Main (distribution)' 
exec sp_trace_setfilter @TraceID, 10, 0, 7, N'Queue Reader History (distribution)' 
exec sp_trace_setfilter @TraceID, 11, 0, 7, N'xx%'   
exec sp_trace_setfilter @TraceID, 11, 0, 7, N'yy%'   
exec sp_trace_setfilter @TraceID, 11, 0, 7, N'user1'   
exec sp_trace_setfilter @TraceID, 11, 0, 7, N'user2'    
exec sp_trace_setfilter @TraceID, 11, 0, 7, N'user3'      
exec sp_trace_setfilter @TraceID, 11, 0, 7, N'user4'    

   
--啓動trace   
exec sp_trace_setstatus @TraceID, 1   
   
--將新建立的traceID記錄到trace配置表   
update trace_confg set traceid=@traceid     
   
select  @TraceID AS 'TRACE_ID'   
return 0   

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章