SSIS 카탈로그
SSISDB 카탈로그는 Integration Services 서버에 배포한 SSIS(Integration Services) 프로젝트의 작업을 수행할 수 있는 중앙 위치입니다. 예를 들어 프로젝트 및 패키지 매개 변수를 설정하고, 패키지의 런타임 값을 지정하기 위한 환경을 구성하고, 패키지를 실행하거나 문제를 해결하고, Integration Services 서버 작업을 관리할 수 있습니다.
SSISDB 카탈로그에 저장되는 개체에는 프로젝트, 패키지, 매개 변수, 환경 및 작업 기록이 있습니다.
SSISDB 데이터베이스에서 뷰를 쿼리하여 SSISDB 카탈로그에 저장된 개체, 설정 및 작업 데이터를 검사할 수 있습니다. SSISDB 데이터베이스에서 저장 프로시저를 호출하거나 SSISDB 카탈로그의 UI를 사용하여 개체를 관리할 수 있습니다. 대부분의 경우 UI를 사용하거나 저장 프로시저를 호출하여 동일한 태스크를 수행할 수 있습니다.
SSISDB 데이터베이스를 유지 관리하려면 사용자 데이터베이스 관리를 위한 표준 엔터프라이즈 정책을 적용하는 것이 좋습니다. 유지 관리 계획 만들기에 대해서는 유지 관리 계획을 참조하십시오.
SSISDB 카탈로그 및 SSISDB 데이터베이스는 Windows PowerShell을 지원합니다. Windows PowerShell과 SQL Server를 함께 사용하는 방법은 SQL Server PowerShell을 참조하십시오. Windows PowerShell을 사용하여 프로젝트 배포와 같은 태스크를 수행하는 방법의 예는 blogs.msdn.com에서 SQL Server 2012의 SSIS 및 PowerShell 블로그 항목을 참조하십시오.
작업 데이터를 보는 방법은 패키지 실행 및 기타 작업 모니터링을 참조하십시오.
SQL Server 데이터베이스 엔진에 연결한 다음 개체 탐색기에서 Integration Services 카탈로그 노드를 확장하여 SQL Server Management Studio에서 SSISDB 카탈로그에 액세스합니다. SQL Server Management Studio에서 SSISDB 데이터베이스에 액세스하려면 개체 탐색기에서 데이터베이스 노드를 확장하면 됩니다.
[!참고]
SSISDB 데이터베이스 이름은 바꿀 수 없습니다.
[!참고]
SSISDB 데이터베이스가 연결된 SQL Server 인스턴스가 중지되었거나 응답하지 않으면 ISServerExec.exe 프로세스가 종료됩니다. 메시지는 Windows 이벤트 로그에 기록됩니다.
SQL Server 리소스가 클러스터 장애 조치(Failover)의 일부로 장애 조치(Failover)되는 경우에는 실행 중인 패키지가 다시 시작되지 않습니다. 검사점을 사용하여 패키지를 다시 시작할 수 있습니다. 자세한 내용은 검사점을 사용하여 패키지 다시 시작을 참조하십시오.
카탈로그 개체 식별자
카탈로그에서 새 개체를 만든 경우 해당 개체에 이름을 할당합니다. 개체 이름은 식별자입니다. SQL Server에서는 식별자에 사용할 수 있는 문자에 대한 규칙을 정의합니다. 다음 개체의 이름은 식별자 규칙을 따라야 합니다.
폴더
프로젝트
환경
매개 변수
환경 변수
폴더, 프로젝트, 환경
폴더, 프로젝트 또는 환경의 이름을 바꿀 때 고려할 규칙은 다음과 같습니다.
ASCII/유니코드 문자 1~31, 따옴표("), 보다 작음(<), 보다 큼(>), 파이프(|), 백스페이스(\b), null(\0) 및 탭(\t)은 올바른 문자가 아닙니다.
이름은 선행 또는 후행 공백을 포함할 수 없습니다.
@를 첫 글자로 사용할 수 없습니다. 하지만 후속 글자에는 @를 사용할 수 있습니다.
이름의 길이는 1자에서 128자 사이여야 합니다.
매개 변수
매개 변수 이름을 지정할 때 고려할 규칙은 다음과 같습니다.
이름의 첫 글자는 Unicode Standard 2.0에서 정의한 문자이거나 밑줄(_)이어야 합니다.
후속 글자는 Unicode Standard 2.0에 정의된 문자 또는 숫자이거나 밑줄(_)일 수 있습니다.
환경 변수
환경 변수 이름을 지정할 때 고려할 규칙은 다음과 같습니다.
ASCII/유니코드 문자 1~31, 따옴표("), 보다 작음(<), 보다 큼(>), 파이프(|), 백스페이스(\b), null(\0) 및 탭(\t)은 올바른 문자가 아닙니다.
이름은 선행 또는 후행 공백을 포함할 수 없습니다.
@를 첫 글자로 사용할 수 없습니다. 하지만 후속 글자에는 @를 사용할 수 있습니다.
이름의 길이는 1자에서 128자 사이여야 합니다.
이름의 첫 글자는 Unicode Standard 2.0에서 정의한 문자이거나 밑줄(_)이어야 합니다.
후속 글자는 Unicode Standard 2.0에 정의된 문자 또는 숫자이거나 밑줄(_)일 수 있습니다.
카탈로그 구성
카탈로그 속성을 조정하여 카탈로그가 동작하는 방식을 세밀하게 조정할 수 있습니다. 카탈로그 속성은 중요한 데이터가 암호화되는 방법과 작업 및 프로젝트 버전 관리 데이터가 보존되는 방법을 정의합니다. 카탈로그 속성을 설정하려면 카탈로그 속성 대화 상자를 사용하거나 catalog.configure_catalog(SSISDB 데이터베이스) 저장 프로시저를 호출합니다. 속성을 보려면 대화 상자를 사용하거나 catalog.catalog_properties(SSISDB 데이터베이스)를 쿼리합니다. 개체 탐색기에서 SSISDB를 마우스 오른쪽 단추로 클릭하여 대화 상자에 액세스할 수 있습니다.
작업 및 프로젝트 버전 정리
카탈로그의 많은 작업에 대한 상태 데이터는 내부 데이터베이스 테이블에 저장됩니다. 예를 들어 카탈로그는 패키지 실행 및 프로젝트 배포 상태를 추적합니다. 작업 데이터의 크기를 유지 관리하기 위해 SQL Server Management Studio의 SSIS 서버 유지 관리 작업을 사용하여 오래된 데이터를 제거합니다. 이 SQL Server 에이전트 작업은 Integration Services가 설치될 때 만들어집니다.
카탈로그의 같은 폴더에 동일한 이름으로 배포하여 Integration Services 프로젝트를 업데이트하거나 다시 배포할 수 있습니다. 기본적으로 프로젝트를 다시 배포할 때마다 SSISDB 카탈로그에서 이전 버전의 프로젝트를 보존합니다. 작업 데이터의 크기를 유지 관리하기 위해 SSIS 서버 유지 관리 작업을 사용하여 오래된 버전의 프로젝트를 제거합니다.
이 SQL Server 에이전트 작업의 동작 방법은 다음 SSISDB 카탈로그 속성에 의해 정의됩니다. 카탈로그 속성 대화 상자를 사용하거나 catalog.catalog_properties(SSISDB 데이터베이스) 및 catalog.configure_catalog(SSISDB 데이터베이스)를 사용하여 속성을 보고 수정할 수 있습니다.
주기적으로 로그 정리
이 속성이 True로 설정된 경우 작업 정리를 위한 작업 단계가 실행됩니다.보존 기간(일)
허용 가능한 작업 데이터의 최대 수명(일)을 정의합니다. 오래된 데이터는 제거됩니다.최소값은 1일입니다. 최대값은 SQL Server int 데이터의 최대값에 의해서만 제한됩니다. 이 데이터 형식에 대한 자세한 내용은 int, bigint, smallint 및 tinyint(Transact-SQL)를 참조하십시오.
주기적으로 이전 버전 제거
이 속성이 True로 설정된 경우 프로젝트 버전 정리를 위한 작업 단계가 실행됩니다.프로젝트당 최대 버전 수
카탈로그에 저장되는 프로젝트 버전 수를 정의합니다. 오래된 버전의 프로젝트는 제거됩니다.
암호화 알고리즘
암호화 알고리즘 속성은 중요한 매개 변수 값을 암호화하는 데 사용되는 암호화 유형을 지정합니다. 다음 암호화 유형 중에서 선택할 수 있습니다.
AES_256(기본값)
AES_192
AES_128
DESX
TRIPLE_DES_3KEY
TRIPLE_DES
DES
Integration Services 프로젝트를 Integration Services 서버에 배포하는 경우 카탈로그에서 패키지 데이터와 중요한 값을 자동으로 암호화합니다. 카탈로그에서는 검색하는 데이터의 암호도 자동으로 해제합니다. SSISDB 카탈로그에서는 ServerStorage 보호 수준을 사용합니다. 자세한 내용은 패키지의 중요한 데이터에 대한 액세스 제어를 참조하십시오.
암호화 알고리즘을 변경하는 작업에는 시간이 많이 소비됩니다. 먼저 서버에서 이전에 지정된 알고리즘을 사용하여 모든 구성 값의 암호를 해독해야 합니다. 그런 다음 새 알고리즘을 사용하여 값을 다시 암호화해야 합니다. 그 동안 서버에서 다른 Integration Services 작업을 수행할 수 없습니다. 따라서 Integration Services 작업을 중단 없이 지속되게 하려면 암호화 알고리즘이 Management Studio의 대화 상자에서 읽기 전용 값으로 지정되어야 합니다.
암호화 알고리즘 속성 설정을 변경하려면 SSISDB 데이터베이스를 단일 사용자 모드로 설정한 다음 catalog.configure_catalog 저장 프로시저를 호출합니다. property_name 인수에 ENCRYPTION_ALGORITHM을 사용합니다. 지원되는 속성 값은 catalog.catalog_properties(SSISDB 데이터베이스)를 참조하십시오. 저장 프로시저에 대한 자세한 내용은 catalog.configure_catalog(SSISDB 데이터베이스)를 참조하십시오.
단일 사용자 모드에 대한 자세한 내용은 단일 사용자 모드로 데이터베이스 설정을 참조하십시오. SQL Server의 암호화 및 암호화 알고리즘에 대한 자세한 내용은 SQL Server 암호화 섹션의 항목을 참조하십시오.
데이터베이스 마스터 키는 암호화에 사용됩니다. 이 키는 카탈로그를 만들 때 생성됩니다. 자세한 내용은 SSIS 카탈로그 만들기를 참조하십시오.
다음 표에는 카탈로그 속성 대화 상자에 표시되는 속성 이름과 데이터베이스 뷰의 해당 속성이 나와 있습니다.
속성 이름(카탈로그 속성 대화 상자) |
속성 이름(데이터베이스 뷰) |
---|---|
암호화 알고리즘 이름 |
ENCRYPTION_ALGORITHM |
주기적으로 로그 정리 |
OPERATION_CLEANUP_ENABLED |
보존 기간(일) |
RETENTION_WINDOW |
주기적으로 이전 버전을 제거 |
VERSION_CLEANUP_ENABLED |
프로젝트당 최대 버전 수 |
MAX_PROJECT_VERSIONS |
서버 차원의 기본 로깅 수준 |
SERVER_LOGGING_LEVEL |
사용 권한
프로젝트, 환경 및 패키지는 보안 개체인 폴더에 포함됩니다. MANAGE_OBJECT_PERMISSIONS 권한을 포함하여 폴더에 대한 사용 권한을 부여할 수 있습니다. MANAGE_OBJECT_PERMISSIONS는 ssis_admin 역할에 대한 사용자 멤버 자격을 부여하지 않고도 사용자에게 폴더 내용에 대한 관리를 위임할 수 있습니다. 프로젝트, 환경 및 작업에 사용 권한을 부여할 수도 있습니다. 작업에는 Integration Services 초기화, 프로젝트 배포, 실행 만들기 및 시작, 프로젝트 및 패키지 유효성 검사, SSISDB 카탈로그 구성 등이 있습니다.
데이터베이스 역할에 대한 자세한 내용은 데이터베이스 수준 역할을 참조하십시오.
SSISDB 카탈로그는 ddl_cleanup_object_permissions DDL 트리거를 사용하여 SSIS 보안 개체에 대한 사용 권한 정보의 무결성을 보장합니다. 데이터베이스 사용자, 데이터베이스 역할 또는 데이터베이스 응용 프로그램 역할과 같은 데이터베이스 보안 주체가 SSISDB 데이터베이스에서 제거되면 트리거가 실행됩니다.
보안 주체가 다른 보안 주체에 대해 사용 권한을 부여하거나 거부한 경우 해당 보안 주체를 제거하려면 먼저 부여자가 제공한 사용 권한을 취소해야 합니다. 그러지 않으면 시스템에서 보안 주체를 제거하려고 할 때 오류 메시지가 반환됩니다. 트리거는 데이터베이스 보안 주체가 피부여자인 모든 사용 권한 레코드를 제거합니다.
트리거를 사용하면 데이터베이스 보안 주체가 SSISDB 데이터베이스에서 삭제된 후 분리된 사용 권한 레코드가 발생하지 않으므로 가능하면 트리거를 사용하도록 설정하는 것이 좋습니다.
사용 권한 관리
SQL Server Management Studio UI, 저장 프로시저 및 Microsoft.SqlServer.Management.IntegrationServicesnamespace 네임스페이스를 사용하여 사용 권한을 관리할 수 있습니다.
SQL Server Management Studio UI를 사용하여 사용 권한을 관리하려면 다음 대화 상자를 사용합니다.
폴더의 경우 폴더 속성 대화 상자의 사용 권한 페이지를 사용합니다.
프로젝트의 경우 프로젝트 속성 대화 상자의 사용 권한 페이지를 사용합니다.
환경의 경우 환경 속성 대화 상자의 사용 권한 페이지를 사용합니다.
Transact-SQL을 사용하여 사용 권한을 관리하려면 catalog.grant_permission(SSISDB 데이터베이스), catalog.deny_permission(SSISDB 데이터베이스) 및 catalog.revoke_permission(SSISDB 데이터베이스)을 호출합니다. 모든 개체의 현재 보안 주체에 대한 유효한 사용 권한을 보려면 catalog.effective_object_permissions(SSISDB 데이터베이스)를 쿼리합니다. 이 항목에서는 여러 유형의 사용 권한에 대해 설명합니다. 사용자에게 명시적으로 할당된 사용 권한을 보려면 catalog.explicit_object_permissions(SSISDB 데이터베이스)를 쿼리합니다.
폴더
폴더에는 SSISDB 카탈로그의 프로젝트 및 환경이 하나 이상 포함됩니다. catalog.folders(SSISDB 데이터베이스) 뷰를 사용하여 카탈로그의 폴더에 대한 정보에 액세스할 수 있습니다. 다음 저장 프로시저를 사용하여 폴더를 관리할 수 있습니다.
프로젝트 및 패키지
각 프로젝트에 여러 패키지를 포함할 수 있습니다. 프로젝트와 패키지 모두 매개 변수 및 환경 참조를 포함할 수 있습니다. 구성 대화 상자를 사용하여 매개 변수 및 환경 참조에 액세스할 수 있습니다.
다음 저장 프로시저를 호출하여 다른 프로젝트 태스크를 수행할 수 있습니다.
이러한 뷰는 패키지, 프로젝트 및 프로젝트 버전에 대한 자세한 정보를 제공합니다.
매개 변수
매개 변수를 사용하여 패키지 실행 시 패키지 속성에 값을 할당할 수 있습니다. 패키지 또는 프로젝트 매개 변수의 값을 설정하고 값을 지우려면 catalog.set_object_parameter_value(SSISDB 데이터베이스) 및 catalog.clear_object_parameter_value(SSISDB 데이터베이스)를 호출합니다. 실행 인스턴스에 대한 매개 변수 값을 설정하려면 catalog.set_execution_parameter_value(SSISDB 데이터베이스)를 호출합니다. catalog.get_parameter_values(SSISDB 데이터베이스)를 호출하여 기본 매개 변수 값을 검색할 수 있습니다.
이러한 뷰는 모든 패키지 및 프로젝트에 대한 매개 변수와 실행 인스턴스에 사용되는 매개 변수 값을 표시합니다.
서버 환경, 서버 변수 및 서버 환경 참조
서버 환경에는 서버 변수가 포함되어 있습니다. Integration Services 서버에서 패키지를 실행하거나 유효성을 검사할 때 변수 값을 사용할 수 있습니다.
다음 저장 프로시저를 사용하여 환경 및 변수에 대한 다른 많은 관리 태스크를 수행할 수 있습니다.
catalog.set_environment_variable_protection(SSISDB 데이터베이스) 저장 프로시저를 호출하여 변수에 대한 민감도 비트를 설정할 수 있습니다.
서버 변수 값을 사용하려면 프로젝트와 서버 환경 간의 참조를 지정합니다. 다음 저장 프로시저를 사용하여 참조를 만들거나 삭제할 수 있습니다. 환경을 프로젝트와 같은 폴더에서 찾을 수 있는지, 아니면 다른 폴더에서 찾을 수 있는지를 나타낼 수도 있습니다.
환경 및 변수에 대한 자세한 정보를 보려면 이러한 뷰를 쿼리하십시오.
실행 및 유효성 검사
실행은 패키지 실행의 인스턴스입니다. catalog.create_execution(SSISDB 데이터베이스) 및 catalog.start_execution(SSISDB 데이터베이스)을 호출하여 실행을 만들고 시작할 수 있습니다. 실행 또는 패키지/프로젝트 유효성 검사를 중지하려면 catalog.stop_operation(SSISDB 데이터베이스)을 호출합니다.
실행 중인 패키지를 일시 중지하고 덤프 파일을 만들려면 catalog.create_execution_dump 저장 프로시저를 호출합니다. 덤프 파일은 실행 문제를 해결하는 데 도움이 될 수 있는 패키지 실행에 대한 정보를 제공합니다. 덤프 파일을 생성하고 구성하는 방법은 패키지 실행을 위한 덤프 파일 생성을 참조하십시오.
실행, 유효성 검사, 작업 중에 기록되는 메시지 및 오류와 관련된 상황별 정보에 대한 자세한 정보를 보려면 이러한 뷰를 쿼리하십시오.
catalog.validate_project(SSISDB 데이터베이스) 및 catalog.validate_package(SSISDB 데이터베이스) 저장 프로시저를 호출하여 프로젝트 및 패키지의 유효성을 검사할 수 있습니다. catalog.validations(SSISDB 데이터베이스) 뷰는 유효성 검사에서 고려되는 서버 환경 참조, 유효성 검사가 종속성 유효성 검사인지 또는 전체 유효성 검사인지 여부, 패키지를 실행하는 데 32비트 런타임이 사용되는지 또는 64비트 런타임이 사용되는지 여부 등에 대한 자세한 정보를 제공합니다.
관련 태스크
관련 내용
blogs.msdn.com의 블로그 항목 - SQL Server 2012의 SSIS 및 PowerShell
blogs.msdn.com의 블로그 항목 - SSIS 카탈로그 액세스 제어 팁
blogs.msdn.com의 블로그 항목 - SSIS 카탈로그 관리 개체 모델에 대한 이해
|