다른 컴퓨터로 보고서 서버 데이터베이스 이동

현재 설치에 사용되는 보고서 서버 데이터베이스를 다른 컴퓨터에 있는 SQL Server데이터베이스 엔진 인스턴스로 이동할 수 있습니다. reportserver 데이터베이스와 reportservertempdb 데이터베이스를 모두 이동하거나 함께 복사해야 합니다. Reporting Services를 설치하려면 두 데이터베이스가 모두 필요합니다. reportservertempdb 데이터베이스는 이동하는 주 reportserver 데이터베이스와 이름으로 관련되어야 합니다.

데이터베이스를 이동해도 보고서 서버 항목에 대해 현재 정의되어 있는 예약된 작업에는 영향을 주지 않습니다.

  • 일정은 보고서 서버 서비스를 처음으로 다시 시작할 때 다시 만들어집니다.

  • 일정을 트리거하는 데 사용되는 SQL Server 에이전트 작업은 새 데이터베이스 인스턴스에서 다시 만들어집니다. 해당 작업을 새 컴퓨터로 이동하지 않아도 되지만 더 이상 사용되지 않을 컴퓨터 작업은 삭제할 수 있습니다.

  • 구독, 캐시된 보고서 및 스냅숏은 이동된 데이터베이스에 그대로 유지됩니다. 데이터베이스를 이동한 후 스냅숏이 새로 고친 데이터를 가져오지 않은 경우 보고서 관리자에서 스냅숏 옵션의 선택을 취소하고 적용을 클릭하여 변경 내용을 저장합니다. 그런 다음 일정을 다시 만들고 적용을 클릭하여 변경 내용을 저장합니다.

  • reportservertempdb에 저장된 임시 보고서 및 사용자 세션 데이터는 해당 데이터베이스를 이동해도 그대로 유지됩니다.

SQL Server에서는 백업 및 복원, 연결 및 분리, 복사를 비롯한 여러 가지 방법으로 데이터베이스를 이동할 수 있습니다. 기존 데이터베이스 위치를 새 서버 인스턴스로 다시 지정하는 데 이러한 방법이 모두 적합한 것은 아닙니다. 보고서 서버 데이터베이스를 이동하는 데 사용해야 하는 방법은 시스템 가용성 요구 사항에 따라 달라집니다. 보고서 서버 데이터베이스를 이동하는 가장 쉬운 방법은 데이터베이스를 분리 후 연결하는 것입니다. 그러나 이 방법을 사용하려면 데이터베이스를 분리하는 동안 보고서 서버를 오프라인 상태로 설정해야 합니다. 서비스 장애를 최소화하려면 백업 및 복원을 사용하는 것이 낫지만 Transact-SQL 명령을 실행하여 작업을 수행해야 합니다. 데이터베이스 복사 마법사를 사용하여 데이터베이스를 복사할 경우 데이터베이스의 사용 권한 설정이 유지되지 않으므로 이 방법은 사용하지 않는 것이 좋습니다.

중요 정보중요

이 항목에 설명된 단계는 기존 설치에서 보고서 서버 데이터베이스를 재배치하는 작업만 수행하려는 경우에 사용하는 것이 좋습니다. 전체 Reporting Services 설치를 마이그레이션하려면, 즉 데이터베이스를 이동하고 해당 데이터베이스를 사용하는 보고서 서버 Windows 서비스의 ID를 변경하려면 연결을 다시 구성하고 암호화 키를 다시 설정해야 합니다. Reporting Services 설치를 마이그레이션하는 방법은 마이그레이션(Reporting Services)을 참조하십시오.

보고서 서버 데이터베이스 분리 및 연결

보고서 서버를 오프라인 상태로 만들 수 있는 경우 데이터베이스를 분리한 후 사용하려는 SQL Server 인스턴스로 이동할 수 있습니다. 이 방법을 사용하면 데이터베이스의 사용 권한이 유지됩니다. SQL Server 2008 데이터베이스를 사용하는 경우 이를 다른 SQL Server 2008 인스턴스로 이동해야 합니다. 데이터베이스를 이동한 후에는 보고서 서버와 보고서 서버 데이터베이스의 연결을 다시 구성해야 합니다. 확장 배포를 실행하려면 배포 환경의 각 보고서 서버에 대한 보고서 서버 데이터베이스 연결을 다시 구성해야 합니다.

다음 단계에 따라 데이터베이스를 이동하십시오.

  1. 이동하려는 보고서 서버 데이터베이스의 암호화 키를 백업합니다. Reporting Services 구성 도구를 사용하여 키를 백업할 수 있습니다.

  2. 보고서 서버 서비스를 중지합니다. Reporting Services 구성 도구를 사용하여 서비스를 중지할 수 있습니다.

  3. SQL ServerManagement Studio를 시작하고 보고서 서버 데이터베이스를 호스팅하는 SQL Server 인스턴스에 대한 연결을 엽니다.

  4. 보고서 서버 데이터베이스를 마우스 오른쪽 단추로 클릭하고 작업을 가리킨 다음 분리를 클릭합니다. 보고서 서버 임시 데이터베이스에 대해 이 단계를 반복합니다.

  5. 사용하려는 SQL Server 인스턴스의 데이터 폴더로 .mdf 및 .ldf 파일을 복사하거나 이동합니다. 두 개의 데이터베이스를 이동하고 있으므로 이동하거나 복사하는 파일이 모두 네 개인지 확인합니다.

  6. Management Studio에서 보고서 서버 데이터베이스를 호스팅할 새 SQL Server 인스턴스에 대한 연결을 엽니다.

  7. 데이터베이스 노드를 마우스 오른쪽 단추로 클릭한 다음 연결을 클릭합니다.

  8. 추가를 클릭하고 연결할 보고서 서버 데이터베이스 .mdf 및 .ldf 파일을 선택합니다. 보고서 서버 임시 데이터베이스에 대해 이 단계를 반복합니다.

  9. 데이터베이스가 연결되면 RSExecRole이 보고서 서버 데이터베이스와 임시 데이터베이스의 데이터베이스 역할인지 확인합니다. RSExecRole에는 보고서 서버 데이터베이스 테이블에 대한 선택, 삽입, 업데이트, 삭제 및 참조 권한과 저장 프로시저에 대한 실행 권한이 있어야 합니다. 자세한 내용은 방법: RSExecRole 만들기를 참조하십시오.

  10. Reporting Services 구성 도구를 시작하고 보고서 서버에 대한 연결을 엽니다.

  11. 데이터베이스 페이지에서 새 SQL Server 인스턴스를 선택한 다음 연결을 클릭합니다.

  12. 방금 이동한 보고서 서버 데이터베이스를 선택한 다음 적용을 클릭합니다.

  13. 암호화 키 페이지에서 복원을 클릭합니다. 키의 백업 복사본이 들어 있는 파일과 파일의 잠금을 해제하기 위한 암호를 지정합니다.

  14. 보고서 서버 서비스를 다시 시작합니다.

보고서 서버 데이터베이스 백업 및 복원

보고서 서버를 오프라인으로 설정할 수 없는 경우 백업 후 복원 방법을 사용하여 보고서 서버 데이터베이스 위치를 다시 지정할 수 있습니다. 'Copy_Only' 옵션을 사용해야 합니다. SQL Server 2008부터 SQL Server Management Studio에서 복사 전용 백업이 지원됩니다. 데이터베이스를 복원한 후에 새 서버 인스턴스의 데이터베이스를 사용하도록 보고서 서버를 구성해야 합니다. 자세한 내용은 이 항목의 마지막 부분에 있는 지침을 참조하십시오.

BACKUP 및 COPY_Only를 사용하여 보고서 서버 데이터베이스 백업

데이터베이스를 백업할 때는 COPY_Only 옵션 및 백업 유형을 전체로 설정합니다.

[!참고]

ReportServerReportServerTempDB 데이터베이스와 연결된 로그 파일을 모두 백업해야 합니다.

SQL Server Management Studio 를 사용하여 데이터베이스를 백업하는 방법에 대한 자세한 내용은 방법: 데이터베이스 백업(SQL Server Management Studio)을 참조하십시오.

RESTORE 및 MOVE를 사용하여 보고서 서버 데이터베이스 위치 다시 지정

데이터베이스를 복원할 때는 RESTORE WITH NORECOVERY 인수를 사용하여 초기 복원을 수행할 수 있습니다. 이렇게 하면 데이터베이스가 복원 중 상태로 유지되므로 로그 백업을 검토하여 복원할 사항을 결정할 수 있습니다. 그런 후에 RESTORE WITH RECOVERY 인수를 사용하여 RESTORE 작업을 반복합니다.

[!참고]

ReportServerReportServerTempDB 데이터베이스와 연결된 로그 파일을 모두 복원해야 합니다.

SQL Server Management Studio 를 사용하여 데이터베이스를 복원하는 방법에 대한 자세한 내용은 방법: 데이터베이스 백업 복원(SQL Server Management Studio)을 참조하십시오.

보고서 서버 데이터베이스 연결을 구성하는 방법

  1. Reporting Services 구성 도구를 시작하고 보고서 서버에 대한 연결을 엽니다.

  2. 데이터베이스 페이지에서 데이터베이스 변경을 클릭합니다. 다음을 클릭합니다.

  3. 기존 보고서 서버 데이터베이스 선택을 클릭합니다. 다음을 클릭합니다.

  4. 이제 보고서 서버 데이터베이스를 호스팅하는 SQL Server를 선택하고 연결 테스트를 클릭합니다. 다음을 클릭합니다.

  5. 데이터베이스 이름에서 사용하려는 보고서 서버 데이터베이스를 선택합니다. 다음을 클릭합니다.

  6. 자격 증명에 보고서 서버가 보고서 서버 데이터베이스에 연결하는 데 사용할 자격 증명을 지정합니다. 다음을 클릭합니다.

  7. 다음, 마침을 차례로 클릭합니다.

[!참고]

Reporting Services를 설치하려면 SQL Server 데이터베이스 엔진 인스턴스에 RSExecRole 역할을 포함해야 합니다. Reporting Services 구성 도구를 통해 보고서 서버 데이터베이스 연결을 설정하면 역할 만들기, 로그인 등록 및 역할 할당이 발생합니다. rsconfig.exe 명령 프롬프트 유틸리티를 사용하는 등 다른 방법을 사용하여 연결을 구성하면 보고서 서버가 작동 상태에 있지 않게 됩니다. 이 경우 WMI 코드를 작성하여 보고서 서버를 사용할 수 있게 만들어야 할 수 있습니다. 자세한 내용은 Reporting Services WMI 공급자를 참조하십시오.