SQL Server Express에서 SQL Server 데이터베이스의 백업 예약 및 자동화

이 문서에서는 Transact-SQL 스크립트 및 Windows 작업 스케줄러를 사용하여 예약된 기준으로 SQL Server Express 데이터베이스의 백업을 자동화하는 방법을 소개합니다.

원래 제품 버전: SQL Server
원본 KB 번호: 2019698

요약

SQL Server Express 버전은 SQL Server 에이전트 구성 요소가 이러한 버전에 포함되지 않기 때문에 작업 또는 유지 관리 계획을 예약하는 방법을 제공하지 않습니다. 따라서 이러한 버전을 사용할 때 데이터베이스를 백업하기 위해 다른 접근 방식을 취해야 합니다.

현재 SQL Server Express 사용자는 다음 방법 중 하나를 사용하여 데이터베이스를 백업할 수 있습니다.

SQL Server Management Studio 또는 Azure Data Studio를 사용합니다. 이러한 도구를 사용하여 데이터베이스를 백업하는 방법에 대한 자세한 내용은 다음 링크를 검토하세요.

이 문서에서는 작업 스케줄러와 함께 Transact-SQL 스크립트를 사용하여 예약된 기준으로 SQL Server Express 데이터베이스의 백업을 자동화하는 방법을 설명합니다.

참고

이는 SQL Server Express 버전에만 적용되며 SQL Server Express LocalDB에는 적용되지 않습니다.

추가 정보

Windows 작업 스케줄러를 사용하여 SQL Server 데이터베이스를 백업하려면 다음 네 단계를 수행해야 합니다.

A단계: 데이터베이스를 백업하는 저장 프로시저를 만듭니다.

SQL express 인스턴스에 연결하고 다음 위치에 있는 스크립트를 사용하여 마스터 데이터베이스에 sp_BackupDatabases 저장 프로시저를 만듭니다.

SQL_Express_Backups

B단계: SQLCMD 도구를 다운로드합니다(해당하는 경우).

유틸리티를 sqlcmd 사용하면 Transact-SQL 문, 시스템 프로시저 및 스크립트 파일을 입력할 수 있습니다. SQL Server 2014 이하 버전에서는 유틸리티가 제품의 일부로 제공됩니다. SQL Server 2016 sqlcmd 부터 유틸리티는 별도의 다운로드로 제공됩니다. 자세한 내용은 sqlcmd 유틸리티를 확인하세요.

C단계: 텍스트 편집기를 사용하여 배치 파일을 만듭니다.

텍스트 편집기에서 Sqlbackup.bat이라는 배치 파일을 만든 다음 시나리오에 따라 다음 예제 중 하나의 텍스트를 해당 파일로 복사합니다.

  • 아래의 모든 시나리오는 D:\SQLBackups을(를) 자리 표시자로 사용합니다. 스크립트는 사용자 환경에서 올바른 드라이브 및 백업 폴더 위치로 조정해야 합니다.

  • SQL 인증을 사용하는 경우 암호가 일반 텍스트로 저장되므로 폴더에 대한 액세스가 권한 있는 사용자로 제한되는지 확인합니다.

참고

SQLCMD 실행 파일의 폴더는 일반적으로 SQL Server를 설치한 후 또는 독립 실행형 도구로 설치한 후 서버의 경로 변수에 있습니다. 그러나 경로 변수에 이 폴더가 나열되지 않은 경우 해당 위치를 경로 변수에 추가하거나 유틸리티의 전체 경로를 지정할 수 있습니다.

예 1: Windows 인증을 사용하여 SQLEXPRESS의 로컬 명명된 인스턴스에 있는 모든 데이터베이스의 전체 백업.

 // Sqlbackup.bat
 sqlcmd -S .\SQLEXPRESS -E -Q "EXEC sp_BackupDatabases @backupLocation='D:\SQLBackups\', @backupType='F'"

예 2: SQLLogin 및 해당 암호를 사용하여 SQLEXPRESS의 로컬 명명된 인스턴스에 있는 모든 데이터베이스의 차등 백업

 // Sqlbackup.bat
sqlcmd -U <YourSQLLogin> -P <StrongPassword> -S .\SQLEXPRESS -Q "EXEC sp_BackupDatabases  @backupLocation ='D:\SQLBackups', @BackupType='D'"

참고

SQLLogin에는 최소한 SQL Server 백업 운영자 역할 이상이 있어야 합니다.

예 3: Windows 인증을 사용하여 SQLEXPRESS의 로컬 명명된 인스턴스에 있는 모든 데이터베이스의 로그 백업

 // Sqlbackup.bat
 sqlcmd -S .\SQLEXPRESS -E -Q "EXEC sp_BackupDatabases @backupLocation='D:\SQLBackups\',@backupType='L'"

예 4: Windows 인증을 사용하여 SQLEXPRESS의 로컬 명명된 인스턴스에 있는 데이터베이스 USERDB의 전체 백업

 // Sqlbackup.bat
 sqlcmd -S .\SQLEXPRESS -E -Q "EXEC sp_BackupDatabases @backupLocation='D:\SQLBackups\', @databaseName='USERDB', @backupType='F'"

마찬가지로 @backupType 매개 변수에 대해 'D'를 붙여넣고 @backupType 매개 변수의 'L'에 붙여넣어 USERDB의 백업 로그를 붙여넣어 USERDB의 차등 백업을 만들 수 있습니다.

D단계: Windows 작업 스케줄러를 사용하여 B단계에서 만든 일괄 배치 파일을 실행하여 작업을 예약합니다. 이렇게 하려면 다음 단계를 따르세요.

  1. SQL Server Express 실행 중인 컴퓨터에서 시작을 클릭한 다음 텍스트 상자에 작업 스케줄러를 입력합니다.

    시작 메뉴의 검색 창에 있는 작업 스케줄러 데스크톱 앱 옵션의 스크린샷.

  2. 가장 일치하는 항목에서 작업 스케줄러를 클릭하여 시작합니다.

  3. 작업 스케줄러에서 작업 일정 라이브러리 를 마우스 오른쪽 단추로 클릭하고 기본 작업 만들기...를 클릭합니다.

  4. 새 작업의 이름(예: SQLBackup)을 입력하고 다음을 클릭합니다.

  5. 작업 트리거에 대해 매일 을 선택하고 다음을 클릭합니다.

  6. 되풀이를 1일로 설정하고 다음을 클릭합니다.

  7. 작업 으로 프로그램 시작을 선택하고 다음을 클릭합니다.

  8. 찾아보기를 클릭하고 C 단계에서 생성한 배치 파일을 클릭한 다음 열기를 클릭합니다.

  9. 마침을 클릭하면 이 작업의 속성 열기 대화 상자를 선택합니다.

  10. 일반 탭에서,

    1. 보안 옵션을 검토하고 작업을 실행하는 사용자 계정에 대해 다음을 확인합니다(작업을 실행할 때 다음 사용자 계정 아래에 나열됨).

      계정에 sqlcmd 유틸리티를 시작할 수 있는 읽기 및 실행 권한이 있어야 합니다. 또한,

      • 배치 파일에서 Windows 인증을 사용하는 경우 작업 소유자가 SQL 백업을 수행할 수 있는지 확인합니다.

      • 배치 파일에서 SQL 인증을 사용하는 경우 SQL 사용자는 SQL 백업을 수행하는 데 필요한 권한이 있어야 합니다.

    2. 요구 사항에 따라 다른 설정을 조정합니다.

테스트로, 작업을 소유한 동일한 사용자 계정으로 시작된 명령 프롬프트에서 C단계의 배치 파일을 실행합니다.

이 문서에 설명된 절차를 사용할 때 다음 사항에 유의하세요.

  • 작업 스케줄러 서비스는 작업이 실행되도록 예약된 시간에 실행 중이어야 합니다. 이 서비스의 시작 유형을 자동으로 설정하는 것이 좋습니다. 이렇게 하면 다시 시작할 때도 서비스가 실행됩니다.

  • 백업이 기록되는 드라이브에 많은 공간이 있어야 합니다. 디스크 공간이 부족하지 않도록 백업 폴더의 이전 파일을 정기적으로 클린 것이 좋습니다. 스크립트에는 오래된 파일을 정리하는 논리가 포함되어 있지 않습니다.

추가 참조 자료

작업 스케줄러 개요