Invoke-PolicyEvaluation cmdlet 사용
Invoke-PolicyEvaluation은 SQL Server 개체의 대상 집합이 하나 이상의 정책 기반 관리 정책에 지정되는 조건을 준수하는지 여부를 보고하는 SQL Server Windows PowerShell cmdlet에 대한 명령 셸입니다.
Invoke-PolicyEvaluation 사용
Invoke-PolicyEvaluation은 대상 집합이라는 SQL Server 개체 집합에 대해 하나 이상의 정책을 평가합니다. 대상 개체 집합은 대상 서버에서 가져옵니다. 각 정책은 대상 개체의 허용 상태인 조건을 정의합니다. 예를 들어 Trustworthy 데이터베이스 정책은 TRUSTWORTHY 데이터베이스 속성을 OFF로 설정해야 한다고 나타냅니다.
-AdHocPolicyEvaluationMode 매개 변수는 수행한 동작을 지정합니다.
확인
현재 로그인의 자격 증명을 사용하여 대상 개체의 준수 상태를 보고합니다. 개체를 다시 구성하지 않습니다. 이 값은 기본 설정입니다.CheckSqlScriptAsProxy
##MS_PolicyTSQLExecutionLogin## 프록시 로그인의 자격 증명을 사용하여 대상 개체의 준수 상태를 보고합니다. 개체를 다시 구성하지 않습니다.구성
현재 로그인의 자격 증명을 사용하여 대상 개체의 준수 상태를 보고합니다. 정책을 준수하지 않는 설정할 수 있는 모든 결정적 옵션을 다시 구성합니다.
정책 지정
정책을 지정하는 방법은 정책 저장 위치에 따라 달라집니다. 정책은 다음 두 가지 형식으로 저장될 수 있습니다.
정책은 데이터베이스 엔진 인스턴스와 같은 정책 저장소에 저장되는 개체일 수 있습니다. SQLSERVER:\SQLPolicy 폴더를 사용하여 정책 저장소에서 정책 위치를 지정할 수 있습니다. Where-Object를 사용하여 정책 범주에 대해 필터링하거나 Get-Item을 사용하여 정책 이름에 대해 필터링하는 경우와 같이 Windows PowerShell cmdlet을 사용하여 입력 정책을 해당 속성을 기반으로 필터링할 수 있습니다.
정책을 XML 파일로 내보낼 수 있습니다. D:와 같은 파일 시스템 드라이브를 사용하여 XML 파일의 위치를 지정할 수 있습니다. Where-Object와 같은 Windows PowerShell cmdlet을 사용하여 정책을 파일 이름과 같은 해당 파일 속성을 기반으로 필터링할 수 있습니다.
정책이 정책 저장소에 저장되는 경우 평가할 정책을 가리키는 PSObjects 집합을 전달해야 합니다. 이는 일반적으로 Get-Item과 같은 cmdlet 출력을 Invoke-PolicyEvaluation으로 파이프하여 수행되며 -Policy 매개 변수를 지정할 필요가 없습니다. 예를 들어 Microsoft Best Practices 정책을 데이터베이스 엔진 인스턴스로 가져온 경우 이 명령은 데이터베이스 상태 정책을 평가합니다.
sl "SQLSERVER:\SQLPolicy\MyComputer\DEFAULT\Policies"
Get-Item "Database Status" | Invoke-PolicyEvaluation -TargetServerName "MYCOMPUTER"
이 예에서는 Where-Object를 사용하여 정책 저장소의 여러 정책을 해당 PolicyCategory 속성을 기반으로 필터링하는 방법을 보여 줍니다. Where-Object의 파이프된 출력에서 가져온 개체가 Invoke-PolicyEvaluation에서 사용됩니다.
sl "SQLSERVER:\SQLPolicy\MyComputer\DEFAULT\Policies"
cgi | Where-Object {$_.PolicyCategory -eq "Microsoft Best Practices: Maintenance"} | Invoke-PolicyEvaluation -TargetServer "MYCOMPUTER"
정책이 XML 파일로 저장되는 경우 -Policy 매개 변수를 사용하여 각 정책에 대한 경로와 이름을 모두 제공해야 합니다. -Policy 매개 변수에 경로를 지정하지 않으면 Invoke-PolicyEvaulation에서 sqlps 경로의 현재 설정을 사용합니다. 예를 들어 이 명령은 SQL Server와 함께 설치된 Microsoft Best Practice 정책 중 하나를 로그인의 기본 데이터베이스에 대해 평가합니다.
Invoke-PolicyEvaluation -Policy "C:\Program Files\Microsoft SQL Server\100\Tools\Policies\DatabaseEngine\1042\Database Status.xml" -TargetServerName "MYCOMPUTER"
이 명령은 동일한 작업을 수행하며 현재 sqlps 경로만 사용하여 정책 XML 파일의 위치를 설정합니다.
sl "C:\Program Files\Microsoft SQL Server\100\Tools\Policies\DatabaseEngine\1042"
Invoke-PolicyEvaluation -Policy "Database Status.xml" -TargetServerName "MYCOMPUTER"
이 예에서는 Get-ChildItem cmdlet을 사용하여 여러 정책 XML 파일을 검색하고 개체를 Invoke-PolicyEvaluation으로 파이프하는 방법을 보여 줍니다.
sl "C:\Program Files\Microsoft SQL Server\100\Tools\Policies\DatabaseEngine\1042"
cgi "Database Status.xml", "Trustworthy Database.xml" | Invoke-PolicyEvaluation -TargetServer "MYCOMPUTER"
대상 집합 지정
다음 3개의 매개 변수를 사용하여 대상 개체 집합을 지정할 수 있습니다.
-TargetServerName은 대상 개체를 포함하는 SQL Server 인스턴스를 지정합니다. 정보를 SQLConnection 클래스의 ConnectionString 속성에 대해 정의된 형식을 사용하는 문자열에 지정할 수 있습니다. SqlConnectionStringBuilder 클래스를 사용하여 올바른 형식의 연결 문자열을 작성할 수 있습니다. 또한 SqlStoreConnection 개체를 만든 다음 -TargetServer에 전달할 수 있습니다. 서버 이름만 포함하는 문자열을 제공하는 경우 Invoke-PolicyEvaluation에서는 Windows 인증을 사용하여 서버에 연결합니다.
-TargetObjects는 대상 집합의 SQL Server 개체를 나타내는 개체 배열 또는 개체를 가져옵니다. 예를 들어 Database 클래스 개체의 배열을 만들어 -TargetObjects에 전달할 수 있습니다.
-TargetExpressions는 대상 집합의 개체를 지정하는 쿼리 식을 포함하는 문자열을 가져옵니다. 쿼리 식은 '/' 문자로 구분된 노드 형식입니다. 각 노드의 형식은 ObjectType[Filter]입니다. 개체 유형은 SMO(SQL Server Management Object) 개체 계층의 개체 중 하나입니다. 필터는 해당 노드에 있는 개체에 대해 필터링하는 식입니다. 자세한 내용은 쿼리 식 및 Unique Resource Names을 참조하십시오.
-TargetObjects 또는 -TargetExpression 중 하나를 지정하거나 둘 다 지정합니다.
이 예에서는 Sfc.SqlStoreConnection 개체를 사용하여 대상 서버를 지정합니다.
sl "C:\Program Files\Microsoft SQL Server\100\Tools\Policies\DatabaseEngine\1042"
$conn = New-Object Microsoft.SqlServer.Management.Sdk.Sfc.SqlStoreConnection("server='MYCOMPUTER';Trusted_Connection=True")
Invoke-PolicyEvaluation -Policy "Database Status.xml" -TargetServerName $conn
이 예에서는 -TargetExpression을 사용하여 평가할 특정 데이터베이스를 식별합니다.
sl "C:\Program Files\Microsoft SQL Server\100\Tools\Policies\DatabaseEngine\1042"
Invoke-PolicyEvaluation -Policy "Database Status.xml" -TargetServerName "MyComputer" -TargetExpression "Server[@Name='MYCOMPUTER']/Database[@Name='AdventureWorks']"
Analysis Services 정책 평가
Analysis Services 인스턴스에 대해 정책을 평가하려면 어셈블리를 로드하여 sqlps에 등록하고, Analysis Services 연결 개체를 사용하여 변수를 만들고, 변수를 -TargetObject 매개 변수에 전달해야 합니다. 이 예에서는 Analysis Services에 대한 최선의 구현 방법 노출 영역 구성 정책을 평가하는 방법을 보여 줍니다.
sl "C:\Program Files\Microsoft SQL Server\100\Tools\Policies\AnalysisServices\1042"
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.AnalysisServices")
$SSASsvr = new-object Microsoft.AnalysisServices.Server
$SSASsvr.Connect("Data Source=Localhost")
Invoke-PolicyEvaluation -Policy "Surface Area Configuration for Analysis Services Features.xml" -TargetObject $SSASsvr
Reporting Services 정책 평가
Reporting Services 정책을 평가하려면 어셈블리를 로드하여 sqlps에 등록하고, Reporting Services 연결 개체를 사용하여 변수를 만들고, 변수를 -TargetObject 매개 변수에 전달해야 합니다. 이 예에서는 Reporting Services에 대한 최선의 구현 방법 노출 영역 구성 정책을 평가하는 방법을 보여 줍니다.
sl "C:\Program Files\Microsoft SQL Server\100\Tools\Policies\ReportingServices\1042"
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SqlServer.Dmf.Adapters")
$SSRSsvr = new-object Microsoft.SqlServer.Management.Adapters.RSContainer('MyComputer')
Invoke-PolicyEvaluation -Policy "Surface Area Configuration for Reporting Services 2008 Features.xml" -TargetObject $SSRSsvr
출력의 형식 지정
기본적으로 Invoke-PolicyEvaluation 출력은 사람이 읽을 수 있는 형식의 간략한 보고서로 명령줄 프롬프트 창에 표시됩니다. -OutputXML 매개 변수를 사용하여 cmdlet에서 대신 XML 파일 형식의 세부 보고서를 생성하도록 지정할 수 있습니다. Invoke-PolicyEvaluation은 SML-IF 판독기에서 파일을 읽을 수 있도록 SML-IF(Systems Modeling Language Interchange Format) 스키마를 사용합니다.
sl "SQLSERVER:\SQLPolicy\MyComputer\DEFAULT\Policies"
Invoke-PolicyEvaluation -Policy "Datbase Status" -TargetServer "MYCOMPUTER" -OutputXML > C:\MyReports\DatabaseStatusReport.xml