SQL Server Audit 동작 그룹 및 동작

SQL Server Audit 기능을 통해 서버 수준 및 데이터베이스 수준의 이벤트 그룹과 개별 이벤트를 감사할 수 있습니다. 자세한 내용은 SQL Server Audit 이해를 참조하십시오.

SQL Server Audit는 0개 이상의 감사 동작 항목으로 구성되어 있습니다. 이러한 감사 동작 항목은 동작 그룹(예: Server_Object_Change_Group) 또는 개별 동작(예: 테이블에 대한 SELECT 작업)일 수 있습니다.

[!참고]

Server_Object_Change_Group에는 모든 서버 개체(데이터베이스 또는 끝점)에 대한 CREATE, ALTER 및 DROP이 포함됩니다.

감사의 동작 범주는 다음과 같습니다.

  • 서버 수준. 관리 변경 내용 및 로그온/로그오프 작업과 같은 서버 작업이 이에 해당됩니다.

  • 데이터베이스 수준. DML(데이터 조작 언어) 및 DDL(데이터 정의 언어) 작업이 이에 해당됩니다.

  • 감사 수준. 감사 프로세스의 동작이 이에 해당됩니다.

SQL Server Audit 구성 요소에서 수행되는 일부 동작은 기본적으로 특정 감사에서 감사됩니다. 이 경우 부모 개체에서 이벤트가 발생한 것이므로 감사 이벤트가 자동으로 발생합니다.

기본적으로 감사되는 동작은 다음과 같습니다.

  • 서버 감사 상태 변경(상태를 ON 또는 OFF로 설정)

다음 이벤트는 기본적으로 감사되지 않습니다.

  • CREATE SERVER AUDIT SPECIFICATION

  • ALTER SERVER AUDIT SPECIFICATION

  • DROP SERVER AUDIT SPECIFICATION

  • CREATE DATABASE AUDIT SPECIFICATION

  • ALTER DATABASE AUDIT SPECIFICATION

  • DROP DATABASE AUDIT SPECIFICATION

모든 감사는 처음 만들어진 상태에서는 비활성화되어 있습니다.

서버 수준 감사 동작 그룹

서버 수준 감사 동작 그룹은 SQL Server 보안 감사 이벤트 클래스와 유사한 동작입니다. 자세한 내용은 SQL Server 이벤트 클래스 참조를 참조하십시오. 

다음 표에서는 서버 수준 감사 동작 그룹에 대해 설명하며 해당하는 경우 동일한 SQL Server 이벤트 클래스를 제공합니다.

동작 그룹 이름

설명

APPLICATION_ROLE_CHANGE_PASSWORD_GROUP

응용 프로그램 역할의 암호가 변경될 때마다 발생하는 이벤트입니다. Audit App Role Change Password 이벤트 클래스와 동일합니다.

AUDIT_CHANGE_GROUP

모든 감사가 생성, 수정 또는 삭제되거나 모든 감사 사양이 생성, 수정 또는 삭제될 때마다 발생하는 이벤트입니다. 감사에 대한 모든 변경 내용은 자체적으로 감사됩니다. Audit Change Audit 이벤트 클래스와 동일합니다.

BACKUP_RESTORE_GROUP

백업 또는 복원 명령이 실행될 때마다 발생하는 이벤트입니다. Audit Backup/Restore 이벤트 클래스와 동일합니다.

BROKER_LOGIN_GROUP

Service Broker 전송 보안과 연관된 감사 메시지를 보고하기 위해 발생하는 이벤트입니다. Audit Broker Login 이벤트 클래스와 동일합니다.

DATABASE_CHANGE_GROUP

데이터베이스가 생성, 변경 또는 삭제되면 발생하면 발생하는 이벤트입니다. 이 이벤트는 모든 데이터베이스가 생성, 변경 또는 삭제될 때마다 발생합니다. Audit Database Management 이벤트 클래스와 동일합니다.

DATABASE_MIRRORING_LOGIN_GROUP

데이터베이스 미러링 전송 보안과 연관된 감사 메시지를 보고하기 위해 발생하는 이벤트입니다. Audit Database Mirroring Login 이벤트 클래스와 동일합니다.

DATABASE_OBJECT_ACCESS_GROUP

메시지 유형, 어셈블리, 계약과 같은 데이터베이스 개체에 액세스할 때마다 발생하는 이벤트입니다.

이 이벤트는 모든 데이터베이스의 모든 액세스에 대해 발생합니다.

참고참고
이로 인해 다량의 감사 레코드가 생성될 수 있습니다.

Audit Database Object Access 이벤트 클래스와 동일합니다.

DATABASE_OBJECT_CHANGE_GROUP

스키마와 같은 데이터베이스 개체에 대해 CREATE, ALTER 또는 DROP 문이 실행되면 발생하는 이벤트입니다. 이 이벤트는 모든 데이터베이스 개체가 생성, 변경 또는 삭제될 때마다 발생합니다.

참고참고
이로 인해 다량의 감사 레코드가 생성될 수 있습니다.

Audit Database Object Management 이벤트 클래스와 동일합니다.

DATABASE_OBJECT_OWNERSHIP_CHANGE_GROUP

이 이벤트는 데이터베이스 범위 내에서 개체에 대한 소유자가 변경되면 발생합니다. 이 이벤트는 모든 서버 데이터베이스의 모든 개체 소유권 변경에 대해 발생합니다. Audit Database Object Take Ownership 이벤트 클래스와 동일합니다.

DATABASE_OBJECT_PERMISSION_CHANGE_GROUP

어셈블리 및 스키마와 같은 데이터베이스 개체에 대해 GRANT, REVOKE 또는 DENY가 실행되면 발생하는 이벤트입니다. 모든 서버 데이터베이스의 모든 개체 사용 권한 변경에 대해 발생하는 이벤트입니다. Audit Database Object GDR 이벤트 클래스와 동일합니다.

DATABASE_OPERATION_GROUP

쿼리 알림 구독 또는 검사점 설정과 같은 데이터베이스 작업이 수행되면 발생하는 이벤트입니다. 이 이벤트는 모든 데이터베이스의 모든 데이터베이스 작업에 대해 발생합니다. Audit Database Operation 이벤트 클래스와 동일합니다.

DATABASE_OWNERSHIP_CHANGE_GROUP

ALTER AUTHORIZATION 문을 사용하여 데이터베이스 소유자를 변경하고 변경 작업에 필요한 권한을 확인하면 발생하는 이벤트입니다. 이 이벤트는 모든 서버 데이터베이스의 모든 데이터베이스 소유권 변경에 대해 발생합니다. Audit Change Database Owner 이벤트 클래스와 동일합니다.

DATABASE_PERMISSION_CHANGE_GROUP

SQL Server의 모든 보안 주체가 문 사용 권한에 대해 GRANT, REVOKE 또는 DENY를 실행할 때마다 발생하는 이벤트입니다. 이는 데이터베이스 사용 권한 부여와 같은 데이터베이스 전용 이벤트에 해당합니다.

모든 서버 데이터베이스의 모든 GDR(데이터베이스 사용 권한 변경)에 대해 발생하는 이벤트입니다. Audit Database Scope GDR 이벤트 클래스와 동일합니다.

DATABASE_PRINCIPAL_CHANGE_GROUP

이 이벤트는 사용자 같은 보안 주체가 데이터베이스에서 생성, 변경 또는 삭제되면 발생합니다. Audit Database Principal Management 이벤트 클래스와 동일합니다. 또한 더 이상 사용되지 않는 sp_grantdbaccess, sp_revokedbaccess, sp_addPrincipal 및 sp_dropPrincipal 저장 프로시저에 대해 발생하는 Audit Add DB Principal 이벤트 클래스와 동일합니다.

sp_addrole 및 sp_droprole 저장 프로시저를 사용하여 데이터베이스 역할을 추가 또는 제거할 때마다 발생하는 이벤트입니다. 이 이벤트는 모든 데이터베이스에서 모든 데이터베이스 보안 주체가 생성, 변경 또는 삭제될 때마다 발생합니다. Audit Add Role 이벤트 클래스와 동일합니다.

DATABASE_PRINCIPAL_IMPERSONATION_GROUP

데이터베이스 범위 내에 EXECUTE AS <principal> 또는 SETPRINCIPAL과 같은 가장 작업이 있으면 발생하는 이벤트입니다. 이 이벤트는 모든 데이터베이스에서 가장이 수행되면 발생합니다. Audit Database Principal Impersonation 이벤트 클래스와 동일합니다.

DATABASE_ROLE_MEMBER_CHANGE_GROUP

데이터베이스 역할에서 로그인이 추가 또는 제거될 때마다 발생하는 이벤트입니다. 이 이벤트 클래스는 sp_addrolemember, sp_changegroup 및 sp_droprolemember 저장 프로시저에 대해 발생합니다. 모든 데이터베이스의 모든 데이터베이스 역할 멤버 변경에 대해 발생합니다. Audit Add Member to DB Role 이벤트 클래스와 동일합니다.

DBCC_GROUP

보안 주체가 모든 DBCC 명령을 실행할 때마다 발생하는 이벤트입니다. Audit DBCC 이벤트 클래스와 동일합니다.

FAILED_LOGIN_GROUP

보안 주체의 SQL Server에 대한 로그인 시도가 실패했음을 나타냅니다. 이 클래스의 이벤트는 연결 풀에서 다시 사용된 연결 또는 새 연결에 의해 발생합니다. Audit Login Failed 이벤트 클래스와 동일합니다.

FULLTEXT_GROUP

전체 텍스트 이벤트가 발생했음을 나타냅니다. Audit Fulltext 이벤트 클래스와 동일합니다.

LOGIN_CHANGE_PASSWORD_GROUP

ALTER LOGIN 문 또는 sp_password 저장 프로시저를 통해 로그인 암호가 변경될 때마다 발생하는 이벤트입니다. Audit Login Change Password 이벤트 클래스와 동일합니다.

LOGOUT_GROUP

보안 주체가 SQL Server에서 로그아웃했음을 나타냅니다. 이 클래스의 이벤트는 연결 풀에서 다시 사용된 연결 또는 새 연결에 의해 발생합니다. Audit Logout 이벤트 클래스와 동일합니다.

SCHEMA_OBJECT_ACCESS_GROUP

스키마에서 개체 사용 권한이 사용될 때마다 발생하는 이벤트입니다. Audit Schema Object Access 이벤트 클래스와 동일합니다.

SCHEMA_OBJECT_CHANGE_GROUP

스키마에 대해 CREATE, ALTER 또는 DROP 작업이 수행되면 발생하는 이벤트입니다. Audit Schema Object Management 이벤트 클래스와 동일합니다.

스키마 개체에 대해 발생하는 이벤트입니다. Audit Object Derived Permission 이벤트 클래스와 동일합니다.

모든 데이터베이스의 모든 스키마가 변경될 때마다 발생하는 이벤트입니다. Audit Statement Permission 이벤트 클래스와 동일합니다.

SCHEMA_OBJECT_OWNERSHIP_CHANGE_GROUP

스키마 개체(예: 테이블, 프로시저, 함수) 소유자 변경 권한을 확인하거나 ALTER AUTHORIZATION 문을 사용하여 개체에 소유자를 할당하면 발생하는 이벤트입니다. 이 이벤트는 모든 서버 데이터베이스의 모든 스키마 소유권 변경에 대해 발생합니다. Audit Schema Object Take Ownership 이벤트 클래스와 동일합니다.

SCHEMA_OBJECT_PERMISSION_CHANGE_GROUP

스키마 개체에 대해 권한 부여, 거부 또는 취소 작업이 수행될 때마다 발생하는 이벤트입니다. Audit Schema Object GDR 이벤트 클래스와 동일합니다.

SERVER_OBJECT_CHANGE_GROUP

서버 개체에 대해 CREATE, ALTER 또는 DROP 작업이 수행되면 발생하는 이벤트입니다. Audit Server Object Management 이벤트 클래스와 동일합니다.

SERVER_OBJECT_OWNERSHIP_CHANGE_GROUP

서버 범위의 개체에 대한 소유자가 변경되면 발생하는 이벤트입니다. Audit Server Object Take Ownership 이벤트 클래스와 동일합니다.

SERVER_OBJECT_PERMISSION_CHANGE_GROUP

SQL Server의 모든 보안 주체가 서버 개체 사용 권한에 대해 GRANT, REVOKE 또는 DENY를 실행할 때마다 발생하는 이벤트입니다. Audit Server Object GDR 이벤트 클래스와 동일합니다.

SERVER_OPERATION_GROUP

설정, 리소스, 외부 액세스, 사용 권한 변경 등의 보안 감사 작업이 사용되면 발생하는 이벤트입니다. Audit Server Operation 이벤트 클래스와 동일합니다.

SERVER_PERMISSION_CHANGE_GROUP

서버 범위의 사용 권한(예: 로그인 생성)에 대해 GRANT, REVOKE 또는 DENY가 실행되면 발생하는 이벤트입니다. Audit Server Scope GDR 이벤트 클래스와 동일합니다.

SERVER_PRINCIPAL_CHANGE_GROUP

서버 보안 주체가 생성, 변경 또는 삭제되면 발생하는 이벤트입니다. Audit Server Principal Management 이벤트 클래스와 동일합니다.

보안 주체가 sp_defaultdb 또는 sp_defaultlanguage 저장 프로시저나 ALTER LOGIN 문을 실행하면 발생하는 이벤트입니다. Audit Addlogin 이벤트 클래스와 동일합니다.

이 이벤트는 sp_addlogin 및 sp_droplogin 저장 프로시저에 대해 발생합니다. 또한 Audit Login Change Property 이벤트 클래스와 동일합니다.

이 이벤트는 sp_grantlogin, sp_revokelogin 또는 sp_denylogin 저장 프로시저에 대해 발생합니다. Audit Login GDR 이벤트 클래스와 동일합니다.

SERVER_PRINCIPAL_IMPERSONATION_GROUP

서버 범위 내에 EXECUTE AS <login>과 같은 가장이 있으면 발생하는 이벤트입니다. Audit Server Principal Impersonation 이벤트 클래스와 동일합니다.

SERVER_ROLE_MEMBER_CHANGE_GROUP

고정 서버 역할에서 로그인이 추가 또는 제거될 때마다 발생하는 이벤트입니다. 이 이벤트는 sp_addsrvrolemember 및 sp_dropsrvrolemember 저장 프로시저에 대해 발생합니다. Audit Add Login to Server Role 이벤트 클래스와 동일합니다.

SERVER_STATE_CHANGE_GROUP

SQL Server 서비스 상태가 수정되면 발생하는 이벤트입니다. Audit Server Starts and Stops 이벤트 클래스와 동일합니다.

SUCCESSFUL_LOGIN_GROUP

보안 주체가 SQL Server에 성공적으로 로그인했음을 나타냅니다. 이 클래스의 이벤트는 연결 풀에서 다시 사용된 연결 또는 새 연결에 의해 발생합니다. Audit Login 이벤트 클래스와 동일합니다.

TRACE_CHANGE_GROUP

ALTER TRACE 권한을 확인하는 모든 문에 대해 발생하는 이벤트입니다. Audit Server Alter Trace 이벤트 클래스와 동일합니다.

고려 사항

서버 수준 동작 그룹은 전체 SQL Server 인스턴스의 동작을 포함합니다. 예를 들어 서버 감사 사양에 적절한 동작 그룹이 추가되면 모든 데이터베이스의 모든 스키마 개체 액세스 검사가 기록됩니다. 데이터베이스 감사 사양에서는 해당 데이터베이스의 스키마 개체 액세스만 기록됩니다.

서버 수준 동작은 데이터베이스 수준 동작에 대한 자세한 필터링을 허용하지 않습니다. 자세한 동작 필터링을 구현하려면 데이터베이스 수준 감사(예: Employee 그룹에서 로그인에 사용할 Customers 테이블 SELECT 동작에 대한 감사)가 필요합니다. 시스템 뷰와 같은 서버 범위 개체는 사용자 데이터베이스 감사 사양에 포함하지 마십시오.

데이터베이스 수준 감사 동작 그룹

데이터베이스 수준 감사 동작 그룹은 SQL Server 보안 감사 이벤트 클래스와 유사한 동작입니다. 이벤트 클래스에 대한 자세한 내용은 SQL Server 이벤트 클래스 참조를 참조하십시오.

다음 표에서는 데이터베이스 수준 감사 동작 그룹에 대해 설명하며 해당하는 경우 동일한 SQL Server 이벤트 클래스를 제공합니다.

동작 그룹 이름

설명

APPLICATION_ROLE_CHANGE_PASSWORD_GROUP

응용 프로그램 역할의 암호가 변경될 때마다 발생하는 이벤트입니다. Audit App Role Change Password 이벤트 클래스와 동일합니다.

AUDIT_CHANGE_GROUP

모든 감사가 생성, 수정 또는 삭제되거나 모든 감사 사양이 생성, 수정 또는 삭제될 때마다 발생하는 이벤트입니다. 감사에 대한 모든 변경 내용은 자체적으로 감사됩니다. Audit Change Audit 이벤트 클래스와 동일합니다.

BACKUP_RESTORE_GROUP

백업 또는 복원 명령이 실행될 때마다 발생하는 이벤트입니다. Audit Backup/Restore 이벤트 클래스와 동일합니다.

DATABASE_CHANGE_GROUP

데이터베이스가 생성, 변경 또는 삭제되면 발생하면 발생하는 이벤트입니다. Audit Database Management 이벤트 클래스와 동일합니다.

DATABASE_OBJECT_ACCESS_GROUP

인증서 및 비대칭 키와 같은 데이터베이스 개체에 액세스할 때마다 발생하는 이벤트입니다. Audit Database Object Access 이벤트 클래스와 동일합니다.

DATABASE_OBJECT_CHANGE_GROUP

스키마와 같은 데이터베이스 개체에 대해 CREATE, ALTER 또는 DROP 문이 실행되면 발생하는 이벤트입니다. Audit Database Object Management 이벤트 클래스와 동일합니다.

DATABASE_OBJECT_OWNERSHIP_CHANGE_GROUP

데이터베이스 범위 내에서 개체에 대한 소유자가 변경되면 발생하는 이벤트입니다. Audit Database Object Take Ownership 이벤트 클래스와 동일합니다.

DATABASE_OBJECT_PERMISSION_CHANGE_GROUP

어셈블리 및 스키마와 같은 데이터베이스 개체에 대해 GRANT, REVOKE 또는 DENY가 실행되면 발생하는 이벤트입니다. Audit Database Object GDR 이벤트 클래스와 동일합니다.

DATABASE_OPERATION_GROUP

쿼리 알림 구독 또는 검사점 설정과 같은 데이터베이스 작업이 수행되면 발생하는 이벤트입니다. Audit Database Operation 이벤트 클래스와 동일합니다.

DATABASE_OWNERSHIP_CHANGE_GROUP

ALTER AUTHORIZATION 문을 사용하여 데이터베이스 소유자를 변경하고 변경 작업에 필요한 권한을 확인하면 발생하는 이벤트입니다. Audit Change Database Owner 이벤트 클래스와 동일합니다.

DATABASE_PERMISSION_CHANGE_GROUP

데이터베이스 사용 권한 부여와 같은 데이터베이스 전용 이벤트에서 SQL Server의 모든 사용자가 문 사용 권한에 대해 GRANT, REVOKE 또는 DENY를 실행할 때마다 발생하는 이벤트입니다. Audit Database Scope GDR 이벤트 클래스와 동일합니다.

DATABASE_PRINCIPAL_CHANGE_GROUP

이 이벤트는 사용자 같은 보안 주체가 데이터베이스에서 생성, 변경 또는 삭제되면 발생합니다. Audit Database Principal Management 이벤트 클래스와 동일합니다. 또한 더 이상 사용되지 않는 sp_grantdbaccess, sp_revokedbaccess, sp_adduser 및 sp_dropuser 저장 프로시저에 대해 발생하는 Audit Add DB User 이벤트 클래스와 동일합니다.

이 이벤트는 더 이상 사용되지 않는 sp_addrole 및 sp_droprole 저장 프로시저를 사용하여 데이터베이스 역할을 추가 또는 제거할 때마다 발생합니다. Audit Add Role 이벤트 클래스와 동일합니다.

DATABASE_PRINCIPAL_IMPERSONATION_GROUP

데이터베이스 범위 내에 EXECUTE AS <user> 또는 SETUSER와 같은 가장이 있으면 발생하는 이벤트입니다. Audit Database Principal Impersonation 이벤트 클래스와 동일합니다.

DATABASE_ROLE_MEMBER_CHANGE_GROUP

데이터베이스 역할에서 로그인이 추가 또는 제거될 때마다 발생하는 이벤트입니다. 이 이벤트 클래스는 sp_addrolemember, sp_changegroup 및 sp_droprolemember 저장 프로시저와 함께 사용됩니다. Audit Add Member to DB Role 이벤트 클래스와 동일합니다.

DBCC_GROUP

보안 주체가 모든 DBCC 명령을 실행할 때마다 발생하는 이벤트입니다. Audit DBCC 이벤트 클래스와 동일합니다.

SCHEMA_OBJECT_ACCESS_GROUP

스키마에서 개체 사용 권한이 사용될 때마다 발생하는 이벤트입니다. Audit Schema Object Access 이벤트 클래스와 동일합니다.

SCHEMA_OBJECT_CHANGE_GROUP

스키마에 대해 CREATE, ALTER 또는 DROP 작업이 수행되면 발생하는 이벤트입니다. Audit Schema Object Management 이벤트 클래스와 동일합니다.

스키마 개체에 대해 발생하는 이벤트입니다. Audit Object Derived Permission 이벤트 클래스와 동일합니다. 또한 Audit Statement Permission 이벤트 클래스와 동일합니다.

SCHEMA_OBJECT_OWNERSHIP_CHANGE_GROUP

스키마 개체(예: 테이블, 프로시저, 함수) 소유자 변경 권한을 확인하거나 ALTER AUTHORIZATION 문을 사용하여 개체에 소유자를 할당하면 발생하는 이벤트입니다. Audit Schema Object Take Ownership 이벤트 클래스와 동일합니다.

SCHEMA_OBJECT_PERMISSION_CHANGE_GROUP

스키마 개체에 대해 권한 부여, 거부 또는 취소 작업이 실행될 때마다 발생하는 이벤트입니다. Audit Schema Object GDR 이벤트 클래스와 동일합니다.

데이터베이스 수준 감사 동작

데이터베이스 수준 동작은 데이터베이스 스키마 및 스키마 개체(예: 테이블, 뷰, 저장 프로시저, 함수, 확장 저장 프로시저, 큐, 동의어)에 대한 특정 동작을 직접 감사할 수 있습니다. 유형, XML 스키마 컬렉션, 데이터베이스 및 스키마는 감사되지 않습니다. 스키마 개체 감사는 스키마 및 데이터베이스에 구성될 수 있습니다. 이 경우 지정된 스키마 또는 데이터베이스에 포함된 모든 스키마 개체의 이벤트가 감사됩니다. 다음 표에서는 데이터베이스 수준 감사 동작에 대해 설명합니다.

동작

설명

SELECT

SELECT를 실행할 때마다 발생하는 이벤트입니다.

UPDATE

UPDATE를 실행할 때마다 발생하는 이벤트입니다.

INSERT

INSERT를 실행할 때마다 발생하는 이벤트입니다.

DELETE

DELETE를 실행할 때마다 발생하는 이벤트입니다.

EXECUTE

EXECUTE를 실행할 때마다 발생하는 이벤트입니다.

RECEIVE

RECEIVE를 실행할 때마다 발생하는 이벤트입니다.

REFERENCES

REFERENCES 사용 권한을 확인할 때마다 발생하는 이벤트입니다.

고려 사항

데이터베이스 수준 감사 동작은 열에 적용되지 않습니다.

쿼리 프로세서에서 쿼리를 매개 변수화하면 쿼리의 열 값 대신 해당 매개 변수가 감사 이벤트 로그에 나타납니다.

감사 수준 감사 동작 그룹

감사 프로세스의 동작을 감사할 수도 있습니다. 이는 서버 범위 또는 데이터베이스 범위일 수 있습니다. 데이터베이스 범위에서는 데이터베이스 감사 사양에 대해서만 발생합니다. 다음 표에서는 감사 수준 감사 동작 그룹에 대해 설명합니다.

동작 그룹 이름

설명

AUDIT_ CHANGE_GROUP

다음 명령 중 하나를 실행할 때마다 발생하는 이벤트입니다.

  • CREATE SERVER AUDIT

  • ALTER SERVER AUDIT

  • DROP SERVER AUDIT

  • CREATE SERVER AUDIT SPECIFICATION

  • ALTER SERVER AUDIT SPECIFICATION

  • DROP SERVER AUDIT SPECIFICATION

  • CREATE DATABASE AUDIT SPECIFICATION

  • ALTER DATABASE AUDIT SPECIFICATION

  • DROP DATABASE AUDIT SPECIFICATION

참고 항목

참조

개념