서버 감사 및 데이터베이스 감사 사양 만들기Create a Server Audit and Database Audit Specification

이 항목에서는 SQL Server 2016SQL Server 2016 또는 SQL Server Management StudioSQL Server Management Studio 을 사용하여 Transact-SQLTransact-SQL에서 서버 감사 및 데이터베이스 감사 사양을 만드는 방법에 대해 설명합니다.This topic describes how to create a server audit and database audit specification in SQL Server 2016SQL Server 2016 by using SQL Server Management StudioSQL Server Management Studio or Transact-SQLTransact-SQL.

인스턴스 또는 데이터베이스 SQL ServerSQL Server 감사 SQL ServerSQL Server 에는 시스템에서 발생하는 추적 이벤트 및 로깅 이벤트가 포함됩니다.Auditing an instance of SQL ServerSQL Server or a SQL ServerSQL Server database involves tracking and logging events that occur on the system. SQL Server Audit 개체는 사용자가 모니터링하려는 서버 또는 데이터베이스 수준 동작 및 동작 그룹에 대한 하나의 인스턴스를 수집합니다.The SQL Server Audit object collects a single instance of server- or database-level actions and groups of actions to monitor. 감사는 SQL ServerSQL Server 인스턴스 수준으로 존재합니다.The audit is at the SQL ServerSQL Server instance level. SQL ServerSQL Server 인스턴스별로 여러 개의 감사를 가질 수 있습니다.You can have multiple audits per SQL ServerSQL Server instance. 데이터베이스 수준 감사 사양 개체는 감사에 속해 있습니다.The Database-Level Audit Specification object belongs to an audit. 감사의 SQL Server 데이터베이스당 하나의 데이터베이스 감사 사양을 만들 수 있습니다.You can create one database audit specification per SQL Server database per audit. 자세한 내용은 SQL Server Audit(데이터베이스 엔진)을 참조하세요.For more information, see SQL Server Audit (Database Engine).

항목 내용In This Topic

시작하기 전 주의 사항 Before You Begin

제한 사항 Limitations and Restrictions

데이터베이스 감사 사양은 지정된 데이터베이스에 있는 비보안 개체입니다.Database audit specifications are non-securable objects that reside in a given database. 데이터베이스 감사 사양을 처음 만들 때는 사용할 수 없는 상태입니다.When a database audit specification is created, it is in a disabled state.

사용자 데이터베이스에 데이터베이스 감사 사양을 만들거나 사양을 수정할 때 시스템 뷰와 같은 서버 범위 개체에 대한 감사 동작은 포함하지 마세요.When you are creating or modifying a database audit specification in a user database, do not include audit actions on server-scope objects, such as the system views. 서버 범위 개체를 포함하더라도 감사가 생성됩니다.If server-scoped objects are included, the audit will be created. 그러나 서버 범위 개체가 포함되지는 않으며 별도의 오류도 반환되지 않습니다.However, the server-scoped objects will not be included, and no error will be returned. 서버 범위 개체를 감사하려면 master 데이터베이스의 데이터베이스 감사 사양을 사용합니다.To audit server-scope objects, use a database audit specification in the master database.

데이터베이스 감사 사양은 해당 사양이 생성된 데이터베이스 내에 있습니다( tempdb 시스템 데이터베이스 제외).Database audit specifications reside in the database where they are created, with the exception of the tempdb system database.

보안 Security

사용 권한 Permissions

  • ALTER ANY DATABASE AUDIT 권한이 있는 사용자는 데이터베이스 감사 사양을 만들어 모든 감사에 바인딩할 수 있습니다.Users with the ALTER ANY DATABASE AUDIT permission can create database audit specifications and bind them to any audit.

  • 생성된 데이터베이스 감사 사양은 CONTROL SERVER, ALTER ANY DATABASE AUDIT 권한이 있는 보안 주체나 sysadmin 계정이 볼 수 있습니다.After a database audit specification is created, it can be viewed by principals with the CONTROL SERVER, ALTER ANY DATABASE AUDIT permissions, or the sysadmin account.

SQL Server Management Studio 사용 Using SQL Server Management Studio

서버 감사를 만들려면To create a server audit

  1. 개체 탐색기에서 보안 폴더를 확장합니다.In Object Explorer, expand the Security folder.

  2. 감사 폴더를 마우스 오른쪽 단추로 클릭하고 새 감사...를 선택합니다.Right-click the Audits folder and select New Audit…. 자세한 내용은 Create a Server Audit and Server Audit Specification을 참조하세요.For more information, see Create a Server Audit and Server Audit Specification.

  3. 옵션 선택을 마쳤으면 확인을 클릭합니다.When you are finished selecting options, click OK.

데이터베이스 수준 감사 사양을 만들려면To create a database-level audit specification

  1. 개체 탐색기에서 감사 사양을 만들 데이터베이스를 확장합니다.In Object Explorer, expand the database where you want to create an audit specification.

  2. 보안 폴더를 확장합니다.Expand the Security folder.

  3. 데이터베이스 감사 사양 폴더를 마우스 오른쪽 단추로 클릭하고 새 데이터베이스 감사 사양...을 선택합니다.Right-click the Database Audit Specifications folder and select New Database Audit Specification….

    데이터베이스 감사 사양 만들기 대화 상자에는 다음과 같은 옵션이 제공됩니다.The following options are available on the Create Database Audit Specification dialog box.

    이름Name
    데이터베이스 감사 사양의 이름입니다.The name of the database audit specification. 새 서버 감사 사양을 만들 때 자동 생성되지만 편집할 수 있습니다.This is generated automatically when you create a new server audit specification but is editable.

    감사Audit
    기존 데이터베이스 감사의 이름입니다.The name of an existing database audit. 감사 이름을 입력하거나 목록에서 선택합니다.Either type in the name of the audit or select it from the list.

    감사 동작 유형Audit Action Type
    캡처할 데이터베이스 수준 감사 동작 그룹 및 감사 동작을 지정합니다.Specifies the database-level audit action groups and audit actions to capture. 데이터베이스 수준 감사 동작 그룹 및 감사 동작의 목록과 여기에 포함된 이벤트에 대한 설명은 SQL Server Audit 동작 그룹 및 동작을 참조하세요.For the list of database-level audit action groups and audit actions and a description of the events they contain, see SQL Server Audit Action Groups and Actions.

    개체 스키마Object Schema
    지정된 개체 이름에 대한 스키마를 표시합니다.Displays the schema for the specified Object Name.

    개체 이름Object Name
    감사할 개체의 이름입니다.The name of the object to audit. 이 이름은 감사 동작에만 사용할 수 있으며 감사 그룹에는 적용되지 않습니다.This is only available for audit actions; it does not apply to audit groups.

    줄임표(...)Ellipsis (…)
    개체 선택 대화 상자를 열고 지정된 감사 동작 유형에 따라 사용 가능한 개체를 찾아 선택합니다.Opens the Select Objects dialog to browse for and select an available object, based on the specified Audit Action Type.

    보안 주체 이름Principal Name
    감사 중인 개체에 대한 감사 필터링의 기준이 되는 계정입니다.The account to filter the audit by for the object being audited.

    줄임표(...)Ellipsis (…)
    개체 선택 대화 상자를 열고 지정된 개체 이름에 따라 사용 가능한 개체를 찾아 선택합니다.Opens the Select Objects dialog to browse for and select an available object, based on the specified Object Name.

  4. 옵션 선택을 마쳤으면 확인을 클릭합니다.When you are finished selecting option, click OK.

Transact-SQL 사용 Using Transact-SQL

서버 감사를 만들려면To create a server audit

  1. 개체 탐색기에서 데이터베이스 엔진Database Engine인스턴스에 연결합니다.In Object Explorer, connect to an instance of 데이터베이스 엔진Database Engine.

  2. 표준 도구 모음에서 새 쿼리를 클릭합니다.On the Standard bar, click New Query.

  3. 다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다.Copy and paste the following example into the query window and click Execute.

    USE master ;  
    GO  
    -- Create the server audit.   
    CREATE SERVER AUDIT Payrole_Security_Audit  
        TO FILE ( FILEPATH =   
    'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA' ) ;   
    GO  
    -- Enable the server audit.   
    ALTER SERVER AUDIT Payrole_Security_Audit   
    WITH (STATE = ON) ;  
    

데이터베이스 수준 감사 사양을 만들려면To create a database-level audit specification

  1. 개체 탐색기에서 데이터베이스 엔진Database Engine인스턴스에 연결합니다.In Object Explorer, connect to an instance of 데이터베이스 엔진Database Engine.

  2. 표준 도구 모음에서 새 쿼리를 클릭합니다.On the Standard bar, click New Query.

  3. 다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다.Copy and paste the following example into the query window and click Execute. 이 예에서는 위에 정의된 서버 감사를 기반으로 Audit_Pay_Tables 테이블에 대해 dbo 사용자가 SELECT 및 INSERT 문을 감사하는 HumanResources.EmployeePayHistory이라는 데이터베이스 감사 사양을 만듭니다.The example creates a database audit specification called Audit_Pay_Tables that audits SELECT and INSERT statements by the dbo user, for the HumanResources.EmployeePayHistory table based on the server audit defined above.

    USE AdventureWorks2012 ;   
    GO  
    -- Create the database audit specification.   
    CREATE DATABASE AUDIT SPECIFICATION Audit_Pay_Tables  
    FOR SERVER AUDIT Payrole_Security_Audit  
    ADD (SELECT , INSERT  
         ON HumanResources.EmployeePayHistory BY dbo )   
    WITH (STATE = ON) ;   
    GO  
    

    자세한 내용은 CREATE SERVER AUDIT(Transact-SQL)CREATE DATABASE AUDIT SPECIFICATION(Transact-SQL)을 참조하세요.For more information, see CREATE SERVER AUDIT (Transact-SQL) and CREATE DATABASE AUDIT SPECIFICATION (Transact-SQL).