KR100259432B1 - 볼륨 스태킹 라이브러리에서의 아웃 보드 데이터 이동 - Google Patents

볼륨 스태킹 라이브러리에서의 아웃 보드 데이터 이동 Download PDF

Info

Publication number
KR100259432B1
KR100259432B1 KR1019970045142A KR19970045142A KR100259432B1 KR 100259432 B1 KR100259432 B1 KR 100259432B1 KR 1019970045142 A KR1019970045142 A KR 1019970045142A KR 19970045142 A KR19970045142 A KR 19970045142A KR 100259432 B1 KR100259432 B1 KR 100259432B1
Authority
KR
South Korea
Prior art keywords
data
tape cartridge
tape
identifier
cartridge
Prior art date
Application number
KR1019970045142A
Other languages
English (en)
Other versions
KR19980069918A (ko
Inventor
조나단 웨인 패크
Original Assignee
포만 제프리 엘
인터내셔널 비지네스 머신즈 코포레이션
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 포만 제프리 엘, 인터내셔널 비지네스 머신즈 코포레이션 filed Critical 포만 제프리 엘
Publication of KR19980069918A publication Critical patent/KR19980069918A/ko
Application granted granted Critical
Publication of KR100259432B1 publication Critical patent/KR100259432B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B23/00Record carriers not specific to the method of recording or reproducing; Accessories, e.g. containers, specially adapted for co-operation with the recording or reproducing apparatus ; Intermediate mediums; Apparatus or processes specially adapted for their manufacture
    • G11B23/02Containers; Storing means both adapted to cooperate with the recording or reproducing means
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0604Improving or facilitating administration, e.g. storage management
    • G06F3/0605Improving or facilitating administration, e.g. storage management by facilitating the interaction with a user or administrator
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0646Horizontal data movement in storage systems, i.e. moving data in between storage devices or systems
    • G06F3/0647Migration mechanisms
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0683Plurality of storage devices
    • G06F3/0686Libraries, e.g. tape libraries, jukebox
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99951File or database maintenance
    • Y10S707/99952Coherency, e.g. same view to multiple users
    • Y10S707/99953Recoverability
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99951File or database maintenance
    • Y10S707/99952Coherency, e.g. same view to multiple users
    • Y10S707/99955Archiving or backup

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Library & Information Science (AREA)
  • Management Or Editing Of Information On Record Carriers (AREA)

Abstract

본 발명에서는 데이터와 관련된 식별자(identifier)가 소스 매체로부터 획득되고, 데이터/식별자 쌍을 거의 연속적인 형태로 타겟 매체 내에 저장함으로써 데이터 및 관련된 식별자가 통합되는 자동화된 테입 라이브러리(tape library) 내에서, 데이터가 소스 매체로부터 타겟 매체로 이동된다. 마그네틱 테입 카트리지와 같은 복수개의 소스 매체 유닛들이 라이브러리에 첫 번째로 로드된다. 각각의 소스 매체 유닛은 하나 이상의 블록들을 포함하고 있으며, 또한 각각의 데이터 블록과 관련된 기계 판독 가능한 식별자를 가지고 있다. 예를 들어, 상기 기계 판독 가능한 식별자는 매체 유닛의 하우징 상에 프린트된 기계 판독 가능한 코드 또는 매체 자체에 저장된 코드에 의해 구현될 수 있다. 각각의 데이터 블록에 대한 식별자는 해당되는 소스 매체를 사용하여 획득된다. 다수의 데이터 블록들 및 식별자들이 단일 출력 매체 유닛 상으로 통합될 수 있다. 각각의 출력 매체 유닛 상의 데이터 블록 및 식별자는 각각의 출력 매체 유닛 상에 거의 연속적인 형태로 기록되고, 각각의 출력 매체 유닛 상에서 데이터 블록 및 관련된 식별자는 서로 간에 미리 정해진 상대적인 상호 관계로 위치된다. 예를 들어, 각각의 식별자는 관련된 데이터 블록에 선행할 수 있다. 각자의 출력 매체 유닛들 사이에서 데이터 블록들을 맵핑(map)하기 위해 카탈로그(catalog)가 생성되거나 갱신된다.

Description

볼륨 스태킹 라이브러리에서의 아웃보드 데이터 이동
본 발명은 마그네틱 테입(magnetic tape)과 같은 데이터 저장 매체를 관리하는 데이터 저장 라이브러리(data storage library)에 관한 것이다. 좀 더 구체적으로는, 본 발명은 소스 매체로부터 타겟 매체로의 데이터 이동에 관한 것으로 여기서 데이터와 관련된 식별자(identifier)는 소스 매체로부터 획득되고, 데이터 및 관련된 식별자를 거의 연속적인 형태로 타겟 매체 상에 저장함으로써 데이터 및 관련된 식별자가 통합된다.
많은 애플리케이션에서, 마그네틱(magnetic) 또는 광(optical) 테입이 저장 매체로 선택되고 있다. 테입 매체는 역사적 또는 법률적인 이유(historical or legal reasons) 등으로 인하여 장기간 저장되어야 하는 데이터에 특히 유용하다. 테입 매체는, 직접 접근 저장 장치(direct access storage device: DASD)로부터의 데이터 이동 및 백업과 같은 단기간 (예를 들어, 1 내지 12 개월)의 저장용으로도 또한 널리 사용된다. 테입 매체의 하나의 일반적인 형태는 테입 카트리지인데, 이러한 테입 카트리지는 소형이고 규격화(compact and modular)되어 있어 테입 라이브러리용으로 사용하기에 특히 편리하다.
이론적으로는, 테입 카트리지는 데이터를 경제적으로 저장하는 하나의 방법이 될 수 있다. 불행하게도, 실제 상황에서 대부분의 테입 관리 방법은 테입 카트리지 당 적은 블록의 관련된 데이터를 저장하는데, 이러한 데이터는 전형적으로 50 Mb 이하를 점유한다. 오늘날 상업적으로 이용 가능한 다수의 테입 카트리지는 800 Mb를 저장할 수 있으며, 25 Gb 이상을 저장 할 수 있는 것도 있으므로, 테입 저장 용량 중 작은 일부분만이 사용되는 셈이다. 따라서, 데이터는 다수의 관련되지 않은 데이터 블록들이 단일 테입 카트리지 상에 통합되었을 경우에 점유하게 될 테입 카트리지보다 훨씬 더 많은 테입 카트리지를 점유한다. 결과적으로, 통상적인 데이터 저장 장치 또는 테입 카트리지는 저장된 데이터 유닛당 고 비용을 요구한다.
최근에는, 테입 작동자(tape operator) 및 테입의 수동 조작을 사용하지 않음으로써 테입 저장 장치의 비용을 어느 정도 감소시키는 자동화된 테입 라이브러리가 소개되고 있다. 그러나, 자동화된 테입 라이브러리도 테입 카트리지의 저장 용량의 사용면에서는 개선이 이루어지지 않고 있다.
데이터를 저장하는데 드는 초기 비용으로는 테입 카트리지, CPU 시간, 테입 장치 사용, 테입 작동자에 의한 조작 등의 비용이 포함된다. 이러한 초기 비용이 지출된 후에도, 카트리지 저장 장치에서는 랙 저장 공간, 테입 카트리지 기후 제어(tape cartridge climate control), 접근 비용 등과 같은 여러 종류의 비용이 여전히 발생된다. 카트리지들은 최초에 자동화된 라이브러리 내에 기록되는데, 이 경우 고객 시스템 관리자(system administrator)는 라이브러리 내의 카트리지를 주기적으로 평가하고 사용 빈도가 낮은 카트리지를 식별하여 자동화된 라이브러리의 한정된 용량으로부터 제거하는 것이 필요하다. 이러한 접근 빈도가 낮은(low-access) 카트리지를 라이브러리로부터 제거하여 외부 저장 선반(shelves)에 수용하는데 추가 비용이 필요하다. 앞서 설명한 팩터들은 데이터를 테입 상에 저장하는데 드는 실제 비용을 크게 증가시킨다. 따라서, 데이터를 테입 상에 더 효과적으로 저장하여 비용을 절감하도록 하는 새로운 방법을 계속적으로 개발할 필요가 있다.
테입 상에 데이터를 더 효과적으로 저장하는 하나의 공지된 방법은 볼륨 스태킹(volume stacking)이다. 볼륨 스태킹이란, 그렇지 않았더라면 분리된 테입 카트리지("볼륨")에 저장되었을 다수의 별개 데이터 블록들을 단일의 테입 카트리지에 통합하는 것을 의미한다. 볼륨 스테킹은 다수의 고객 볼륨들을 단일의 물리적인 볼륨 상에 위치시킴으로써 자동화된 라이브러리 내에서 이용 가능한 저장 장치 셀들의 수를 효과적으로 배가시킨다. 예를 들어, 통상의 고객은 각각 평균 50 Mb의 실제 데이터를 포함하는 100,000 개의 카트리지를 가질 수 있다. 총 실제 데이터는 5 Tb이다. 만약 데이터가 10 Gb의 용량을 가진 카트리지 상으로 이동된다면, 500 개의 테입 카트리지만이 필요하게된다. 이는 200 : 1의 감소를 나타낸다. 이러한 감소를 고려하면, 자주 접근되지 않는 데이터를 자동화된 시스템 내에 유지하는 것이 경제적으로 훨씬 더 타당할 수 있고, 그러한 시스템의 총 비용 및 작동 이익을 얻는다.
새롭게 생성된 데이터에 대해서는, 데이터 수신시에 데이터를 볼륨 스태킹을 실행하는 자동화된 라이브러리 내로 향하게 함으로써 볼륨 스태킹이 쉽게 구현된다. 그러나, 기존의 쉘프 데이터(shelf data)를 볼륨 스택(volume-stacked)된 형태로 이동("migrate")하는 것은 훨씬 더 어려운 문제이다. 그러한 이동을 수행하는 하나의 접근 방법은 각각의 볼륨을 라이브러리 내에 장착하여 볼륨의 내용을 라이브러리 내의 볼륨 및 디바이스 상으로 전자적으로 복제하는 호스트 애플리케이션을 수행하는 것이다. 이러한 접근 방법 중 하나의 예로는 Mobius 테입 보관 제품(tape saver product)이 있다. 이들과 같은 공지의 접근 방법들이 몇 몇 애플리케이션에는 적합할 수 있지만, 시스템 프로그래머, CPU, 및 잠재적으로 수 십만개의 테입 카트리지를 조작하는데 필요한 테입 작동자 리소스 측면에서 볼때에 상당한 고비용이 든다. 즉, 그러한 접근 방법은 앞선 별개의 데이터 그룹의 통합을 감독하고, 통합된 데이터에 새로운 볼륨 일련 번호(volume serial number: "volser")를 할당하며, 앞선 별개의 각 데이터 블록에 대한 볼륨 일련 번호에 변경된 내용을 반영하기 위하여 카탈로그를 갱신하고, 다른 관련된 업무(task)를 수행한다.
이러한 접근 방법은 시간 소모적 이라는 점 이외에도, 복제 과정 도중 볼륨 일련 번호가 필연적으로 변경되기 때문에 카탈로그되지 않은(uncatalogued) 볼륨 상에 포함된 데이터에 대해서는 적용되지 않는 문제점이 있다.
데이터 이동 중에 고려되어야 할 또 다른 점은 자동 카트리지 라이브러리에 의해 조작되는 카트리지가 일반적으로 볼륨을 식별하기 위해 외부 기계 판독 가능한 라벨을 필요로 한다는 것이다. 기존의 카트리지를 라이브러리 내로 단지 이동하기 위해 이들 기존의 카트리지를 기계 판독 가능한 라벨로 재 라벨링(re-labeling)하는 것은 비용이 많이 들 수 있으며 또한 시간 소모를 초래할 수 있다.
본 발명은 소스 매체로부터 타겟 매체로의 데이터 이동에 관한 것이다. 여기서 데이터와 관련된 식별자(identifier)는 소스 테입 매체로부터 획득되고, 데이터 및 관련된 식별자를 거의 연속적인 형태로 타겟 매체 상에 저장함으로써 데이터 및 관련된 식별자가 통합된다.
도 1은 본 발명에 따른 장치의 하나의 예시적인 실시예에 있어서 하드웨어 요소 및 상호 연결 관계를 보여주는 블록도.
도 2는 본 발명에 따른 제품의 예를 보여주는 다이어그램.
도 3은 본 발명의 하나의 예시적인 실시예에 따라 데이터를 소스 테입 카트리지로부터 캐쉬로 이동하는데 사용되는 동작 단계의 순서를 도시한 플로우챠트.
도 4는 본 발명의 하나의 예시적인 실시예에 따라 데이터를 캐쉬로부터 자동화된 테입 라이브러리로 이동하는데 사용되는 동작 단계의 순서를 도시한 플로우챠트.
〈도면의 주요부분에 대한 부호의 설명〉
100 : 데이터 저장장치 서브 시스템
102 : 호스트
104 : 저장장치 인터페이스
106 : 캐쉬
108 : 자동화된 테입 라이브러리
110 : 저장장치 제어기
112 : 캐쉬 관리기
116 : 입력 설비
118 : 출력 설비
120 : 빈(bin)
122 : 피커(picker)
124 : 테입(tape)
본 발명의 하나의 실시예에서는 데이터가 자동화된 테입 라이브러리를 사용하여 통합된다. 먼저, 복수개의 소스 테입 매체 유닛들이 라이브러리의 로딩 메카니즘(loading mechanism)에 로드된다. 각각의 소스 테입 매체 유닛은 데이터 블록을 포함하고, 데이터 블록에 관련된 볼륨 일련 번호("volser")와 같은 기계 판독 가능한 식별자를 제공한다. 예를 들어, 기계 판독 기능한 식별자는 IBM 표준 또는 ANSI 표준 에이프 라벨(ape label)과 같은, 테입 매체 유닛의 하우징 상에 프린트된 기계 판독 가능한 코드 또는 테입 매체 자체에 저장된 코드에 의해 구현될 수 있다. 각각의 데이터 블록에 대한 식별자는 해당되는 소스 테입 매체를 사용하여 결정된다.
데이터 블록 및 해당되는(corresponding) 식별자는 하나 이상의 타겟 테입 매체 유닛으로 통합되는데, 각각의 데이터 그룹 및 관련(associated)된 식별자는 하나의 동일한 타겟 테입 매체 유닛 상에 함께 저장된다. 데이터 블록 및 식별자는 타겟 테입 매체 유닛 상에 거의 연속적인 형태로 기록되고, 각각의 타겟 테입 매체 상의 데이터 블록 및 관련된 식별자는 서로에 대하여 미리 정해진 상대적인 상호 관계로 위치된다. 예를 들어, 각각의 식별자는 관련된 데이터 블록에 선행하는 헤더(header)에 의해 구현될 수 있다. 카탈로그는 데이터 블록 및 데이터 블록과 관련된 타겟 테입 매체 유닛 사이의 상호 관계를 맵핑(map)하기 위해 생성되거나 갱신된다.
따라서, 하나의 실시예에서 본 발명은 상기에서 기술된 것들과 같은 동작 단계들을 사용하여 데이터를 이동시키는 방법을 제공하도록 구현될 수 있다. 다른 실시예에서는, 본 발명에 따른 데이터를 이동시키기 위한 장치를 제공하도록 본 발명이 구현될 수 있다. 또 다른 실시예에서는, 본 발명에 따른 데이터를 이동시키기 위한 방법을 수행하기 위한 디지털 데이터 처리 장치에 의해 수행될 수 있는 기계 판독 가능한 명령어들로 구성된 프로그램을 유형적으로(tangibly) 구현하는 데이터 저장 장치를 포함하는 제품을 제공하도록 본 발명이 구현될 수 있다.
본 발명은 사용자에게 다수의 분명한 장점들을 제공한다. 본 발명은 고객이나, 시스템 프로그래머, 또는 호스트 리소스로 하여금 이동 처리를 수행할 것을 요구함이 없이 구현될 수 있다는 점이 중요하다. 또 다른 장점으로는, 각각의 카트리지를 개별적으로 장착하는 대신에 작동자는 동시에 많은 수의 카트리지를 로드할 수 있다는 것이다. 예를 들어, 작동자는 라이브러리의 입력 설비 용량과 관련하여 가능한 수 만큼의 카트리지를 로드할 수 있다. 본 발명의 또 다른 잇점은 앞서 카탈로그되지 않은 데이터셋을 지원하여 데이터 블록의 식별자(예를 들어, 볼륨 일련 번호)와 데이터의 초기 블록 사이의 연관 관계를 유지하는 것이다. 또한, 본 발명에서는 데이터 블록과 관련된 최초의 볼륨 일련 번호가 동일하게 유지되고, 데이터의 이동이 테입 관리 시스템 및 작업 제어 언어(job control language)와 같은 고객 애플리케이션에 투명(transparent)하기 때문에 사용하기에 편리하다. 또한, 본 발명은 기계 판독 가능한 외부 라벨로 이동된 카트리지의 재 라벨링(re-labeling)을 필요로 하지 않기 때문에 효율이 향상된다.
본 발명의 특징, 목적 및 장점은 첨부 도면과 관련하여 이하의 상세한 설명을 살펴보면 당업자들에게 보다 명백해질 것이다.
하드웨어 요소 및 상호 연결 관계
본 발명의 하나의 특징은 다양한 하드웨어 구성에 의해 구현될 수 있는 데이터 이동 장치에 관한 것이다. 하나의 예가 도 1의 하드웨어 요소 및 상호 연결 관계에 의해 구현된 데이터 저장 서브 시스템 (100)으로 도시되어 있다. 서브 시스템 (100)은 하나 이상의 호스트 (102), 저장 장치 인터페이스 (104) 및 자동화된 테입 라이브러리 (108)을 포함한다. 아래에서 설명되는 이유로 인하여 서브 시스템 (100)은 또한 캐쉬 (106)을 선택적으로 포함할 수 있다.
대개, 호스트 (102)는 캐쉬 (106) 및 라이브러리 (108) 상에 저장된 데이터를 사용하는 하나 이상의 유닛을 포함한다. 저장 장치 인터페이스(104)는 호스트 (102)와 캐쉬 (106) 사이의 데이터, 및 호스트 (102)와 라이브러리 (108) 사이의 데이터를 교환한다. 이러한 교환은 호스트 (102)로부터의 커맨드(command)에 따라 수행된다. 호스트 (102)는 메인 프레임 또는 개인용 컴퓨터; 워크스테이션; 사용자 콘솔, 키보드 또는 터미널; 애플리케이션 프로그램 등과 같은 다양한 형태 및 다수의 유닛들에 의해 구현될 수 있다.
자동화된 테입 라이브러리 (108)은 테입 (124)와 같은 테입의 저장, 로딩, 언로딩, 이동, 기록 및 판독을 관리하는 장치를 포함한다. 테입 (124)는 복수의 빈(bins) (120)에 저장된다. 로봇 팔(robotic arm)과 같은 피커(picker) (122)는 선택적으로 테입 (124)를 출력 설비 (118)로부터 입력 설비 (116)으로 이동하도록 지시하며, 테입 드라이브 (126)에서 테입 드라이브 (126)으로 이동하도록 지시한다. 예를 들어, 입력 설비 (116)은 하나 이상의 테입 저장장치 슬롯과 함께 작동자로부터 테입을 수령하기 위한 일괄 로딩 메카니즘(batch loading mechanism)(도시되지 않음)을 포함할 수 있다. 유사한 방법으로, 출력 설비 (118)은 하나 이상의 테입 저장장치 슬롯과 함께 라이브러리 (108)로부터 작동자로 테입을 전달하기 위한 일괄 출력 메카니즘(batch output mechanism)(도시되지 않음)을 포함할 수 있다.
테입 라이브러리 (108)은 새로운 구조 또는 통상적인 테입 라이브러리를 포함할 수 있다. 예를 들어, 테입 라이브러리 (108)은 적어도 (1) IBM CST 테입(18 또는 36 트랙으로 포맷된 표준 카트리지 시스템 테입) 및 IBM ECCST 테입(36 트랙으로 포맷된 용량이 향상된 카트리지 시스템 테입) 형태의 테입을 액세스하기 위한 IBM 3490 모델 C2A 테입 드라이브 및 (2) IBM HPCT 테입(128 트랙으로 포맷된 고성능 카트리지 테입)을 액세스하기 위한 IBM 3590 모델 B2A 테입 드라이브를 갖는 IBM 모델 3494 테입 라이브러리를 포함할 수 있다. 라이브러리 (108)은 또한 라이브러리 (108)의 동작을 감독하는 테입 라이브러리 관리기 (114)를 포함하고, 라이브러리 (108)에 의해 구현된 특정 구성을 위해 새로운 구조 또는 통상적인 관리기를 포함할 수 있다. 예시된 예에서는, 테입 라이브러리 관리기(114)는 IBM 모델 3494 테입 라이브러리에 사용되는 라이브러리 관리기를 포함할 수 있다.
선택적인 요소인 캐쉬 (106)은 서브 시스템 (100) 내에 포함되어 데이터 저장 장치 주소에 빠른 접근을 제공할 수 있다. 이하에서 상세히 설명되는 바와 같이, 새롭게 수신된 데이터는 캐쉬 (106) 내에 먼저 저장된 후, 테입 라이브러리 (108)로 즉시 이동되거나, 또는 사용되지 않은 기간 또는 레벨과 같은 어떤 기준을 만족할 때 테입 라이브러리 (108)로 이동될 수 있다. 예시된 실시예에서, 캐쉬 (106)은 큰 데이터 용량을 갖는 "하드 드라이브(hard drive)"와 같은 자기 디스크 저장 장치를 포함할 수 있다.
저장 장치 인터페이스 (104)는 저장 장치 제어기 (110), 캐쉬 관리기 (112) 및 카탈로그 (128)을 포함한다. 캐쉬 관리기 (112)는 캐쉬 (106)의 동작을 감시하고, 캐쉬 (106)에 의해 구현된 데이터 저장 장치 타입을 위해 새로운 구조 또는 통상적인 관리기를 포함할 수 있다. 예시된 예에서, 캐시 관리기 (112)는 디스크 드라이브 제어기를 포함할 수 있다. 카탈로그 (128)은 저장 장치 제어기 (110)에 의해 사용되어 데이터 저장 서브 시스템 (100) 내에 저장된 데이터 위치에 관한 정보를 보유한다.
저장 장치 제어기 (110)은 관리기 (112) 및 (114)의 동작을 지시하고 또한, 데이터를 테입 드라이브 (126)으로 이동하거나 또는 테입 드라이브 (126)으로부터 데이터를 이동한다. 저장 장치 제어기 (110)은 호스트 (102)로부터 커맨드 및 데이터를 수신하고, 호스트의 커맨드를 수행하기 위해 필요한 동작을 취하기 위해 관리기 (112) 및 (114)를 지시하는 적당한 커맨드를 발행한다. 저장 장치 제어기 (110)은 마이크로 프로세서, 개인용 컴퓨터 또는 더 진보된 처리 기계와 같은 디지털 처리 장치를 포함할 수 있다.
동작
상기에서 기술된 다양한 하드웨어 실시예에 추가하여, 본 발명의 또 다른 특징은 자동화된 데이터 저장 장치 라이브러리를 사용하여 데이터를 이동하는 방법에 관한 것이다. 이러한 방법은 예를 들어 이하에서 기술되는 기계 판독 가능한 명령어들의 시퀀스를 수행하는 데이터 저장 서브 시스템 (100)을 동작시킴으로써 구현될 수 있다.
데이터 저장 장치
이러한 기계 판독 가능한 명령어들은 다양한 형태의 데이터 저장 매체 내에 존재할 수 있다. 이러한 점에서, 본 발명의 하나의 특징은 본 발명에 따라 데이터를 이동시키기 위한 방법을 수행하기 위한 디지털 데이터 처리기에 의해 수행 가능한 기계 판독 가능한 명령어들로 구성된 프로그램을 유형적으로 구현하는 데이터 저장 매체를 포함하는 제품과 관련되어 있다.
이러한 데이터 저장 매체는, 예를 들어 저장 장치 인터페이스 (104) 내에 포함된 RAM과 같은 메모리(도시되지 않음)를 포함할 수 있다. 다른 방법으로, 명령어들은 휴대용 자기 데이터 저장 디스켓 (200) (도 2)과 같은 또 다른 데이터 저장 매체 내에 포함될 수 있다. 명령어들은 저장 장치 인터페이스 (104), 디스켓 (200) 또는 다른 어느 곳에 포함되어 있을지라도, DASD 저장 장치(예를 들어, 통상적인 "하드 드라이브" 또는 RAID(redundant array inexpensive disk) 어레이), 자기 테입, 전자적인 판독 전용 메모리(electronic read-only memory)(예를 들어, ROM), 광 저장 장치(optical storage device)(예를 들어, write-once, read-many: WORM), 종이 천공 카드 또는 기타 다른 데이터 저장 매체와 같은 또 다른 형태의 데이터 저장 매체 상에 대신 저장될 수 있다. 본 발명의 예시적인 실시예에서, 기계 판독 가능한 명령어들은 컴파일된 "C" 언어 코드 라인들을 포함할 수 있다.
동작 순서
상기에서 논의된 바와 같이, 본 발명의 방법은 데이터를 타겟 테입 카트리지로 이동하는 것과 관련되어 있는데, 여기서 데이터 블록들과 관련된 식별자(identifier)는 소스 매체로부터 획득되고, 데이터 블록들 및 그들과 관련된 식별자들을 거의 연속적인 형태로 타겟 테입 매체 내에 저장함으로써 이들 데이터 블록들 및 관련된 식별자들이 통합된다. 이하에서 기술되는 하나의 실시예에서는, 입력 데이터가 소스 테입 카트리지로부터 수신되고, 캐쉬 (106) 상에 "버츄얼" 테입 카트리지 형태로 저장되어 어떤 미리 정해진 계획에 따라 테입 라이브러리 내의 타겟 테입 카트리지로 이동된다.
예시된 실시예에서는, 각각의 소스 테입 카트리지는 하나의 데이터 블록 및, 그 데이터 블록과 관련된 볼륨 일련 번호와 같은 정보를 포함하는 기계 판독 가능한 해당되는 식별자를 포함한다. 예를 들어, 각각의 식별자는 테입 카트리지의 하우징 상에 외부적으로 프린트될 수 있거나 또는 카트리지의 테입 매체 상에 저장된 코드에 의해 제공될 수 있다. IBM 또는 ISO/ANSI 형태의 데이터 라벨에 의해 제공되는 형태의 정보와 같은 기타 다른 정보도 또한 포함될 수 있다. 예시된 예에서는 도시되지 않았지만, 각각의 소스 테입 카트리지는 기계 판독 가능한 해당되는 수의 식별자를 가진 다수의 데이터 블록을 포함할 수 있다.
테입 에뮬레이션(tape emulation)
바람직한 실시예에서, 저장 장치 인터페이스 (104)는 캐쉬 (106)에게 호스트 (102)로부터 새롭게 수신된 데이터를 저장하도록 지시하고, 또한 호스트 요구에 응답하여 저장된 데이터를 판독하도록 지시한다. 예시된 실시예에서는, 캐쉬 (106)이 테입 저장 시스템을 에뮬레이트(emulate)하지만, 고속 저장, 데이터 첨부 가능성 등과 같은 테입에서는 이용할 수 없는 많은 장점들을 제공한다. 대다수가 당업계에서 공지된 테입 에뮬레이션 시스템에 관한 추가적인 정보는 아래의 참조 자료: (1) "Virtual Storage System & Methods"라는 명칭으로 1984년 8월 21일 허여된 미국 특허 제 4,467,421 및 (2) "Virtual Integrated Cartridge Loader for Virtual Tape Storage System"라는 명칭으로 Carlson 등에 의해 1996년 9월 10일 출원된 미국 특허 출원 제 08/707,891호에서 찾아볼 수 있다. 상기 참조 자료들의 내용은 본 발명의 일부를 이룬다.
테입 저장 서브 시스템을 에뮬레이팅하면, 캐쉬 관리기 (112)가 캐쉬 (106) 내에 포함된 버츄얼 테입 카트리지 상에 데이터를 저장하는데 필요한 다른 정보 및 디렉토리를 보유한다. 각각의 버츄얼 카트리지는 데이터의 볼륨에 해당하는데, 이러한 데이터 볼륨은 본 실시예에서는 하나의 테입 카트리지 상에 이전에 포함된 데이터 블록을 포함한다. 각각의 버츄얼 카트리지는 관련된 식별자를 가진다. 각각의 카트리지 매체가 하나의 볼륨을 나타내는 본 발명의 예에서, 각각의 식별자는 볼륨 일련 번호를 포함할 수 있다. 데이터가 캐쉬 (106)으로부터 라이브러리 (108)로 이동될 때, 캐쉬 관리기 (112)는 각각의 버츄얼 카트리지 식별자와 함께 이동되어야 하는 버츄얼 카트리지를 라이브러리 (108)에 제공한다. 캐쉬 관리기 (112)는 또한 자동화된 테입 라이브러리 내의 이동된 데이터의 위치에 관한 정보를 카탈로그 (128)에 제공한다.
당업자라면 호스트와 통신하는데 있어서 테입 저장 장치를 에뮬레이트하기 위한 캐쉬 (106)의 구조, 동작 및 사용에 관한 상세한 설명이 상기에서 인용된 것과 같은 공지의 버츄얼 라이브러리 및 본 발명의 개시 내용의 잇점을 갖는다는 것을 명백히 이해할 것이다.
테입으로부터 캐쉬로의 데이터 이동
본 발명의 하나의 실시예에 따르면, 동작 순서 (300)(도 3)에 따라서 데이터가 서브 시스템 (100)으로 전달된다. 개략적으로, 순서 (300)은 소스 테입의 수신, 테입의 내용 판독, 및 테입의 내용을 캐쉬 (106) 상에 통합하는 역할을 한다. 본 발명에 따르면, 데이터는 (1) 예시된 바와 같이 작동자에 의해 라이브러리에 제공되는 기존의 테입 카트리지(도시되지 않음)로부터 이동되고/되거나 (2)라이브러리에 이미 포함된 테입 카트리지(도시되지 않음)로부터 이동된다. 중요한 것은, 본 발명에 따른 데이터 이동은 다수의 버츄얼 카트리지와 그들의 데이터를 캐쉬 (106) 상에 통합하여, 캐쉬 (106) 내에 있는 데이터의 고속 저장 및 검색을 용이하게 하고, 캐쉬 (106) 내에 데이터를 첨부하며, 테입 시스템에서는 이용할 수 없는 기타 다른 잇점을 갖는다는 점이다. 이러한 절차는, 예를 들어 구형 모델(older model)로 된 테입 라이브러리 또는 테입 드라이브에서 이전에 개시된(previously initiated) 테입 카트리지 상에 원래 저장된 데이터를 통합하는데 특히 유용하다.
이러한 처리의 예를 보여주기 위하여, 도 3은 데이터가 소스 테입 카트리지로부터 캐쉬 (106)으로 이동되는 것을 보여주는 방법의 순서 (300)을 도시하고 있다. 설명의 편의를 위하여(그러나 그것에 의해 의도된 어떠한 한정도 없이), 도 3의 예는 상기에서 기술된 데이터 저장 서브 시스템 (100) (도 1)과 관련하여 기술된다. 타스크(task) (302)에서 순서 (300)이 시작된 후, 이동할 소스 테입 카트리지를 선택하기 위해 타스크 (304)가 수행된다. 작동자가 이미 존재하는(올드("old")) 테입 카트리지를 통합하기를 원하는 예시된 실시예에서는, 이동되어야 하는 올드 카트리지를 식별하는 작동자에 의해 타스크 (304)가 수행된다. 올드 테입 카트리지는 IBM CST, IBM ECCST, 및 IBM HPCT 등과 같은 다수의 다른 포맷을 사용할 수 있다.
다음으로, 타스크 (306)에서는 올드 카트리지가 자동화된 테입 라이브러리 (108) 내로 로드된다. 즉, 작동자는 카트리지를 취합하여 그들을 테입 라이브러리 입력 설비 (116) 내로 로드한다. 소스 카트리지의 수는 라이브러리의 입력 설비 (116)의 용량에 의해서만 제한을 받는다. 상기에서 언급되었듯이, 입력 설비 (116)은 이러한 목적을 위해 피커 (122)를 사용하여 하나 이상의 테입 드라이브 (126)에 액세스 가능한 입력 랙(input rack)과 같은 일괄 로딩 설비(batch loading facility)를 포함할 수 있다. 바람직하게는, 소스 카트리지가 다중 볼륨 데이터 그룹의 일부분이면 그룹 내의 모든 카트리지들이 입력 설비 (116) 내로 함께 로드된다.
다음으로, 소스 테입 카트리지 중에서 첫 번째 카트리지를 초기에 선택하여 타스크 (308)이 데이터셋을 올드 카트리지로부터 캐쉬 (106)으로 이동시키는 동작을 시작한다. 예를 들어, 타스크 (308)은 작동자에 의해 발행되는 커맨드에 응답하여 개시될 수 있다. 타스크 (310)에서는, 라이브러리 (108)이 선택된 카트리지를 테입 드라이브 (126)들 중의 하나로 로드한다. 데이터셋의 이동이 본 발명의 예에서는 하나씩(one-by-one) 수행되는 것으로 예시되어 있지만, 만약 라이브러리 (108)이 다수의 테입 드라이브 (126)을 포함하고 있다면 다수의 데이터셋이 동시적으로 이동될 수도 있다.
타스크 (310)에서 선택된 카트리지가 로딩이 완료된 후, 테입 드라이브 (126)은 자신의 기록/판독 헤드를 테입의 시작 부분에 위치시키고 타스크 (312)에서 카트리지의 식별자를 판독한다. 상기에서 언급한 바와 같이, 각각의 식별자는 적어도 관련된 물리적인 카트리지의 볼륨 일련 번호를 포함한다. 다음으로, 질의(query) (314)가 볼륨 일련 번호의 유효성 및 식별자 내의 기타 다른 적용 가능한 정보를 확인한다. 타스크 (314)의 확인이 실패("아니오"라는 결정)한 경우, 타스크 (316)이 현재 로드된 카트리지의 이동을 취소하고, 이하에서 논의될 질의(query) (320)으로 진행한다. 타스크 (316)은 또한 후속 작동자를 표시하기 위해 카트리지의 "실패(failed)" 상태를 기록할 수 있다.
질의 (314)의 확인이 성공하면("예"라는 결정), 타스크 (318)은 현재 로드된 소스 카트리지의 데이터를 소스 카트리지의 식별자와 동일한 식별자로 캐쉬 (106) 내의 버츄얼 카트리지 상에 복사한다. 타스크 (318)은 또한 데이터 및 데이터에 관련된 버츄얼 카트리지의 캐쉬 (106) 내에서의 위치를 리스트(list)하는 캐쉬 관리기 (112) 내의 디렉토리를 갱신한다. 디렉토리가 존재하지 않으면, 타스크 (318)이 디렉토리를 생성한다. 선택 사양(option)으로서, 타스크 (318)은 또한 복제된 데이터의 식별자를 인벤토리(inventory) 내에 입력할 수 있다. 타스크 (318)에서 소스 카트리지의 데이터가 캐쉬 (106)에 복사된 후, 카트리지는 테입 드라이브 (126)에 의해 언로드(unload)되고, 카트리지는 출력 설비 (118) 내에 위치할 수도 있다. 이러한 카트리지들은 타스크 (324)에서 보여지는 바와 같이 라이브러리 (108)로부터 제거될 수 있거나, 또는 빈 카트리지(empty cartridge)로서 나중에 사용하기 위하여 라이브러리 (108)에 의해 재활용(recycle)될 수 있다.
타스크 (318) 후에, 질의 (320)이 타스크 (306)에서 로드된 각각의 소스 카트리지가 캐쉬 (106)에 복사(또는, 복사 시도)되었는지의 여부를 질의한다. 질의가 없는 경우, 타스크 (322)에서 다음 카트리지가 로드되고, 타스크 (310) 내지 (320)이 반복된다. 질의 (320)이 모든 소스 카트리지가 처리되었다고 결정하면, 타스크 (326)에서 루틴 (300)이 끝난다.
캐쉬로부터 라이브러리로 데이터 이동
본 발명 방법 상의 또 다른 특징은 데이터가 캐쉬 (106)으로부터 라이브러리(108) 내의 타겟 테입 카트리지로 이동하는 것을 포함한다. 이러한 처리의 예를 제공하기 위하여, 도 4는 데이터가 캐쉬 (106)으로부터 라이브러리 (108)로 이동하는 것을 보여주는 방법의 순서 (400)을 도시하고 있다. 설명의 편의를 위하여(그러나 그것에 의해 의도된 어떠한 한정도 없이), 도 4의 예는 상기에서 기술된 데이터 저장 서브 시스템 (100) (도 1)과 관련하여 기술된다.
타스크 (402)에서 순서 (400)이 시작된 후, 타스크 (404)는 캐쉬 (106)의 내용을 분석하여, 테입 라이브러리 (108)로 이동하기에 적합한 버츄얼 카트리지 및 그들과 관련된 데이터를 식별한다. 하나의 실시예에서는, 캐쉬 (106)에서 제공되는 모든 데이터들은 라이브러리 (108)로 이동하기 위하여 표시될 수 있다. 다른 방법으로, 각각의 버츄얼 카트리지는 캐쉬 (106) 내의 버츄얼 카트리지가 도달하는 즉시 타겟 카트리지로 이동될 수 있다. 또 다른 방법으로는, 호스트 (102)에 의해 사용되는 활성화된 데이터는 비활성화된 데이터가 소스 카트리지로부터 캐쉬 (106)을 통하여 직접 라이브러리 (108) 내의 타겟 카트리지로 이동되는 동안 캐쉬 (106) 내에 보유될 수 있다. 또 다른 방법으로는, 타스크 (404)의 분석이, 예를 들어 최근 최소 사용(least-recently-used: LRU) 데이터셋, 최소 사용 빈도수(least-frequently-used: LFU) 데이터셋, 또는 기타 다른 적당한 종류의 데이타셋을 식별하는 것을 포함할 수 있다. 이것은 캐쉬 (106)에서 무효 데이터(stale data)를 제거하여 액세스가 될 가능성이 큰 데이터를 위해 캐쉬 저장 공간을 비우도록(free)한다. 타스크 (404)는 주기적인 방법(periodic base)과 같이 미리 정해진 계획에 따라 수행될 수도 있다.
타스크 (406)에서는, 라이브러리 (108)이 타겟 테입 카트리지를 테입 드라이브(도시되지 않음)에 로드한다. 타겟 테입 카트리지는 캐쉬 (106)으로부터 제공되는 버츄얼 카트리지 및 그들과 관련된 데이터셋을 수신하여 통합하는 역할을 한다. 궁극적으로, 타겟 테입 카트리지는 다수의 상이한 소스 테입 카트리지 상에 이전에 개별적으로 저장된 다수의 데이터 블록을 포함한다. 타겟 테입 카트리지는 다수의 상이한 포맷을 사용할 수 있지만, 상기에서 언급한 IBM HPCT와 같은 고용량의 최신 포맷을 사용하는 것이 바람직하다. 타겟 카트리지의 외부 표면은 해당되는 버츄얼 카트리지의 식별자와 같은 카트리지의 데이터 내용에 관한 볼륨에 특정한 어떠한 정보(volume-specific information)를 가질 필요가 없다는 점이 장점이다. 본 명세서에서 설명되었듯이, 각각의 소스 카트리지의 식별자는 캐쉬 (106)로 이동 및 그 후의 라이브러리 (108)로 이동하는 전과정에 걸쳐서 매체 자체 상에 저장된 식별자를 수반한다. 타스크 (406)의 이후에, 타스크 (408)이 라이브러리 (108)로 이동하기 위하여 타스크 (404)에서 식별된 버츄얼 카트리지 중 첫 번째 버츄얼 카트리지 및 그것과 관련된 데이터를 초기에 선택한다.
그 후, 질의(query) (416)은 타겟 카트리지가 현재 데이터셋을 수신할 수 있는지의 여부를 결정한다. 바람직하게는, 각각의 타겟 카트리지가 카트리지의 데이터 용량이 허용하는 양만큼의 데이터로 채워진다. 질의 (416)이 타겟 카트리지가 현재 데이터셋을 저장할 만한 공간을 가지고 있지 않음을 발견하면, 타스크 (418)에서 테입 드라이브가 빈 타겟 카트리지를 로드한다. 타스크 (418) 후에(또는 타겟 카트리지가 풀(full)이 아닌 경우), 타스크 (420)은 현재 로드된 소스 카트리지의 데이터를 타겟 카트리지로 전달한다. 데이터와 함께, 데이터 식별자는 또한 타겟 카트리지에 기록된다. 바람직하게는, 각각의 데이터 블록 및 해당되는 식별자가 서로에 대하여 미리 정해진 상대적인 상호 관계로 타겟 카트리지에 기록된다. 예를 들어, 식별자는 자신의 해당 데이터 블록에 거의 바로 앞에 올 수 있다. 데이터 식별자 조합( combination)은 단일 트랙, 다중 단일 방향 트랙, 양 방향으로 구부러진 패턴, 또는 타겟 카트리지의 저장 표면을 추적하는 또 다른 미리 정해진 패스(path)와 같은 타겟 카트리지에 의해 정의된 데이터 패스를 따라서 기록된다.
바람직하게는, 데이터 및 그 식별자는 타겟 카트리지의 데이터 패스를 따라서 가장 최근에 기록된 데이터 식별자가 있는 경우에는 그 식별자에 실질적으로 인접한 타겟 카트리지에 기록된다. 즉, 타스크 (420)은 각각의 연속적인 데이터 블록 및 관련된 식별자들이 타겟 카트리지 데이터 패스를 따라서 거의 연속적인 형태로 이전의 데이터 블록 및 식별자에 연결되는 것을 보장한다. 따라서, 각각의 식별자가 자신과 관련된 각 데이터 블록 앞에 있게되면, 타겟 카트리지 상의 데이터 블록들은 모두 사이에 끼게되는 식별자에 의해 분리된다. 캐쉬 (106)으로부터 제공되는 데이터를 연결함으로써, 타겟 카트리지의 저장 공간이 효율적으로 유지된다.
타스크 (420) 후에, 타스크 (422)는 카탈로그 (128)을 갱신하여 최근에 기록된 데이터 블록을 라이브러리 (108) 내의 위치와 연관시킨다. 타스크 (422) 후에, 타스크 (424)는 타스크 (404)에서 식별된 모든 데이터가 처리되었는지의 여부를 결정한다. 모든 데이터가 처리되지 않은 경우, 다음번 식별된 데이터 블록이 타스크 (426)에서 선택되고, 타스크 (416) 내지 (424)에서 그 데이터에 대한 처리가 계속된다. 타스크 (424)가 처리할 데이터셋을 더 이상 발견하지 못하면, 타스크 (428)에서 루틴 (400)이 끝난다.
소스 테입으로부터 라이브러리로의 데이터 이동
도 3 내지 4에 대한 또 다른 방법으로, 데이터는 캐쉬 (106) 내의 모든 중간 저장을 생략한 채 소스 카트리지로부터 타겟 카트리지로 직접 이동될 수 있다. 이것은 도 3 및 도 4의 단계 (300) 및 (400)을 몇가지 수정하여 수행시킴으로써 이루어진다. 일반적으로, 단계 (300) 및 (400)은 동시에 수행될 수 있는데, 순서 (300)은 이동을 위한 소스 카트리지를 준비하고 순서 (400)은 이동을 위한 타겟 카트리지를 준비한다. 그러나, 타스크 (318)에서는, 데이터가 소스 카트리지로부터 캐쉬 (106)으로 복사되는 것이 아니라, 그 대신 타스크 (420)에 도시된 바와 같이 타겟 카트리지로 복사된다. 따라서, 이 실시예에서는, 타스크 (318) 및 (420)이 동일하다. 또 다른 상이점은 타스크 (404)가 순서 (300)에 의해 이동을 위하여 준비된 소스 데이터를 식별하는 것을 포함한다는 점이다.
또 다른 방법으로는, 작동자가 카트리지를 "활성(active)" 또는 "비활성(inactive)"으로 선택적으로 지정하는 것이 가능한데, 여기서 비활성 카트리지는 바로 위에서 기술한 바와 같이 타겟 테입으로 직접 이동될 수 있고, 활성 카트리지는 도 3에 도시된 바와 같이 캐쉬 (106)에 저장된다.
다른 실시예
본 발명은 바람직한 실시예를 참조하여 특별히 도시되고 기술되었지만, 본 발명의 정신, 범위, 및 개시 내용을 이탈함이 없이 당업자는 본 발명으로부터 다양한 변경을 가할 수 있다는 것을 이해할 수 있을 것이다.
소스 매체로부터 타겟 매체로의 데이터 이동에 관한 본 발명의 방법에서는, 데이터와 관련된 식별자(identifier)가 소스 테입 매체로부터 획득되고, 데이터 및 관련된 식별자를 거의 연속적인 형태로 타겟 매체 상에 저장함으로써 데이터 및 관련된 식별자가 통합된다.

Claims (40)

  1. 데이터 이동 방법(data migration method)에 있어서,
    a) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블 록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    b) 각 테입 카트리지로부터 그 테입 카트리지의 데이터 블록과 관련된 식별자를 판독하는 단계;
    c) 데이터 블록들 및 그들과 관련된 식별자들을 입력 테입 카트리지로부터 단일 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스(data storage path)를 정의하고, 각 데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되고, 데이터 블록 및 식별자는 데이터 저장 패스를 따라서 실질적으로 연속적인 형태로 기록됨―; 및
    d) 복사된 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 카트리지에 대한 복사된 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 방법.
  2. 제 1항에 있어서, 상기 복사하는 단계가
    데이터 블록들의 일부 및 그들과 관련된 식별자들을 입력 테입 카트리지로부터 제 1 출력 테입 카트리지로 복사하는 제 1 단계; 및
    다른 나머지 데이터 블록들 및 그들과 관련된 식별자들을 입력 테입 카트리지로부터 제 2 출력 테입 카트리지로 복사하는 제 2 단계
    를 포함하는 방법.
  3. 제 1항에 있어서, 상기 고유한 식별자가 볼륨 일련 번호(volume serial numbers)인 방법.
  4. 제 1항에 있어서, 각 테입 카트리지가 테입 매체 및 매체 하우징(media housing)을 포함하고, 상기 판독 단계가 매체 하우징에 의해 제공된 기계 판독 가능한 코드(machine-readable code)를 판독하는 단계를 포함하는 방법.
  5. 제 1항에 있어서, 각 테입 카트리지가 테입 매체 및 매체 하우징(media housing)을 포함하고, 상기 판독 단계가 테입 매체로부터 기계 판독 가능한 코드(machine-readable code)를 판독하는 방법.
  6. 제 1항에 있어서, 데이터 저장 패스(data storage path)가 구부러진(serpentine) 데이터 저장 패스를 포함하는 방법.
  7. 제 1항에 있어서, 상기 수령 단계는 작동자(作動者: human operator)가 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리의 테입 로더(tape loader) 내로 위치시키는 단계를 포함하는 방법.
  8. 제 1항에 있어서, 상기 테입 카트리지가 자기 테입 저장 장치 유닛(magnetic tape storage units)을 포함하는 방법.
  9. 데이터 이동 방법(data migration method)에 있어서,
    a) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    b) 각 테입 카트리지로부터 그 테입 카트리지의 데이터 블록과 관련된 식별자를 판독하는 단계;
    c) 데이터 블록들 및 식별자들을 입력 테입 카트리지로부터 캐쉬 저장 장치로 복사하는 단계;
    d) 선택된 데이터 블록들 및 그들과 관련된 식별자들을 캐쉬 저장 장치로부터 자동화된 테입 카트리지 라이브러리 내에 보유된 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스(data storage path)를 정의하고, 각 데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되고, 데이터 블록 및 식별자는 데이터 저장 패스를 따라서 거의 연속적인 형태로 기록됨―; 및
    e) 출력 테입 카트리지에 복사된 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 저장 장치 사이트에 대한 상기 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 방법.
  10. 데이터 이동 방법에 있어서,
    a) 각 입력 테입 매체 유닛이 그 내부에 데이터 블록을 저장하고 있으며, 또한 그 내부에 저장된 데이터 블록과 관련된 기계 판독 가능한 식별자를 포함하는 복수개의 입력 테입 매체 유닛을 테입 라이브러리의 로딩 메카니즘(loading mechanism)에 로딩하는 단계;
    b) 데이터 블록과 관련된 식별자를 결정하기 위하여 입력 테입 매체 유닛을 사용하는 단계;
    c) 데이터 블록들 및 그 식별자들을 다수의 출력 테입 매체 유닛으로 통합하는 단계―여기서 각 데이터 블록 및 관련된 식별자는 하나의 동일한 출력 테입 매체 유닛에 함께 저장되고, 각 출력 테입 매체 유닛 상의 데이터 블록들 및 관련된 식별자들은 미리 정해진 서로 상대적인 관계로 위치되며, 각 출력 테입 매체 유닛 상의 데이터 블록들 및 식별자들은 출력 테입 매체 유닛 상에 거의 연속적인 형태로 기록됨―; 및
    d) 통합된 각 데이터 블록을 그 통합된 데이터 블록을 포함하고 있는 출력 테입 매체 유닛과 상호 관련시키는 현재 카탈로그를 생성하는 단계
    를 포함하는 방법.
  11. 제 10항에 있어서, 현재 카탈로그를 생성하는 단계가 현재 카탈로그를 새로이 형성하는 단계들을 포함하는 방법.
  12. 제 10항에 있어서, 현재 카탈로그를 생성하는 단계가 기존의 카탈로그를 갱신하는 단계들을 포함하는 방법.
  13. 데이터 통합 방법(method of consolidating data)에 있어서,
    a) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    b) 각 소스 테입 카트리지로부터 그 소스 테입 카트리지 상에 저장된 데이터 블록과 관련된 식별자를 판독하는 단계;
    c) 각 데이터 블록 및 그것과 관련된 식별자를 단일 타겟 테입 카트리지―여기서 타겟 테입 카트리지는 데이터 패스를 정의하고, 각 후속(subsequent) 데이터 블록 및 관련된 식별자는 데이터 패스를 따라서 실질적으로 연속적인 형태로 이전의 데이터 블록들 및 식별자들에 연결됨― 로 연속적으로 복사하는 단계; 및
    d) 복사된 각 식별자를 타겟 테입 카트리지와 링크시키고, 다른 카트리지에 대한 복사된 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 방법.
  14. 데이터 이동 방법(data migration method)에 있어서,
    a) 각 테입 카트리리가 그 입력 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 수령하는 단계;
    b) 각 입력 테입 카트리지로부터 그 입력 테입 카트리지 상에 포함된 데이터 블록과 관련된 식별자를 판독하는 단계;
    c) 데이터 블록들을 입력 테입 카트리지로부터 캐쉬 내에 미리 규정된 위치로 복사하고, 또한 식별자를 캐쉬에 기록하는 단계;
    d) 각 식별자를 캐쉬 내의 해당되는 미리 규정된 위치와 링크시키고, 다른 저장 위치에 대한 식별자의 이전의 모든 링크를 삭제하기 위해 카달로그를 갱신하는 단계;
    e) 데이터 블록 및 식별자를 캐쉬로부터 단일 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스(data storage path)를 정의하고, 각 데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되며, 데이터 블록 및 식별자는 데이터 저장 패스를 따라서 거의 연속적인 형태로 기록됨―; 및
    f) 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 저장 위치에 대한 상기 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 방법.
  15. 제 14항에 있어서, 상기 캐쉬가 자기 데이터 저장 디스크 드라이브(magnetic data storage disk drive)를 포함하는 방법.
  16. 제 14항에 있어서, 상기 캐쉬가 RAM(random access memory)을 포함하는 방법.
  17. 데이터 이동 방법의 단계들을 수행하기 위한, 디지탈 처리 장치에 의해 수행 가능한, 기계 판독 가능 명령어들로 구성된 프로그램을 유형적으로 구현하는 데이터저장 매체를 포함하는 제품에 있어서, 상기 데이터 이동 방법이
    a) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블 록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    b) 각 테입 카트리지로부터 그 테입 카트리지의 데이터 블록과 관련된 식별자를 판독하는 단계;
    c) 데이터 블록들 및 그들과 관련된 식별자들을 입력 테입 카트리지로부터 단일 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스(data storage path)를 정의하고, 각 데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되고, 데이터 블록 및 식별자는 데이터 저장 패스를 따라서 실질적으로 연속적인 형태로 기록됨―; 및
    d) 복사된 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 카트리지에 대한 복사된 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 제품.
  18. 데이터 이동 방법의 단계들을 수행하기 위한, 디지탈 처리 장치에 의해 수행 가능한, 기계 판독 가능 명령어들로 구성된 프로그램을 유형적으로 구현하는 데이터저장 매체를 포함하는 제품에 있어서, 상기 데이터 이동 방법이
    a) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    b) 각 테입 카트리지로부터 그 테입 카트리지의 데이터 블록과 관련된 식별자를 판독하는 단계;
    c) 데이터 블록들 및 식별자들을 입력 테입 카트리지로부터 캐쉬 저장 장치로 복사하는 단계;
    d) 선택된 데이터 블록들 및 그들과 관련된 식별자들을 캐쉬 저장 장치로부터 자동화된 테입 카트리지 라이브러리 내에 보유된 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스(data storage path)를 정의하고, 각 데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되고, 데이터 블록 및 식별자는 데이터 저장 패스를 따라서 실질적으로 연속적인 형태로 기록됨―; 및
    e) 출력 테입 카트리지에 복사된 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 저장 장치 사이트에 대한 상기 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 제품.
  19. 자동화된 테입 라이브러리를 사용하여 데이터 이동 방법의 단계들을 수행하기 위한, 디지탈 처리 장치에 의해 수행 가능한, 기계 판독 가능 명령어들로 구성된 프로그램을 유형적으로 구현하는 데이터 저장 매체를 포함하는 제품에 있어서, 상기 데이터 이동 방법이
    a) 각 입력 테입 매체 유닛이 그 내부에 데이터 블록을 저장하고 있으며, 또한 그 내부에 저장된 데이터 블록과 관련된 기계 판독 가능한 식별자를 포함하는 복수개의 입력 테입 매체 유닛을 테입 라이브러리의 로딩 메카니즘(loading mechanism)에 로딩하는 단계;
    b) 데이터 블록과 관련된 식별자를 결정하기 위하여 입력 테입 매체 유닛을 사용하는 단계;
    c) 데이터 블록들 및 그 식별자들을 다수의 출력 테입 매체 유닛 상으로 통합하는 단계―여기서 각 데이터 블록 및 관련된 식별자는 하나의 동일한 출력 테입 매체 유닛 상에 함께 저장되고, 각 출력 테입 매체 유닛 상의 데이터 블록들 및 관련된 식별자들은 미리 정해진 서로 상대적인 관계로 위치되며, 각 출력 테입 매체 유닛 상의 데이터 블록들 및 식별자들은 출력 테입 매체 유닛 상에 거의 연속적인 형태로 기록됨―; 및
    d) 통합된 각 데이터 블록을 그 통합된 데이터 블록을 포함하고 있는 출력테입 매체 유닛과 상호 관련시키는 현재 카탈로그를 생성하는 단계
    를 포함하는 제품.
  20. 데이터 통합 방법의 단계들을 수행하기 위한, 디지탈 처리 장치에 의해 수행 가능한, 기계 판독 가능 명령어들로 구성된 프로그램을 유형적으로 구현하는 데이터 저장 매체를 포함하는 제품에 있어서, 상기 데이터 이동 방법이
    a) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    b) 각 소스 테입 카트리지로부터 그 소스 테입 카트리지 상에 저장된 데이터 블록과 관련된 식별자를 판독하는 단계;
    c) 각 데이터 블록 및 그것과 관련된 식별자를 단일 타겟 테입 카트리지로 연속적으로 복사하는 단계―여기서 타겟 단일 테입 카트리지는 데이터 패스를 정의하고, 각 후속(subsequent) 데이터 블록 및 관련된 식별자는 데이터 패스를 따라서 실질적으로 연속적인 형태로 이전의 데이터 블록들 및 식별자들에 연결됨―; 및
    d) 복사된 각 식별자를 타겟 테입 카트리지와 링크시키고, 다른 카트리지에 대한 복사된 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 제품.
  21. 데이터 이동 방법의 단계들을 수행하기 위한, 디지탈 처리 장치에 의해 수행 가능한, 기계 판독 가능 명령어들로 구성된 프로그램을 유형적으로 구현하는 데이터 저장 매체를 포함하는 제품에 있어서, 상기 데이터 이동 방법이
    a) 각 테입 카트리리가 그 입력 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 수령하는 단계;
    b) 각 입력 테입 카트리지로부터 그 입력 테입 카트리지 상에 포함된 데이터 블록과 관련된 식별자를 판독하는 단계;
    c) 데이터 블록들을 입력 테입 카트리지로부터 캐쉬 내에 미리 규정된 위치로 복사하고, 또한 식별자를 캐쉬에 기록하는 단계;
    d) 각 식별자를 캐쉬 내의 해당되는 미리 규정된 위치와 링크시키고, 다른 저장 위치에 대한 식별자의 이전의 모든 링크를 삭제하기 위해 카달로그를 갱신하는 단계;
    e) 데이터 블록 및 식별자를 캐쉬로부터 단일 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스(data storage path)를 정의하고, 각 데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되며, 데이터 블록 및 식별자는 데이터 저장 패스를 따라서 거의 연속적인 형태로 기록됨―; 및
    f) 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 저장 위치에 대한 상기 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는단계
    를 포함하는 제품.
  22. 데이터 이동 장치에 있어서, 상기 장치는
    a) 적어도 하나의 테입 드라이브를 갖는 테입 카트리지 라이브러리; 및
    b) 라이브러리에 결합된 라이브러리 관리기
    를 포함하고,
    라이브러리 관리기는
    ⅰ) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    ⅱ) 각 테입 카트리지로부터 그 테입 카트리지의 데이터 블록과 관련된 식별자를 판독하는 단계;
    ⅲ) 데이터 블록들 및 그들과 관련된 식별자들을 입력 테입 카트리지로부터 단일 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스(data storage path)를 정의하고, 각 데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되고, 데이터 블록 및 식별자는 데이터저장 패스를 따라서 실질적으로 연속적인 형태로 기록됨―; 및
    ⅳ) 복사된 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 카트리지에 대한 복사된 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 방법을 수행하도록 프로그램되는
    데이터 이동 장치.
  23. 제 22항에 있어서, 상기 테입 카트리지 라이브러리가 적어도 하나의 소스 테입 드라이브 및 적어도 하나의 타겟 테입 드라이브를 포함하는 데이터 이동 장치.
  24. 제 22항에 있어서, 상기 방법이
    데이터 블록들의 일부 및 그들과 관련된 식별자들을 입력 테입 카트리지로부터 제 1 출력 테입 카트리지로 복사하는 제 1 단계; 및
    다른 나머지 데이터 블록들 및 그들과 관련된 식별자들을 입력 테입 카트리지로부터 제 2 출력 테입 카트리지로 복사하는 제 2 단계
    를 포함하는 데이터 이동 장치.
  25. 제 22항에 있어서, 상기 고유한 식별자가 볼륨 일련 번호(volume serial numbers)인 데이터 이동 장치.
  26. 제 22항에 있어서, 각 테입 카트리지가 테입 매체 및 매체 하우징(media housing)을 포함하고, 상기 판독 단계가 매체 하우징에 의해 제공된 기계 판독 가능한 코드(machine-readable code)를 판독하는 단계를 포함하는 데이터 이동 장치.
  27. 제 22항에 있어서, 각 테입 카트리지가 테입 매체 및 매체 하우징(media housing)을 포함하고, 상기 판독 단계가 테입 매체로부터 기계 판독 가능한 코드(machine-readable code)를 판독하는 데이터 이동 장치.
  28. 제 22항에 있어서, 데이터 저장 패스(data storage path)가 구부러진(serpentine) 데이터 저장 패스를 포함하는 데이터 이동 장치.
  29. 제 22항에 있어서, 상기 수령 단계는 작동자(作動者: human operator)가 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리의 테입 로더 내로 위치시키는 단계를 포함하는 데이터 이동 장치.
  30. 제 22항에 있어서, 상기 테입 카트리지가 자기 테입 저장 장치 유닛(magnetic tape storage units)을 포함하는 데이터 이동 장치.
  31. 데이터 이동 장치에 있어서, 상기 장치는
    a) 적어도 하나의 테입 드라이브를 갖는 테입 카트리지 라이브러리; 및
    b) 라이브러리에 결합된 라이브러리 관리기
    를 포함하고,
    라이브러리 관리기는
    ⅰ) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    ⅱ) 각 테입 카트리지로부터 그 테입 카트리지의 데이터 블록과 관련된 식별자를 판독하는 단계;
    ⅲ) 데이터 블록들 및 식별자들을 입력 테입 카트리지로부터 캐쉬 저장 장치로 복사하는 단계;
    ⅳ) 선택된 데이터 블록들 및 그들과 관련된 식별자들을 캐쉬 저장 장치로부터 자동화된 테입 카트리지 라이브러리 내에 보유된 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스(data storage path)를 정의하고, 각데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되고, 데이터 블록 및 식별자는 데이터 저장 패스를 따라서 실질적으로 연속적인 형태로 기록됨―; 및
    ⅴ) 출력 테입 카트리지에 복사된 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 저장 장치 사이트에 대한 상기 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 방법을 수행하도록 프로그램되는
    데이터 이동 장치.
  32. 데이터 이동 장치에 있어서, 상기 장치는
    a) 적어도 하나의 테입 드라이브를 갖는 테입 카트리지 라이브러리; 및
    b) 라이브러리에 결합된 라이브러리 관리기
    를 포함하고,
    라이브러리 관리기는
    ⅰ) 각 입력 테입 매체 유닛이 그 내부에 데이터 블록을 저장하고 있으며, 또한 그 내부에 저장된 데이터 블록과 관련된 기계 판독 가능한 식별자를 포함하는, 복수개의 입력 테입 매체 유닛을 테입 라이브러리의 로딩 메카니즘(loading mechanism)에 로딩하는 단계;
    ⅱ) 데이터 블록과 관련된 식별자를 결정하기 위하여 입력 테입 매 체 유닛을 사용하는 단계;
    ⅲ) 데이터 블록들 및 그 식별자들을 다수의 출력 테입 매체 유닛 상으로 통합하는 단계―여기서 각 데이터 블록 및 관련된 식별자는 동일한 출력 테입 매체 유닛 상에 함께 저장되고, 각 출력 테입 매체 유닛 상의 데이터 블록들 및 관련된 식별자들은 미리 정해진 서로 상대적인 관계로 위치되며, 각 출력 테입 매체 유닛 상의 데이터 블록들 및 식별자들은 출력 테입 매체 유닛상에 실질적으로 연속적인 형태로 기록됨―; 및
    ⅳ) 통합된 각 데이터 블록을 그 통합된 데이터 블록을 포함하고 있는 출력 테입 매체 유닛과 상호 관련시키는 현재 카탈로그를 생성하는 단계
    를 포함하는 방법을 수행하도록 프로그램되는
    데이터 이동 장치.
  33. 제 32항에 있어서, 상기 테입 카트리지 라이브러리가 적어도 하나의 소스 테입 드라이브 및 적어도 하나의 타겟 테입 드라이브를 포함하는 데이터 이동 장치.
  34. 제 32항에 있어서, 현재 카탈로그를 생성하는 단계가 현재 카탈로그를 새로이 형성하는 단계들을 포함하는 데이터 이동 장치.
  35. 제 32항에 있어서, 현재 카탈로그를 생성하는 단계가 기존의 카탈로그를 갱신하는 단계들을 포함하는 데이터 이동 장치.
  36. 데이터 이동 장치에 있어서, 상기 장치는
    a) 적어도 하나의 테입 드라이브를 갖는 테입 카트리지 라이브러리; 및
    b) 라이브러리에 결합된 라이브러리 관리기
    를 포함하고,
    라이브러리 관리기는
    ⅰ) 각 테입 카트리리가 그 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 테입 카트리지 라이브러리(tape cartridge library)로 수령하는 단계;
    ⅱ) 각 소스 테입 카트리지로부터 그 소스 테입 카트리지 상에 저장된 데이터 블록과 관련된 식별자를 판독하는 단계;
    ⅲ) 각 데이터 블록 및 그것과 관련된 식별자를 단일 타겟 테입 카트리지―여기서 단일 타겟 테입 카트리지는 데이터 패스를 정의하고, 각 후속(subsequent) 데이터 블록 및 관련된 식별자는 데이터 패스를 따라서 실질적으로 연속적인 형태로 이전의 데이터 블록들 및 식별자들에 연결됨―로 연속적으로 복사하는 단계; 및
    ⅳ) 복사된 각 식별자를 타겟 테입 카트리지와 링크시키고, 다른 카트리지에 대한 복사된 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계
    를 포함하는 방법을 수행하도록 프로그램되는
    데이터 이동 장치.
  37. 제 36항에 있어서, 상기 테입 카트리지 라이브러리가 적어도 하나의 소스 테입 드라이브 및 적어도 하나의 타겟 테입 드라이브를 포함하는 데이터 이동 장치.
  38. 데이터 이동 장치에 있어서,
    a) 적어도 하나의 테입 드라이브를 갖는 테입 카트리지 라이브러리;
    b) 캐쉬; 및
    c) 라이브러리 및 캐쉬에 결합된 라이브러리 관리기
    를 포함하고,
    라이브러리 관리기는
    ⅰ) 각 테입 카트리리가 그 입력 테입 카트리지로부터 판독될 수 있는 데이터 블록 및 관련된 고유한 식별자를 포함하는 복수개의 입력 테입 카트리지를 수령하는 단계;
    ⅱ) 각 입력 테입 카트리지로부터 그 입력 테입 카트리지 상에 포함된 데이터 블록과 관련된 식별자를 판독하는 단계;
    ⅲ) 데이터 블록들을 입력 테입 카트리지로부터 캐쉬 내에 미리 규정된 위치로 복사하고, 또한 식별자를 캐쉬에 기록하는 단계;
    ⅳ) 각 식별자를 캐쉬 내의 해당되는 미리 규정된 위치와 링크 시키고, 다른 저장 위치에 대한 식별자의 이전의 모든 링크를 삭제하기 위해 카탈로그를 갱신하는 단계;
    ⅴ) 데이터 블록 및 식별자를 캐쉬로부터 단일 출력 테입 카트리지로 복사하는 단계―여기서 출력 테입 카트리지는 데이터 저장 패스 (data storage path)를 정의하고, 각 데이터 블록은 자신과 관련된 식별자에 인접한 출력 테입 카트리지에 기록되며,데이터 블록 및 식별자는 데이터 저장 패스를 따라서 실질적으로 연속적인 형태로 기록됨―; 및
    ⅵ) 각 식별자를 출력 테입 카트리지와 링크시키고, 다른 저장 위치에 대한 상기 식별자의 이전의 모든 링크를 삭제하기 위해 카달로그를 갱신하는 단계
    를 포함하는 방법을 수행하도록 프로그램되는
    데이터 이동 장치.
  39. 제 38항에 있어서, 상기 캐쉬가 자기 데이터 저장 디스크 드라이브(magnetic data storage disk drive)를 포함하는 데이터 이동 장치.
  40. 제 38항에 있어서, 상기 캐쉬가 RAM(random access memory)을 포함하는 데이터 이동 장치.
KR1019970045142A 1997-01-02 1997-08-30 볼륨 스태킹 라이브러리에서의 아웃 보드 데이터 이동 KR100259432B1 (ko)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/778,118 US5809511A (en) 1997-01-02 1997-01-02 Outboard data migration in a volume stacking library
US8/778,118 1997-01-02

Publications (2)

Publication Number Publication Date
KR19980069918A KR19980069918A (ko) 1998-10-26
KR100259432B1 true KR100259432B1 (ko) 2000-06-15

Family

ID=25112356

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019970045142A KR100259432B1 (ko) 1997-01-02 1997-08-30 볼륨 스태킹 라이브러리에서의 아웃 보드 데이터 이동

Country Status (2)

Country Link
US (1) US5809511A (ko)
KR (1) KR100259432B1 (ko)

Families Citing this family (84)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH10224665A (ja) * 1997-02-04 1998-08-21 Sony Corp 送出システム
JP3734334B2 (ja) * 1997-05-07 2006-01-11 富士通株式会社 データ移行システム、データ移行用プログラムを格納したコンピュータ読み取り可能な記録媒体、及びデータ移行方法
US5911148A (en) * 1997-05-29 1999-06-08 International Business Machines Corporation Automated message processing system configured for automated tape device management
US5999982A (en) * 1997-05-29 1999-12-07 International Business Machines Corporation Automated message processing system having a plurality of expert local facilities responsive to messages routed thereto to perform predetermined actions
US6098148A (en) * 1997-05-29 2000-08-01 International Business Machines Corporation Storage and access of data using volume trailer
US6496791B1 (en) * 1997-07-09 2002-12-17 Neville Yates Interfaces for an open systems server providing tape drive emulation
US6067481A (en) * 1997-11-12 2000-05-23 Quantum Corporation Virtual magnetic tape drive library system
US6044442A (en) * 1997-11-21 2000-03-28 International Business Machines Corporation External partitioning of an automated data storage library into multiple virtual libraries for access by a plurality of hosts
US6105037A (en) 1997-12-12 2000-08-15 International Business Machines Corporation Apparatus for performing automated reconcile control in a virtual tape system
US6304880B1 (en) * 1997-12-12 2001-10-16 International Business Machines Corporation Automated reclamation scheduling override in a virtual tape server
US6014675A (en) * 1997-12-18 2000-01-11 International Business Machines Corporation Method and apparatus for facilitating progressive increase in allowable mount/demounts during inventory updates
DE19811034A1 (de) * 1998-03-13 1999-09-16 Grau Software Gmbh Datenspeichereinrichtung
US6269423B1 (en) * 1998-05-13 2001-07-31 International Business Machines Corporation Method and apparatus for providing improved caching for a virtual tape server
US6324497B1 (en) 1998-07-15 2001-11-27 Sutmyn Storage Corporation Tape drive emulation system including tape library interface
US6260006B1 (en) 1998-12-22 2001-07-10 Storage Technology Corporation System and method for multi-volume tape library
US6760708B1 (en) 1999-08-19 2004-07-06 Dell Products L.P. Method and system for migrating stored data to a build-to-order computing system
US6560726B1 (en) 1999-08-19 2003-05-06 Dell Usa, L.P. Method and system for automated technical support for computers
US6606716B1 (en) 1999-10-06 2003-08-12 Dell Usa, L.P. Method and system for automated technical support for computers
US6564220B1 (en) 1999-10-06 2003-05-13 Dell Usa, L.P. System and method for monitoring support activity
US6539499B1 (en) 1999-10-06 2003-03-25 Dell Usa, L.P. Graphical interface, method, and system for the provision of diagnostic and support services in a computer system
US6598223B1 (en) 1999-10-06 2003-07-22 Dell Usa, L.P. Method and system for installing and testing build-to-order components in a defined configuration computer system
US6574615B1 (en) 1999-10-06 2003-06-03 Dell Usa, L.P. System and method for monitoring support activity
US6556431B1 (en) 1999-10-06 2003-04-29 Dell Usa, L.P. System and method for converting alternating current into direct current
US6317316B1 (en) 1999-10-06 2001-11-13 Dell Usa, L.P. Method and system for integrated personal computer components
US6563698B1 (en) 1999-10-06 2003-05-13 Dell Usa, L.P. System and method for providing a computer system with a detachable component
AU2001229332A1 (en) 2000-01-10 2001-07-24 Connected Corporation Administration of a differential backup system in a client-server environment
FR2812100B1 (fr) * 2000-07-20 2003-01-17 Near Technologies Procede de sauvegarde de donnees informatiques
FR2812736B1 (fr) * 2000-08-04 2003-12-19 Near Technologies Systeme de stockage virtuel
WO2002029511A2 (en) * 2000-10-05 2002-04-11 Wintegra Ltd. Method system and apparatus for multiprocessing
US6625703B2 (en) * 2000-11-02 2003-09-23 International Business Machines Corporation Verifying primary and backup copies of vital information for a processing system employing a pseudo-fixed reference identifier
JP2002157092A (ja) * 2000-11-17 2002-05-31 Hitachi Ltd 記憶システムおよび記憶システム間のデータ転送方法
US6557089B1 (en) 2000-11-28 2003-04-29 International Business Machines Corporation Backup by ID-suppressed instant virtual copy then physical backup copy with ID reintroduced
US6804078B2 (en) 2001-07-19 2004-10-12 International Business Machines Corporation Apparatus and method to expedite data access from a portable data storage cartridge
JP3749243B2 (ja) * 2001-09-03 2006-02-22 松下電器産業株式会社 半導体発光デバイス,発光装置及び半導体発光デバイスの製造方法
US6868478B2 (en) * 2002-06-20 2005-03-15 International Business Machines Corporation Method, system, and article of manufacture for optimizing storage utilization
US7454529B2 (en) 2002-08-02 2008-11-18 Netapp, Inc. Protectable data storage system and a method of protecting and/or managing a data storage system
US7069466B2 (en) * 2002-08-14 2006-06-27 Alacritus, Inc. Method and system for copying backup data
KR100532842B1 (ko) * 2002-08-17 2005-12-05 삼성전자주식회사 하드디스크 드라이브의 공간낭비를 줄일 수 있는 영상기록/재생장치
US7222140B2 (en) * 2002-08-28 2007-05-22 International Business Machines Corporation Method for improving the recovery time from a lost database in a VTS automation system
US7197518B2 (en) * 2002-08-29 2007-03-27 International Business Machines Corporation Method and apparatus for recovery of the association of construct definitions with logical volumes in a virtual tape server
US7418562B2 (en) * 2002-08-29 2008-08-26 International Business Machines Corporation Apparatus and method to assign one or more storage construct names to a logical volume
US7882081B2 (en) 2002-08-30 2011-02-01 Netapp, Inc. Optimized disk repository for the storage and retrieval of mostly sequential data
US7437387B2 (en) 2002-08-30 2008-10-14 Netapp, Inc. Method and system for providing a file system overlay
US6851031B2 (en) * 2002-08-30 2005-02-01 Alacritus, Inc. Method of importing data from a physical data storage device into a virtual tape library
US6862656B2 (en) * 2002-08-30 2005-03-01 Alacritus, Inc. System and method for exporting a virtual tape
US7080223B2 (en) * 2002-10-15 2006-07-18 International Business Machines Corporation Apparatus and method to manage and copy computer files
US8024172B2 (en) 2002-12-09 2011-09-20 Netapp, Inc. Method and system for emulating tape libraries
US7567993B2 (en) 2002-12-09 2009-07-28 Netapp, Inc. Method and system for creating and using removable disk based copies of backup data
US7080203B2 (en) * 2003-01-21 2006-07-18 International Business Machines Corporation Serial EEPROM for volume identification and drive specific information storage in a hard disk drive library
US6973369B2 (en) * 2003-03-12 2005-12-06 Alacritus, Inc. System and method for virtual vaulting
US7146474B2 (en) * 2003-03-12 2006-12-05 International Business Machines Corporation System, method and computer program product to automatically select target volumes for a fast copy to optimize performance and availability
US7437492B2 (en) 2003-05-14 2008-10-14 Netapp, Inc Method and system for data compression and compression estimation in a virtual tape library environment
US7269701B2 (en) * 2003-10-10 2007-09-11 International Business Machines Corporation Self-configuration of source-to-target mapping
US7325159B2 (en) * 2004-02-04 2008-01-29 Network Appliance, Inc. Method and system for data recovery in a continuous data protection system
US7490103B2 (en) * 2004-02-04 2009-02-10 Netapp, Inc. Method and system for backing up data
US7559088B2 (en) 2004-02-04 2009-07-07 Netapp, Inc. Method and apparatus for deleting data upon expiration
US7783606B2 (en) 2004-02-04 2010-08-24 Netapp, Inc. Method and system for remote data recovery
US7904679B2 (en) 2004-02-04 2011-03-08 Netapp, Inc. Method and apparatus for managing backup data
US7720817B2 (en) 2004-02-04 2010-05-18 Netapp, Inc. Method and system for browsing objects on a protected volume in a continuous data protection system
US7426617B2 (en) * 2004-02-04 2008-09-16 Network Appliance, Inc. Method and system for synchronizing volumes in a continuous data protection system
US7406488B2 (en) * 2004-02-04 2008-07-29 Netapp Method and system for maintaining data in a continuous data protection system
US7315965B2 (en) 2004-02-04 2008-01-01 Network Appliance, Inc. Method and system for storing data using a continuous data protection system
US8028135B1 (en) 2004-09-01 2011-09-27 Netapp, Inc. Method and apparatus for maintaining compliant storage
US20060080500A1 (en) * 2004-10-07 2006-04-13 Unisys Corporation Method and system for managing data transfer between different types of tape media
US20060101084A1 (en) * 2004-10-25 2006-05-11 International Business Machines Corporation Policy based data migration in a hierarchical data storage system
US7581118B2 (en) 2004-12-14 2009-08-25 Netapp, Inc. Disk sanitization using encryption
US7774610B2 (en) 2004-12-14 2010-08-10 Netapp, Inc. Method and apparatus for verifiably migrating WORM data
US7558839B1 (en) 2004-12-14 2009-07-07 Netapp, Inc. Read-after-write verification for improved write-once-read-many data storage
US7526620B1 (en) 2004-12-14 2009-04-28 Netapp, Inc. Disk sanitization in an active file system
US7401198B2 (en) 2005-10-06 2008-07-15 Netapp Maximizing storage system throughput by measuring system performance metrics
US7386667B2 (en) * 2005-11-09 2008-06-10 International Business Machines Corporation Storing information regarding operation of an automated data storage library to memory and to a reserved cartridge
US7752401B2 (en) 2006-01-25 2010-07-06 Netapp, Inc. Method and apparatus to automatically commit files to WORM status
US7650533B1 (en) 2006-04-20 2010-01-19 Netapp, Inc. Method and system for performing a restoration in a continuous data protection system
US20080061979A1 (en) * 2006-09-13 2008-03-13 Hause Curtis B Traceable RFID enable data storage device
US20080065676A1 (en) * 2006-09-13 2008-03-13 Hause Curtis B System and method for tracing data storage devices
US20080122623A1 (en) * 2006-09-13 2008-05-29 Hause Curtis B System and method for tracing data storage devices
JP2008077519A (ja) * 2006-09-22 2008-04-03 Fujitsu Ltd 仮想テープ装置、仮想テープ装置のデータ管理方法、仮想テープ装置のデータ管理プログラム
US20080198022A1 (en) * 2007-02-21 2008-08-21 Imation Corp. Inkjet printable RFID label and method of printing an inkjet printable RFID label
US7953433B2 (en) 2007-04-24 2011-05-31 Imation Corp. Data storage device and data storage device tracing system
US8016194B2 (en) 2008-03-06 2011-09-13 Imation Corp. Mobile data storage device reader having both radiofrequency and barcode scanners
US7864478B2 (en) * 2008-08-22 2011-01-04 International Business Machines Corporation Verification of a tape data storage cartridge
JP5878360B2 (ja) * 2011-12-19 2016-03-08 インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation データのメデイア移行時における改ざんを検出する方法、及び記憶装
US9250823B1 (en) * 2014-05-20 2016-02-02 Emc Corporation Online replacement of physical storage in a virtual storage system
US11074005B1 (en) 2020-01-03 2021-07-27 International Business Machines Corporation Coordinated storage media verification

Family Cites Families (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4467421A (en) * 1979-10-18 1984-08-21 Storage Technology Corporation Virtual storage system and method
US4638424A (en) * 1984-01-12 1987-01-20 International Business Machines Corporation Managing data storage devices connected to a digital computer
US4928245A (en) * 1987-01-27 1990-05-22 Storage Technology Corporation Automated cartridge system
US4932826A (en) * 1987-01-27 1990-06-12 Storage Technology Corporation Automated cartridge system
US4945429A (en) * 1988-01-27 1990-07-31 Storage Technology Corporation Data security arrangement for an automated magnetic tape cartridge library system
US5455926A (en) * 1988-04-05 1995-10-03 Data/Ware Development, Inc. Virtual addressing of optical storage media as magnetic tape equivalents
US4876662A (en) * 1988-05-02 1989-10-24 International Business Machines Corporation Optimizing volume mounts in a multidrive environment
US5394539A (en) * 1991-09-04 1995-02-28 International Business Machines Corporation Method and apparatus for rapid data copying using reassigned backing pages
US5432656A (en) * 1992-05-01 1995-07-11 Fujitsu Limited Library apparatus having recording medium entry and ejection units
US5403639A (en) * 1992-09-02 1995-04-04 Storage Technology Corporation File server having snapshot application data groups
JPH07191899A (ja) * 1993-12-27 1995-07-28 Hitachi Ltd ファイル転送方法、データアクセス方法およびデータ書き込み方法
US5642501A (en) * 1994-07-26 1997-06-24 Novell, Inc. Computer method and apparatus for asynchronous ordered operations
US5613154A (en) * 1994-12-20 1997-03-18 International Business Machines Corporation System and method for management of transient data storage mediums in an automated data storage library
US5715464A (en) * 1995-06-07 1998-02-03 International Business Machines Corporation Computer system having suspend once resume many sessions

Also Published As

Publication number Publication date
US5809511A (en) 1998-09-15
KR19980069918A (ko) 1998-10-26

Similar Documents

Publication Publication Date Title
KR100259432B1 (ko) 볼륨 스태킹 라이브러리에서의 아웃 보드 데이터 이동
US5029125A (en) Method of reading and writing files on nonerasable storage media
US5475834A (en) Integration of migration level two and backup tape processing using multiple inventory entries
US6336163B1 (en) Method and article of manufacture for inserting volumes for import into a virtual tape server
US5870732A (en) Inventory method for logical volumes in an automated storage library
US6031798A (en) Library control of media capacity scaling and library component attributes
US6360232B1 (en) Disaster recovery method for a removable media library
US6269431B1 (en) Virtual storage and block level direct access of secondary storage for recovery of backup data
US5805864A (en) Virtual integrated cartridge loader for virtual tape storage system
US6557073B1 (en) Storage apparatus having a virtual storage area
US5546557A (en) System for storing and managing plural logical volumes in each of several physical volumes including automatically creating logical volumes in peripheral data storage subsystem
US6366987B1 (en) Computer data storage physical backup and logical restore
US6226712B1 (en) Storage and access to scratch mounts in VTS system
US6353878B1 (en) Remote control of backup media in a secondary storage subsystem through access to a primary storage subsystem
US5963971A (en) Method and apparatus for handling audit requests of logical volumes in a virtual media server
US7334083B2 (en) Library system, virtual library apparatus, cache restoring method, and computer readable recording medium recorded thereon a cache restoring program
US20060101084A1 (en) Policy based data migration in a hierarchical data storage system
US6691137B1 (en) Cache management system utilizing cascading tokens
US6691136B2 (en) Fast data retrieval based upon contiguous consolidation of records according to frequency of access
US5388260A (en) Transparent library management
US6321239B1 (en) Efficient volume copy using pre-configuration of log structured target storage
US7664910B2 (en) Data management method and apparatus, hierarchical storage apparatus and computer-readable storage medium
JPH056889B2 (ko)
JPS60147855A (ja) 記憶管理装置
JPH0589583A (ja) ボリユームからオブジエクトを削除する方法及び階層記憶システム

Legal Events

Date Code Title Description
A201 Request for examination
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20070302

Year of fee payment: 8

LAPS Lapse due to unpaid annual fee