PowerShell 스크립트 작업 단계 만들기

이 항목에서는 SQL Server Management Studio 또는 Transact-SQL을 사용하여 SQL Server 2012에서 PowerShell 스크립트를 실행하는 SQL Server 에이전트 작업 단계를 만들고 정의하는 방법에 대해 설명합니다.

항목 내용

  • 시작하기 전 주의 사항  

    보안

  • PowerShell 스크립트 작업 단계를 만들려면

    SQL Server Management Studio

    Transact-SQL

    SQL Server 관리 개체

시작하기 전 주의 사항

보안

자세한 내용은 SQL Server 에이전트 보안 구현을 참조하십시오.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]

SQL Server Management Studio 사용

PowerShell 스크립트 작업 단계를 만들려면

  1. 개체 탐색기에서 SQL Server 데이터베이스 엔진 인스턴스에 연결한 다음 해당 인스턴스를 확장합니다.

  2. SQL Server 에이전트를 확장하고 새 작업을 만들거나 기존 작업을 마우스 오른쪽 단추로 클릭한 다음 속성을 클릭합니다. 작업을 만드는 방법은 작업 만들기를 참조하십시오.

  3. 작업 속성 대화 상자에서 단계 페이지를 클릭한 다음 새로 만들기를 클릭합니다.

  4. 새 작업 단계 대화 상자에서 작업 단계 이름을 입력합니다.

  5. 형식 목록에서 PowerShell을 클릭합니다.

  6. 다음 계정으로 실행 목록에서 작업에 사용할 자격 증명을 가진 프록시 계정을 선택합니다.

  7. 명령 입력란에 작업 단계를 위해 실행될 PowerShell 스크립트 구문을 입력합니다. 아니면 열기를 클릭한 다음 해당 스크립트 구문이 포함된 파일을 선택합니다. PowerShell 스크립트 예는 아래의 Transact-SQL 사용을 참조하십시오.

  8. 고급 페이지를 클릭하여 작업 단계가 성공 또는 실패할 경우에 수행할 동작, SQL Server 에이전트의 작업 단계 실행 시도 횟수, 다시 시도 간격 등 작업 단계 옵션을 설정합니다.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]

Transact-SQL 사용

PowerShell 스크립트 작업 단계를 만들려면

  1. 개체 탐색기에서 데이터베이스 엔진 인스턴스에 연결합니다.

  2. 표준 도구 모음에서 새 쿼리를 클릭합니다.

  3. 다음 예를 복사하여 쿼리 창에 붙여 넣고 실행을 클릭합니다.

    -- creates a PowerShell job step that finds the processes that use more than 1000 MB of memory and kills them
    USE msdb;
    GO
    EXEC sp_add_jobstep
        @job_name = N'Weekly Sales Data Backup',
        @step_name = N'Kills all processes that use more than 1000 MB of memory',
        @subsystem = N'PowerShell',
        @command = N'Get-Process | Where-Object { $_.WS -gt 1000MB } | Stop-Process', 
        @retry_attempts = 5,
        @retry_interval = 5 ;
    GO
    

자세한 내용은 sp_add_jobstep(Transact-SQL)을 참조하십시오.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]

SQL Server 관리 개체 사용

PowerShell 스크립트 작업 단계를 만들려면

Visual Basic, Visual C#, PowerShell 등 선택한 프로그래밍 언어를 사용하여 JobStep 클래스를 사용합니다. 자세한 내용은 SMO(SQL Server 관리 개체)를 참조하십시오.

맨 위로 이동 링크와 함께 사용되는 화살표 아이콘[Top]