SQL Server 프로파일러
SQL Server 프로파일러는 추적을 작성 및 관리하고 추적 결과를 분석 및 재생하기 위한 풍부한 인터페이스입니다. 이벤트는 추적 파일에 저장되며 나중에 문제를 진단하려고 할 때 이 파일을 분석하거나 이 파일을 사용하여 특정 단계를 재생할 수 있습니다.
중요 |
---|
Microsoft는 향후 데이터베이스 엔진 추적 캡처 및 추적 재생에 SQL Server 프로파일러를 사용하지 않을 것임을 발표하고 있습니다. 이러한 기능은 다음 버전의 SQL Server에서는 지원되지만 이후 버전에서 제거될 예정입니다. 어떤 버전의 SQL Server에서 제거될지는 결정되지 않았습니다. Microsoft SQL Server 추적 및 재생 개체를 포함하는 Microsoft.SqlServer.Management.Trace 네임스페이스도 더 이상 사용되지 않을 예정입니다. Analysis Services 작업에는 SQL Server 프로파일러가 계속 사용되며 지원됩니다. 다음 표에서는 SQL Server 2012에서 추적 데이터를 캡처하고 재생하는 데 사용할 수 있는 권장 기능을 보여 줍니다. |
기능\대상 작업 |
관계형 엔진 |
Analysis Services |
추적 캡처 |
SQL Server Management Studio의 확장 이벤트 그래픽 사용자 인터페이스 |
SQL Server 프로파일러 |
추적 재생 |
Distributed Replay |
SQL Server 프로파일러 |
SQL Server Profiler의 이점
Microsoft SQL Server 프로파일러는 데이터베이스 엔진 또는 Analysis Services의 인스턴스를 모니터링하기 위한 SQL 추적에 대한 그래픽 사용자 인터페이스입니다. 각 이벤트에 대한 데이터를 캡처하고 파일이나 테이블에 저장하여 나중에 분석할 수 있습니다. 예를 들어 프로덕션 환경을 모니터링하여 어느 저장 프로시저가 너무 늦게 실행되어 성능을 떨어뜨리고 있는지 볼 수 있습니다. SQL Server 프로파일러는 다음과 같은 작업에 사용됩니다.
문제가 발생한 원인을 찾기 위해 문제 쿼리 실행
실행이 느린 쿼리를 찾고 진단
문제가 발생한 일련의 Transact-SQL 문 포착. 그런 다음 저장된 추적을 사용하여, 문제를 진단할 수 있는 테스트 서버에서 문제를 복제할 수 있습니다.
SQL Server의 성능을 모니터링하여 작업 튜닝. 데이터베이스 작업에 맞게 물리적 데이터베이스 디자인을 튜닝하는 방법은 데이터베이스 엔진 튜닝 관리자를 참조하십시오.
문제 진단을 위해 성능 카운터의 상관 관계 지정
또한 SQL Server 프로파일러는 SQL Server의 인스턴스에서 수행되는 동작을 감사하는 기능을 지원합니다. 감사는 보안 관리자가 나중에 검토할 수 있도록 보안 관련 동작을 기록합니다.
SQL Server Profiler 개념
SQL Server 프로파일러 도구를 사용하려면 도구가 작동하는 방식을 설명하는 용어를 알고 있어야 합니다.
[!참고]
SQL Server 프로파일러를 사용할 때 SQL 추적을 이해하면 도움이 됩니다. 자세한 내용은 SQL 추적을 참조하십시오.
이벤트
이벤트는 SQL Server 데이터베이스 엔진 인스턴스에서 발생하는 동작으로, 이벤트의 예는 다음과 같습니다.로그인 연결, 실패 및 연결 끊김
Transact-SQL SELECT, INSERT, UPDATE, DELETE 문
RPC(원격 프로시저 호출) 일괄 처리 상태
저장 프로시저의 시작 또는 끝
저장 프로시저에 있는 문의 시작 또는 끝
SQL 일괄 처리의 시작 또는 끝
SQL Server 오류 로그에 쓴 오류
데이터베이스 개체에서 획득 또는 해제된 잠금
열린 커서
보안 권한 검사
한 이벤트에 의해 생성된 모든 데이터는 추적에서 한 줄에 표시됩니다. 이 행은 이벤트를 자세히 설명하는 데이터 열로 구분됩니다.
이벤트클래스
이벤트 클래스는 추적할 수 있는 이벤트 유형입니다. 이벤트 클래스에는 이벤트에서 보고할 수 있는 모든 데이터가 포함됩니다. 이벤트 클래스의 예는 다음과 같습니다.SQL:BatchCompleted
Audit Login
Audit Logout
Lock:Acquired
Lock:Released
이벤트범주
이벤트 범주는 SQL Server 프로파일러 내에서 이벤트를 그룹화하는 방법을 정의합니다. 예를 들어 모든 잠금 이벤트 클래스는 Locks 이벤트 범주 내에서 그룹화됩니다. 그러나 이벤트 범주는 SQL Server 프로파일러 내에서만 존재합니다. 이 용어는 엔진 이벤트를 그룹화하는 방법과 관계가 없습니다.데이터열
데이터 열은 추적에 캡처된 이벤트 클래스의 특성입니다. 이벤트 클래스가 수집할 수 있는 데이터 형식을 결정하기 때문에 모든 데이터 열이 모든 이벤트 클래스에 적용되는 것은 아닙니다. 예를 들어 Lock:Acquired 이벤트 클래스를 캡처하는 추적에서 BinaryData 데이터 열에는 잠긴 페이지 ID 값이나 행 값이 들어 있지만 캡처하는 이벤트 클래스에 적용할 수 없는 Integer Data 데이터 열에는 아무 값도 들어 있지 않습니다.템플릿
템플릿은 추적의 기본 구성을 정의합니다. 특히 SQL Server 프로파일러로 모니터링하려는 이벤트 클래스가 템플릿에 포함됩니다. 예를 들어 사용할 이벤트, 데이터 열 및 필터를 지정하는 템플릿을 만들 수 있습니다. 템플릿은 실행되지 않으며 .tdf 확장명을 가진 파일로 저장됩니다. 템플릿을 저장한 후에는 템플릿에 기반한 추적이 시작될 때 캡처된 추적 데이터를 제어할 수 있습니다.추적
추적은 선택한 이벤트 클래스, 데이터 열 및 필터에 기초하여 데이터를 캡처합니다. 예를 들어 예외 오류를 모니터링하는 추적을 만들 수 있습니다. 이 작업을 수행하려면 Exception 이벤트 클래스를 선택하고 Error, State 및 Severity 데이터 열을 선택합니다. 추적 결과에서 의미 있는 데이터를 제공하려면 이 3열의 데이터를 수집해야 합니다. 그런 다음 구성된 방식으로 추적을 실행하고 서버에서 발생하는 모든 Exception 이벤트에 대한 데이터를 수집합니다. 추적 데이터를 즉시 분석에 사용하거나 저장한 후 나중에 분석할 수 있습니다. 나중에 추적을 재생할 수 있지만 Exception 이벤트와 같은 특정 이벤트는 재생할 수 없습니다. 또한 추적을 템플릿으로 저장하여 나중에 유사한 추적을 구성할 수 있습니다.SQL Server는 SQL Server 인스턴스를 추적하는 두 가지 방법을 제공합니다. SQL Server 프로파일러를 사용하여 추적하거나 시스템 저장 프로시저를 사용하여 추적할 수 있습니다.
필터
추적 또는 템플릿을 만들 때 이벤트가 수집하는 데이터를 필터링할 조건을 정의할 수 있습니다. 추적이 지나치게 커지지 않도록 필터링을 통해 이벤트 데이터의 하위 집합만 수집할 수 있습니다. 예를 들어 추적에서 Microsoft Windows 사용자 이름을 특정 사용자로 제한하여 출력 데이터를 줄일 수 있습니다.필터가 설정되어 있지 않으면 선택된 이벤트 클래스의 모든 이벤트가 추적 출력에서 반환됩니다.
SQL Server Profiler 태스크
태스크 설명 |
항목 |
---|---|
SQL Server에서 특정한 유형의 이벤트를 모니터링하기 위해 제공하는 미리 정의된 템플릿과 추적을 재생하는 데 필요한 사용 권한을 보여 줍니다. |
|
SQL Server Profiler를 실행하는 방법에 대해 설명합니다. |
|
추적을 만드는 방법에 대해 설명합니다. |
|
추적 파일에 대한 이벤트 및 데이터 열을 지정하는 방법에 대해 설명합니다. |
|
파일에 추적 결과를 저장하는 방법에 대해 설명합니다. |
|
테이블에 추적 결과를 저장하는 방법에 대해 설명합니다. |
|
추적에서 이벤트를 필터링하는 방법에 대해 설명합니다. |
|
필터 정보를 보는 방법에 대해 설명합니다. |
|
필터를 수정하는 방법에 대해 설명합니다. |
|
추적 파일(SQL Server Profiler)에 대한 최대 파일 크기를 설정하는 방법에 대해 설명합니다. |
|
추적 테이블에 대한 최대 테이블 크기를 설정하는 방법에 대해 설명합니다. |
|
추적을 시작하는 방법에 대해 설명합니다. |
|
서버에 연결한 후 추적을 자동으로 시작하는 방법에 대해 설명합니다. |
|
이벤트 시작 시간을 기반으로 이벤트를 필터링하는 방법에 대해 설명합니다. |
|
이벤트 종료 시간을 기반으로 이벤트를 필터링하는 방법에 대해 설명합니다. |
|
추적에서 SPID(서버 프로세스 ID)를 필터링하는 방법에 대해 설명합니다. |
|
추적을 일시 중지하는 방법에 대해 설명합니다. |
|
추적을 중지하는 방법에 대해 설명합니다. |
|
추적을 일시 중지하거나 중지했다가 다시 실행하는 방법에 대해 설명합니다. |
|
추적 창을 지우는 방법에 대해 설명합니다. |
|
추적 창을 닫는 방법에 대해 설명합니다. |
|
추적 정의 기본값을 설정하는 방법에 대해 설명합니다. |
|
추적 표시 기본값을 설정하는 방법에 대해 설명합니다. |
|
추적 파일을 여는 방법에 대해 설명합니다. |
|
추적 테이블을 여는 방법에 대해 설명합니다. |
|
추적 테이블을 재생하는 방법에 대해 설명합니다. |
|
추적 파일을 재생하는 방법에 대해 설명합니다. |
|
한 번에 하나의 이벤트를 재생하는 방법에 대해 설명합니다. |
|
중단점까지 재생하는 방법에 대해 설명합니다. |
|
커서까지 재생하는 방법을 설명합니다. |
|
Transact-SQL 스크립트를 재생하는 방법에 대해 설명합니다. |
|
추적 템플릿을 만드는 방법에 대해 설명합니다. |
|
추적 템플릿을 수정하는 방법에 대해 설명합니다. |
|
전역 추적 옵션을 설정하는 방법에 대해 설명합니다. |
|
추적 중에 값 또는 데이터 열을 찾는 방법에 대해 설명합니다. |
|
실행 중인 추적에서 템플릿을 파생하는 방법에 대해 설명합니다. |
|
추적 파일 또는 추적 테이블에서 템플릿을 파생하는 방법에 대해 설명합니다. |
|
추적 실행을 위한 Transact-SQL 스크립트를 만드는 방법에 대해 설명합니다. |
|
추적 템플릿을 내보내는 방법에 대해 설명합니다. |
|
추적 템플릿을 가져오는 방법에 대해 설명합니다. |
|
추적에서 스크립트를 추출하는 방법에 대해 설명합니다. |
|
추적과 Windows 성능 로그 데이터의 상관 관계를 지정하는 방법에 대해 설명합니다. |
|
추적에 표시되는 열을 구성하는 방법에 대해 설명합니다. |
|
SQL Server Profiler를 시작하는 방법에 대해 설명합니다. |
|
추적 및 추적 템플릿을 저장하는 방법에 대해 설명합니다. |
|
추적 템플릿을 수정하는 방법에 대해 설명합니다. |
|
추적과 Windows 성능 로그 데이터의 상관 관계를 지정하는 방법에 대해 설명합니다. |
|
SQL Server Profiler를 사용하여 추적을 보고 분석하는 방법에 대해 설명합니다. |
|
SQL Server Profiler를 사용하여 교착 상태를 분석하는 방법에 대해 설명합니다. |
|
SQL Server Profiler에서 SHOWPLAN 결과로 쿼리를 분석하는 방법에 대해 설명합니다. |
|
SQL Server Profiler로 추적을 필터링하는 방법에 대해 설명합니다. |
|
SQL Server Profiler의 재생 기능을 사용하는 방법에 대해 설명합니다. |
|
SQL Server Profiler에 대한 상황에 맞는 도움말 항목을 보여 줍니다. |
|
SQL Server 프로파일러에서 성능 및 작업을 모니터링하는 데 사용하는 시스템 저장 프로시저를 보여 줍니다. |