當我們需要對數據庫操作進行監控時,我們可以採用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