針對擴充事件使用 PowerShell 提供者
您可以使用 SQL Server PowerShell 提供者來管理 SQL Server 擴充事件。 XEvent 子資料夾位於 SQLSERVER 磁碟機底下。 您可以使用下列其中一種方法來存取這個資料夾:
在命令提示字元中,輸入 sqlps,然後按 ENTER。 輸入 cd xevent,然後按 ENTER。 您可以從該處使用 cd 和 dir 命令 (或 Set-Location 和 Get-ChildItem Cmdlet) 巡覽至伺服器名稱和實例名稱。
在物件總管中,展開執行個體名稱、展開 [管理]、以滑鼠右鍵按一下 [擴充事件],然後按一下 [啟動 PowerShell]。 這樣就會在下列路徑中啟動 PowerShell:
PS SQLSERVER:\XEvent\ServerNameInstanceName\
注意
您可以從 [擴充事件] 底下的任何節點啟動 PowerShell。 例如,您可以用滑鼠右鍵按一下 [工作階段],然後按一下 [啟動 PowerShell]。 這樣就會在下一個層級 (Sessions 資料夾) 啟動 PowerShell。
您可以瀏覽 XEvent 資料夾樹狀目錄來檢視現有的擴充事件工作階段及其相關聯的事件、目標和述詞。 例如,在 PS SQLSERVER:\XEvent\ServerNameInstanceName\ 路徑中,如果您輸入 cd sessions、按下 ENTER、輸入 >,然後再按下 ENTER,就可以查看儲存在該執行個體上的工作階段清單。 您也可以檢視工作階段是否正在執行 (如果有,執行的時間長度),以及工作階段是否設定為在執行個體啟動時啟動。
若要檢視與工作階段相關聯的事件、其述詞和目標,您可以將目錄變更為工作階段名稱,然後檢視 events 或 targets 資料夾。 例如,若要檢視與預設系統健康情況工作階段相關聯的事件及其述詞,請在 PS SQLSERVER:\XEvent\ServerNameInstanceName\Sessions\ 路徑中,輸入 cd system_health\events、按下 ENTER、輸入 >,然後按下 ENTER。
SQL Server PowerShell 提供者是一項功能強大的工具,可讓您用來建立、改變和管理擴充事件工作階段。 下列章節將提供使用 PowerShell 指令碼搭配擴充事件的一些基本範例。
範例
在下列範例中,請注意:
您必須從 PS SQLSERVER:\> 提示字元 (在命令提示字元中輸入 sqlps 即可使用) 執行這些指令碼。
這些指令碼會使用預設 SQL Server 執行個體。
您必須使用 .ps1 副檔名來儲存這些指令碼。
PowerShell 執行原則必須允許指令碼執行。 若要設定執行原則,請使用 Set-Executionpolicy Cmdlet。 (如需詳細資訊,請輸入 get-help set-executionpolicy -detailed,然後按 ENTER。)
下列指令碼會建立名為 'TestSession' 的新工作階段。
#Script for creating a session.
cd XEvent
$h = hostname
cd $h
#Use the default instance.
$store = dir | where {$_.DisplayName -ieq 'default'}
$session = new-object Microsoft.SqlServer.Management.XEvent.Session -argumentlist $store, "TestSession"
$event = $session.AddEvent("sqlserver.file_written")
$event.AddAction("package0.callstack")
$session.Create()
下列指令碼會將信號緩衝區目標加入至您在上一則範例中建立的工作階段 (這個範例會顯示 Alter 方法的使用方式。請注意,第一次建立工作階段時,您就可以新增目標。)
#Script to alter a session.
cd XEvent
$h = hostname
cd $h
cd DEFAULT\Sessions
#Used to find the specified session.
$session = dir|where {$_.Name -eq 'TestSession'}
#Add the ring buffer target and call the Alter method.
$session.AddTarget("package0.ring_buffer")
$session.Alter()
下列指令碼會建立使用述詞運算式的新工作階段。 在此情況下,工作階段會收集何時寫入 c:\temp.log 檔案 (透過 sqlserver.file_written 事件) 的相關資訊。
#Script for creating a session.
cd XEvent
$h = hostname
cd $h
#Use the default instance.
$store = dir | where {$_.DisplayName -ieq 'default'}
$session = new-object Microsoft.SqlServer.Management.XEvent.Session -argumentlist $store, "TestSession2"
$event = $session.AddEvent("sqlserver.file_written")
#Construct a predicate "equal_i_unicode_string(path, N'c:\temp.log')".
$column = $store.SqlServerPackage.EventInfoSet["file_written"].DataEventColumnInfoSet["path"]
$operand = new-object Microsoft.SqlServer.Management.XEvent.PredOperand -argumentlist $column
$value = new-object Microsoft.SqlServer.Management.XEvent.PredValue -argumentlist "c:\temp.log"
$compare = $store.Package0Package.PredCompareInfoSet["equal_i_unicode_string"]
$predicate = new-object Microsoft.SqlServer.Management.XEvent.PredFunctionExpr -argumentlist $compare, $operand, $value
$event.SetPredicate($predicate)
$session.Create()
安全性
若要建立、更改或卸除擴充事件工作階段,您必須擁有 ALTER ANY EVENT SESSION 權限。