KR101405729B1 - 동적 저장장치 계층화 방법 및 시스템 - Google Patents

동적 저장장치 계층화 방법 및 시스템 Download PDF

Info

Publication number
KR101405729B1
KR101405729B1 KR1020117011778A KR20117011778A KR101405729B1 KR 101405729 B1 KR101405729 B1 KR 101405729B1 KR 1020117011778 A KR1020117011778 A KR 1020117011778A KR 20117011778 A KR20117011778 A KR 20117011778A KR 101405729 B1 KR101405729 B1 KR 101405729B1
Authority
KR
South Korea
Prior art keywords
virtual volume
storage
storage pool
storage device
pool
Prior art date
Application number
KR1020117011778A
Other languages
English (en)
Other versions
KR20110117057A (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 KR20110117057A publication Critical patent/KR20110117057A/ko
Application granted granted Critical
Publication of KR101405729B1 publication Critical patent/KR101405729B1/ko

Links

Images

Classifications

    • 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/0662Virtualisation aspects
    • G06F3/0665Virtualisation aspects at area level, e.g. provisioning of virtual or logical volumes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • 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/061Improving I/O performance
    • 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/0638Organizing or formatting or addressing of data
    • G06F3/064Management of blocks
    • 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/0689Disk arrays, e.g. RAID, JBOD

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Stored Programmes (AREA)

Abstract

본 명세서는 저장장치 핫 스팟(storage hot-spot)을 포함하는 가상 볼륨의 시점(point-in-time) 복사본을 생성하고, 저장장치 핫 스팟을 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하며 상기 제 2 저장장치 풀 내에 상기 가상 볼륨 세그먼트를 배치하기 위해서 상기 가상 볼륨의 논리 블록 어드레스 매핑을 재구성하는 것을 포함하는 동적 저장장치 계층화를 위한 시스템 및 방법을 개시한다.

Description

동적 저장장치 계층화 방법 및 시스템{METHOD AND SYSTEM FOR DYNAMIC STORAGE TIERING USING ALLOCATE-ON-WRITE SNAPSHOTS}
동적 저장장치 계층화(Dynamic Storage Tiering: DST)는 저장 장치들을 그들의 성능 특성을 기반으로 계층으로 그룹화하고 그들의 특정 능력을 활용하기 위해서 그 장치들에 데이터를 동적으로 재배치하는 개념이다. DST 시스템은 데이터가 온라인 상에서 접근가능하도록 유지된 상태에서 이러한 재배치를 수행하는 것이 바람직하다.
성능 관리를 위해서, 높은 활동 또는 부하 수준을 가진 데이터는 고성능 저장 계층에 재배치될 수 있다. 한편, 고성능 저장 계층의 용량을 증가시키기 위해서 낮은 활동 수준을 가진 데이터는 저성능 저장 계층에 재배치될 수 있다.
본 명세서는 동적 저장장치 계층화를 위한 시스템 및 방법을 개시한다.
동적 저장장치 계층화를 위한 방법은 저장장치 핫 스팟을 포함하는 가상 볼륨의 시점 복사본을 생성하는 단계; 상기 저장장치 핫 스팟을 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 단계; 및 상기 제 2 저장장치 풀 내부에 가상 볼륨 세그먼트 복사본을 배열하기 위해 상기 가상 볼륨의 논리적 블록 어드레스 매핑을 재구성하는 단계를 포함할 수 있다.
동적 저장장치 계층화를 위한 시스템은 저장장치 핫 스팟을 포함하는 가상 볼륨의 시점 복사본을 생성하는 수단; 상기 저장장치 핫 스팟을 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 수단; 및 상기 제 2 저장장치 풀 내부에 가상 볼륨 세그먼트 복사본을 배열하기 위해 상기 가상 볼륨의 논리적 블록 어드레스 매핑을 재구성하는 수단을 포함할 수 있다.
본 명세서의 많은 이점은 첨부된 도면을 참조함으로써 당업자들에 의해 충분히 이해될 수 있다.
도 1은 데이터 저장 시스템을 도시한다.
도 2는 데이터 저장 시스템을 도시한다.
도 3은 데이터 저장 시스템을 도시한다.
도 4는 데이터 저장 시스템을 도시한다.
도 5는 동적 저장장치 계층화와 관련된 동작 흐름을 도시한다.
도 6은 동적 저장장치 계층화와 관련된 동작 흐름을 도시한다.
도 7은 동적 저장장치 계층화와 관련된 동작 흐름을 도시한다.
도 8은 동적 저장장치 계층화와 관련된 동작 흐름을 도시한다.
도 9는 동적 저장장치 계층화와 관련된 동작 흐름을 도시한다.
이하의 구체적인 설명에 있어서, 본 명세서의 일부를 형성하는 첨부된 도면에 대해 참조부호가 부여된다. 도면에 있어서, 문맥이 다르게 기술되지 않는 한, 유사한 참조 부호는 통상적으로 유사한 구성 요소를 나타낸다. 상세한 설명, 도면 및 청구항에 기재된 예시적인 실시예는 한정하고자 하는 것은 아니다. 여기에 제시된 주제의 사상 또는 범위에서 벗어나지 않고 다른 실시예들이 사용될 수 있으며 다른 변경이 가해질 수 있다.
도 1을 참조하면, 호스트(101) 컴퓨팅 장치, 복수 배열 독립 디스크(Redundant Array of Independent Disks: RAID) 제어기(102) 및 RAID(103)를 포함하는 대용량 저장 시스템(100)이 예시적으로 도시된다. RAID 제어기(102)는 RAID 제어기(102)가 RAID(103) 상에 구성된 다양한 논리적 볼륨에 접근하는 호스트(101)의 독출/기입 요청을 처리할 수 있도록 하는 볼륨 관리 회로/소프트웨어를 포함할 수 있다. RAID(103)는 n 개의 드라이브를 갖는 드라이브 그룹을 포함할 수 있다.
도 1을 참조하면, 하나 이상의 물리적 드라이브(예를 들어, 드라이브0 내지 드라이브 n)는 하나 이상의 가상 드라이브(예를 들어, RAID(103)의 가상 드라이브(104A) 내지 가상 드라이브(104C))로 논리적으로 구획될 수 있다. 하나 이상의 가상 드라이브의 일부는 저장장치 풀(storage pool)(예를 들어, 저장장치 풀(105A), 저장장치 풀(105B) 등)로 더 구획될 수 있다. 저장장치 풀은 유사한 성능 특성을 가진 하나 이상의 물리적 드라이브들(또는 하나 이상의 물리적 드라이브의 하나 이상의 논리적 부분들)로 정의될 수 있다. 예를 들어, 저장장치 풀(105A)(즉, 드라이브 0)은 고성능 고체 상태 드라이브(Solid State Drives: SSDs)를 포함할 수 있는 반면 저장장치 풀(105B)(즉, 드라이브 1 및 드라이브 2)은 직렬 ATA (Serial Advanced Technology Attachment: SATA) 하드 디스크 드라이브(HDD)와 같은 저성능 장치들을 포함할 수 있다. 고성능 저장장치 풀과 저성능 저장장치 풀을 구별할 수 있는 요소들은 단위 시간 당 처리된 입/출력(I/O) 동작의 개수, 단위 시간 당 독출 또는 기입된 바이트 수 및/또는 입/출력 요청에 대한 평균 응답 시간을 포함할 수 있다.
전체 시스템 성능을 향상시키기 위해서, 높은 활동 수준을 가진 데이터(예를 들어, 많은 입/출력 요청이 그 데이터에 발송되는 경우)를 고성능 저장장치 풀에 할당하는 반면 낮은 활동 수준을 가진 데이터를 저성능 저장장치 풀에 할당하는 것이 바람직할 수 있다. 효율적인 DST 해법을 얻기 위해서 저장장치 풀들 간에 이동하는 데이터 블록의 크기는 완전한 SCSI 논리적 유닛(LU)보다 더 작을 수 있다.
주어진 LU에 대해서, 높은 활동 수준을 가진 데이터는 LU 내의 논리적 블록 어드레스(LBA) 범위로 식별될 수 있다. LU의 나머지 부분에 비해 중요한 활동 부하를 갖는 그러한 LBA 범위는 핫 스팟(hot-spot)으로 지칭될 수 있다. LU는 하나 이상의 핫 스팟을 포함할 수 있다.
현재 핫 스팟이 존재하는 저장장치 풀은 근원지 저장장치 풀로 지칭될 수 있다. 핫 스팟이 이동될 수 있는 저장장치 풀은 목적지 저장장치 풀로 지칭될 수 있다. 핫 스팟은 빈번하게 접근되고 고성능 저장장치 풀로 이동될 수 있는 데이터를 나타낼 수 있다는 것에 주의해야 한다. 한편, 드물게 접근되고, 핫 스팟 이동에 대해서 여기에서 설명되는 바와 같은 동일한 시스템 및 방법을 활용하는 저성능 저장장치 풀로 이동될 수 있는 데이터는 콜드 스팟(cold spot)으로 지칭될 수 있다.
핫 스팟은 호스트(101)로부터 수신되는 I/O 요청에 대한 어드레스 위치를 감시함으로써 RAID 제어기(102)에 의해 식별될 수 있다. I/O 요청 임계값을 초과하는 경우(예를 들어, 특정된 요청 속도, 요청의 개수 등을 초과하는 경우), 주어진 저장장치 풀 내에 존재하는 LBA들의 특정 세그먼트에 대해서, 그 LBA들은 핫 스팟으로 지정될 수 있으며 이는 상호적인 성능 특성을 갖는 저장장치 풀에 재할당된다.
도 2를 참조하면, 가상 볼륨(106)은 하나 이상의 저장장치 풀의 용량에 근거하여 공급될 수 있다. 예를 들어, 저장장치 풀(105B)은 하나 이상의 가상 드라이브들(예를 들어, 물리적 드라이브 0에 할당된 가상 드라이브(104A) 일부의 가상 드라이브 LBA 세그먼트(107A); 물리적 드라이브 1에 할당된 가상 드라이브(104B) 일부의 가상 드라이브 LBA 세그먼트(107B); 물리적 드라이브 2에 할당된 가상 드라이브(104C) 일부의 가상 드라이브 LBA 세그먼트(107C); 등)로부터의 LBA들을 포함할 수 있다.
도 3 및 4를 참조하면, 하나의 가상 볼륨은 하나 이상의 가상 드라이브들(예를 들어, 가상 드라이브 세그먼트들) 내에 있는 하나 이상의 LBA 범위들에 매핑될 수 있다. 가상 볼륨이 하나 이상의 저장장치 풀로부터 공급되면, 가상 볼륨 LBA 범위를 가상 드라이브 LBA 범위에 각각 매핑하기 위해서 가상 볼륨 세그먼트가 생성될 수 있다. 예를 들어, 가상 볼륨 LBA 세그먼트(108A)는 가상 드라이브(104A)의 LBA들 0 내지 m에 매핑되는 LBA들 0 내지 m을 포함할 수 있다. 가상 볼륨 LBA 세그먼트(108B)는 가상 드라이브(104B)의 LBA들 0 내지 j에 매핑되는 LBA들 m+1 내지 n을 포함할 수 있다. 가상 볼륨 LBA 세그먼트(108C)는 가상 드라이브(104C)의 LBA들 0 내지 k에 매핑되는 LBA들 n+1 내지 p를 포함할 수 있다.
대용량 저장 시스템(100)은 스냅샷(snapshot) 기능을 더 구현할 수 있다. 스냅샷 기능은 가상 볼륨(예를 들어, 가상 볼륨(106A))의 하나 이상 시점(point- in-Time: PiT) 복사본의 생성 및 저장을 고려한다. 시점(PiT)이 가상 볼륨에 대해서 생성되면, 가상 볼륨의 내용은 동결될 수 있고, PiT 임시 가상 볼륨(PTVV)이 생성될 수 있으며 이는 PiT가 점유된 후에 가상 볼륨에 대해 일어나는 모든 변경을 기록한다. 결과적으로, 가상 볼륨의 원본 내용은 PiT가 생성될 때 보존된다. 그러한 스냅샵 메커니즘은 기입시 할당(allocate-on-write) 또는 기입 시 재전달(redirect-on-write) (통칭하여 "기입 시 할당") 스냅샷으로 지칭될 수 있다. 또한, 이후의 PiT들은 현재의 PTVV가 동결되고 새로운 PTVV가 생성되는 주어진 PTVV에 대해서 생성될 수 있다.
도 5 내지 9는 동적 저장장치 계층화와 관련된 대표적 동작을 나타내는 동작 흐름을 도시한다. 도 5 내지 9에서, 논의 및 설명은 도 1 내지 4에서 전술한 예 및/또는 다른 예와 상황에 대해서 제공될 수 있다. 그러나, 상기 동작 흐름은 많은 다른 환경과 상황에서 및/또는 도 1 내지 4의 변형된 형태로 실행될 수 있다는 것이 이해되어야 한다. 부가적으로, 다양한 동작 흐름이 예시된 순서(들)로 제시되지만, 다양한 동작이 예시된 순서가 아닌 다른 순서로 수행되거나 또는 동시에 수행될 수 있다는 것이 이해되어야 한다.
도 5를 참조하면, 저장장치 핫 스팟을 포함하는 가상 볼륨의 시점 복사본을 생성하는 것을 예시하는 동작 흐름이 도시된다. 원본 가상 볼륨(예를 들면, 가상 볼륨(106A))의 내용을 동결시킬 수 있고 제 1 PTVV (예를 들면, PTVV1)가 생성될 수 있는 제 1 PiT(예를 들면, PiT1)가 일어날 수 있다. PTVV가 생성된 후, 호스트(예를 들면, 호스트(101))로부터 가상 볼륨으로의 기입 동작들은 PTVV로 전달될 수 있다. 호스트로부터 가상 볼륨으로의 독출 동작들은 PiT 이후 변형되지 않은 데이터에 대해서는 원본 가상 볼륨으로, 또한 PiT 이후에 변형된 데이터에 대해서는 PTVV로 전달될 것이다. 가장 최근의 PiT는 모든 현재의 기입 동작들이 그 PTVV로 전달되기 때문에, "활성" PiT로 부를 수 있다.
이후에, PTVV1의 내용을 동결시킬 수 있고 제 2 PTVV(예를 들면, PTVV2)가 생성될 수 있는 제 2 PiT(예를 들면, PiT2)가 일어날 수 있다. PTVV가 생성된 후, 호스트로부터 가상 볼륨으로의 기입 동작들은 활성 PTVV(예를 들면, PTVV2)로 전달될 수 있다. 호스트로부터 가상 볼륨으로의 독출 동작들은 제 1 PiT(예를 들면, PiT1) 이후 변형되지 않는 데이터에 대해서는 원본 가상 볼륨으로, 제 1 PiT 이후 제 2 PiT(예를 들면, PiT2) 이전에 변형되는 데이터에 대해서는 제 1 PTVV(예를 들면, PTVV1)으로, 또한 제 2 PiT 이후에 변형되는 데이터에 대해서는 활성 PTVV(예를 들면, PTVV2)로 전달될 것이다.
PiT(예를 들면, PiT1)의 삭제 시에, 원본 가상 볼륨(예를 들면, 가상 볼륨(106))은 PiT가 존재하는 동안 기입 요청에 의해 발송된 원본 볼륨의 일부의 내용이 PTVV와 일치되게 갱신되도록 재구성될 수 있다. 예를 들어, PiT가 존재하는 동안 기입 요청에 의해 발송된 가상 볼륨(106)의 LBA들이 가상 볼륨(106)의 LBA들로 복사될 수 있다.
도 6을 참조하면, 핫 스팟을 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 것을 예시하는 동작 흐름이 도시된다. 예를 들면, (저장장치 풀(105B)에 위치하는 가상 드라이브(104B)의 일부와 현재 연관된) 가상 드라이브 LBA 세그먼트(107B)는 저장장치 풀(105A)로 복사될 수 있다. 핫 스팟을 포함하는 가상 볼륨 세그먼트의 복사는, 복사 동작 중에 가상 볼륨 세그먼트 내에 있는 데이터의 변형이 PiT 까지 유지된다는 것을 보장하기 위해서 연관된 가상 볼륨에 대한 PiT가 생성된 후에 일어날 수 있다.
도 7을 참조하면, 제 2 저장장치 풀 내의 가상 볼륨 세그먼트 복사본을 참조하기 위해 가상 볼륨의 논리적 블록 어드레스 매핑을 재구성하는 것을 예시하는 동작 흐름이 도시된다.
도 8을 참조하면, 제 2 저장장치 풀에 있는 가상 볼륨 세그먼트 복사본을 제 2 메모리 위치의 데이터로 갱신하는 것을 예시하는 동작 흐름이 도시된다. 도 5를 참조하여 전술한 바와 같이, 가상 볼륨(예를 들면, 가상 볼륨(106))은 가상 볼륨의 내용이 PiT와 연관된 PTVV와 일치하도록 PiT의 삭제 시에 자동으로 갱신될 수 있다. 예를 들어, 고성능 저장장치 풀(예를 들어, 저장장치 풀(105A)의 가상 드라이브(104D))로 이동된 가상 볼륨(106)의 세그먼트는 이전에 생성된 PTVV1과 일치하도록 갱신될 수 있다. PTVV1의 LBA들에 있는 데이터는 가상 드라이브(104D) 상의 가상 드라이브 LBA 세그먼트(107D)로 복사될 수 있으므로, PTVV1와 연관된 PiT를 삭제하게 된다.
도 9를 참조하면, 핫 스팟을 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀의 가상 볼륨으로부터 할당 해제(de-allocating)하는 것을 예시하는 동작 흐름이 도시된다. 예를 들어, 저장장치 풀(105A)에 가상 드라이브 LBA 세그먼트(107B)를 복사할 때, 저장장치 풀(105B)의 가상 드라이브 LBA 세그먼트(107B)가 할당 해제될 수 있고, 가상 드라이브 LBA 세그먼트(107B)와 이전에 연관되었던 가상 드라이브(104B)의 일부가 이용가능한 시스템 메모리 풀로 복귀될 수 있다.
본 발명과 그에 수반되는 많은 이점들은 상기의 설명에 의해 이해될 것으로 여겨진다. 또한 발명의 범위와 사상을 벗어나지 않고 또는 그 필수적인 이점들을 손해보지 않고서 발명의 구성 요소들의 형태, 구성 및 배치가 다양하게 변경될 수 있다는 것이 명백할 것으로 여겨진다. 전술한 형태는 단지 설명을 위한 실시예일 뿐이다. 후술하는 청구항은 그러한 변경을 포괄 및 포함하고자 하는 것이다.
전술한 상세한 설명은 블록도, 플로우차트 및/또는 예를 사용함으로써 장치 및/또는 프로세스의 기재된 다양한 실시예를 포함할 수 있다. 그러한 블록도, 플로우차트 및/또는 예가 하나 이상의 기능 및/또는 동작을 포함하는 한, 당업자들은 그러한 블록도, 플로우차트 및 예의 범위 내에 있는 각 기능 및/또는 동작이 광범위한 하드웨어, 소프트웨어, 펌웨어 또는 그들의 실질적인 임의의 조합에 의해 개별적으로 및/또는 집합적으로 구현될 수 있다는 것을 이해할 것이다. 일 실시예에서, 여기에 기재된 주제의 여러 부분들은 주문형 집적 회로(ASICs), 현장 프로그래머블 게이트 어레이(FPGAs), 디지털 신호 처리기(DSPs), 또는 다른 집적 형태로 구현될 수 있다. 그러나, 당업자들은 여기에 개시된 실시예의 일부 측면이 그 전체로 또는 부분적으로 집적 회로 내에 하나 이상의 컴퓨터에서 실행되는 하나 이상의 컴퓨터 프로그램들(예를 들면, 하나 이상의 컴퓨터 시스템에서 실행되는 하나 이상의 프로그램들), 하나 이상의 프로세서에서 실행되는 하나 이상의 프로그램들(예를 들면, 하나 이상의 마이크로프로세서에서 실행되는 하나 이상의 프로그램들), 펌웨어, 또는 그들의 실질적인 임의의 조합으로서 동등하게 구현될 수 있다는 것을 인정할 것이며, 그러한 회로를 설계하는 것 및/또는 그러한 소프트웨어 및/또는 펌웨어를 위한 코드를 기입하는 것이 본 명세서를 고려하여 당업자의 기술 내에서 충분히 가능하다는 것을 인정할 것이다.
부가적으로, 당업자들은 여기에 기재된 주제의 메커니즘이 다양한 형태로 프로그램 제품으로서 배포될 수 있다는 것과, 여기에 기재된 주제의 예시적인 실시예가 실제로 배포되기 위해 사용되는 신호 운반 매체의 특정 형태에 관계없이 적용된다는 것을 이해할 것이다. 신호 운반 매체의 예는, 제한되지는 않지만, 플로피 디스크, 하드 디스크 드라이브, 컴팩트 디스크(CD), 디지털 비디오 디스크(DVD), 디지털 테이프, 컴퓨터 메모리 등과 같은 기록 가능 매체; 및 디지털 및/또는 아날로그 통신 매체(예를 들면, 광 섬유 케이블, 도파관, 유선 통신 링크, 무선 통신 링크(예를 들면, 송신기, 수신기, 송신 로직, 수신 로직 등) 등)와 같은 전송형 매체를 포함할 수 있다.
당업자들은 하드웨어, 소프트웨어 및/또는 펌웨어 사이에 차이가 거의 존재하지 않을 수 있는 지점까지 발전된 본 기술 분야의 상태가 시스템 측면의 구현을 포함할 수 있다는 것을 이해할 것이다; 하드웨어, 소프트웨어 및/또는 펌웨어의 사용은 (반드시 그러한 것은 아니지만, 어떤 상황에서는 하드웨어와 소프트웨어 사이의 선택이 중요해질 수 있다는 점에서) 일반적으로 비용 대비 효율 트레이드 오프를 나타내는 설계 선택이 될 수 있다. 당업자들은 여기에 기술된 프로세스 및/또는 시스템 및/또는 다른 기술들이 영향을 받을 수 있는 다양한 전달 수단(예를 들면, 하드웨어, 소프트웨어 및/또는 펌웨어)이 존재할 수 있다는 것과, 프로세스 및/또는 시스템 및/또는 다른 기술이 배치될 수 있는 상황에 따라 우선하는 전달 수단이 달라질 수 있다는 것을 이해할 것이다. 예를 들어, 구현자가 속도 및 정확도가 중요하다고 판단하면, 구현자는 주로 하드웨어 및/또는 펌웨어 전달 수단을 채택할 수 있고; 그렇지 않고 유연성이 중요할 수 있다면, 구현자는 주로 소프트웨어 구현을 채택할 수 있고; 또한 그렇지 않다면 구현자는 하드웨어, 소프트웨어 및/또는 펌웨어의 일부 조합을 채택할 수 있다. 따라서, 여기에 기술된 프로세스 및/또는 장치 및/또는 다른 기술이 영향받을 수 있는 여러 개의 가능한 전달 수단이 존재할 수 있으며, 전달 수단이 배치될 상황 및 가변될 수 있는 구현자의 특정 관심사(예를 들면, 속도, 유연성 또는 예측 가능성)에 따라서 사용될 임의의 전달 수단이 선택될 수 있다는 점에서 그들 전달 수단 중 어느 것도 다른 것보다 본질적으로 우월하다고 할 수는 없다. 당업자는 구현의 광학적인 측면이 통상적으로 광 지향적인 하드웨어, 소프트웨어 또는 펌웨어를 이용할 것이라는 사실을 이해할 것이다.

Claims (24)

  1. 저장장치 핫 스팟(storage hot-spot) 및 저장장치 콜드 스팟(storage cold-spot) 중 적어도 하나를 포함하는 가상 볼륨의 시점 복사본(point-in-time copy)을 생성하는 단계와,
    상기 가상 볼륨으로 전달된 기입 동작들을 시점(point-in-time;PiT) 임시 가상 볼륨으로 재전달하는 단계와,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 단계와,
    상기 제 2 저장장치 풀 내의 상기 가상 볼륨 세그먼트 복사본을 참조(reference)하기 위해 상기 가상 볼륨의 논리적 블록 어드레스 매핑을 재구성하는 단계와,
    상기 가상 볼륨의 시점 복사본을 삭제할 때 상기 제 2 저장장치 풀 내의 상기 가상 볼륨 세그먼트 복사본을 상기 시점 임시 가상 볼륨의 데이터로 갱신하는 단계를 포함하는
    동적 저장장치 계층화(dynamic storage tiering) 방법.
  2. 제 1 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 단계는, 상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 고성능 저장장치 풀의 가상 볼륨 세그먼트로 복사하는 단계를 포함하는
    동적 저장장치 계층화 방법.
  3. 제 1 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 단계는, 상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 저성능 저장장치 풀의 가상 볼륨 세그먼트로 복사하는 단계를 포함하는
    동적 저장장치 계층화 방법.
  4. 제 1 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 상기 제 1 저장장치 풀의 상기 가상 볼륨으로부터 할당 해제(de-allocating)하는 단계를 더 포함하는
    동적 저장장치 계층화 방법.
  5. 저장장치 핫 스팟 및 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨의 시점 복사본을 생성하는 수단과,
    상기 가상 볼륨으로 전달된 기입 동작들을 시점 임시 가상 볼륨으로 재전달하는 수단과,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 수단과,
    상기 제 2 저장장치 풀 내의 상기 가상 볼륨 세그먼트 복사본을 참조하기 위해 상기 가상 볼륨의 논리적 블록 어드레스 매핑을 재구성하는 수단과,
    상기 가상 볼륨의 시점 복사본을 삭제할 때 상기 제 2 저장장치 풀 내의 상기 가상 볼륨 세그먼트 복사본을 상기 시점 임시 가상 볼륨의 데이터로 갱신하는 수단을 포함하는
    동적 저장장치 계층화 시스템.
  6. 제 5 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 수단은, 상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 고성능 저장장치 풀의 가상 볼륨 세그먼트로 복사하는 수단을 포함하는
    동적 저장장치 계층화 시스템.
  7. 제 5 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 수단은, 상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 저성능 저장장치 풀의 가상 볼륨 세그먼트로 복사하는 수단을 포함하는
    동적 저장장치 계층화 시스템.
  8. 제 5 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 상기 제 1 저장장치 풀의 상기 가상 볼륨으로부터 할당 해제하는 수단을 더 포함하는
    동적 저장장치 계층화 시스템.
  9. 저장장치 핫 스팟 및 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨의 시점 복사본을 생성하는 회로와,
    상기 가상 볼륨으로 전달된 기입 동작들을 시점 임시 가상 볼륨으로 재전달하는 회로와,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 회로와,
    상기 제 2 저장장치 풀 내의 상기 가상 볼륨 세그먼트 복사본을 참조하기 위해 상기 가상 볼륨의 논리적 블록 어드레스 매핑을 재구성하는 회로와,
    상기 가상 볼륨의 시점 복사본을 삭제할 때 상기 제 2 저장장치 풀 내의 상기 가상 볼륨 세그먼트 복사본을 상기 시점 임시 가상 볼륨의 데이터로 갱신하는 회로를 포함하는
    동적 저장장치 계층화 시스템.
  10. 제 9 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 회로는, 상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 고성능 저장장치 풀의 가상 볼륨 세그먼트로 복사하는 회로를 포함하는
    동적 저장장치 계층화 시스템.
  11. 제 9 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 가상 볼륨 세그먼트를 제 1 저장장치 풀로부터 제 2 저장장치 풀로 복사하는 회로는, 상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 저성능 저장장치 풀의 가상 볼륨 세그먼트로 복사하는 회로를 포함하는
    동적 저장장치 계층화 시스템.
  12. 제 9 항에 있어서,
    상기 저장장치 핫 스팟 및 상기 저장장치 콜드 스팟 중 적어도 하나를 포함하는 상기 가상 볼륨 세그먼트를 상기 제 1 저장장치 풀의 상기 가상 볼륨으로부터 할당 해제하는 회로를 더 포함하는
    동적 저장장치 계층화 시스템.
  13. 삭제
  14. 삭제
  15. 삭제
  16. 삭제
  17. 삭제
  18. 삭제
  19. 삭제
  20. 삭제
  21. 삭제
  22. 삭제
  23. 삭제
  24. 삭제
KR1020117011778A 2009-01-23 2009-03-31 동적 저장장치 계층화 방법 및 시스템 KR101405729B1 (ko)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US20581009P 2009-01-23 2009-01-23
US61/205,810 2009-01-23
PCT/US2009/001991 WO2010085228A1 (en) 2009-01-23 2009-03-31 Method and system for dynamic storage tiering using allocate-on-write snapshots

Publications (2)

Publication Number Publication Date
KR20110117057A KR20110117057A (ko) 2011-10-26
KR101405729B1 true KR101405729B1 (ko) 2014-06-10

Family

ID=42356122

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020117011778A KR101405729B1 (ko) 2009-01-23 2009-03-31 동적 저장장치 계층화 방법 및 시스템

Country Status (7)

Country Link
US (1) US8713267B2 (ko)
EP (1) EP2382548A4 (ko)
JP (1) JP5456063B2 (ko)
KR (1) KR101405729B1 (ko)
CN (1) CN102150144B (ko)
TW (1) TWI475393B (ko)
WO (1) WO2010085228A1 (ko)

Families Citing this family (33)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8713267B2 (en) 2009-01-23 2014-04-29 Lsi Corporation Method and system for dynamic storage tiering using allocate-on-write snapshots
CN102272742B (zh) * 2009-01-29 2015-08-05 Lsi公司 为卷提供动态存储分级的在线数据放置的写时分配快照机制
US9134922B2 (en) 2009-03-12 2015-09-15 Vmware, Inc. System and method for allocating datastores for virtual machines
US8732217B2 (en) * 2009-10-30 2014-05-20 Symantec Corporation Using a per file activity ratio to optimally relocate data between volumes
US8375180B2 (en) * 2010-02-05 2013-02-12 International Business Machines Corporation Storage application performance matching
US20120047108A1 (en) * 2010-08-23 2012-02-23 Ron Mandel Point-in-time (pit) based thin reclamation support for systems with a storage usage map api
US8539172B1 (en) 2010-11-08 2013-09-17 Infinidat Ltd. System and method for accessing data in an external virtual memory
US8645659B1 (en) 2010-12-01 2014-02-04 Infinidat Ltd. Method for managing volumes/snapshots in pools of external virtual memory
WO2012131753A1 (en) * 2011-03-25 2012-10-04 Hitachi, Ltd. Storage system and performance management method of storage system
US20120259961A1 (en) * 2011-04-07 2012-10-11 Infinidat Ltd. System of managing remote resources
US8918615B2 (en) 2011-04-27 2014-12-23 Hitachi, Ltd. Information storage system including a plurality of storage systems that is managed using system and volume identification information and storage system management method for same
US8775774B2 (en) 2011-08-26 2014-07-08 Vmware, Inc. Management system and methods for object storage system
US8650359B2 (en) 2011-08-26 2014-02-11 Vmware, Inc. Computer system accessing object storage system
US8595460B2 (en) 2011-08-26 2013-11-26 Vmware, Inc. Configuring object storage system for input/output operations
US8775773B2 (en) 2011-08-26 2014-07-08 Vmware, Inc. Object storage system
US8769174B2 (en) 2011-08-29 2014-07-01 Vmware, Inc. Method of balancing workloads in object storage system
US8677085B2 (en) 2011-08-29 2014-03-18 Vmware, Inc. Virtual machine snapshotting in object storage system
US8719523B2 (en) * 2011-10-03 2014-05-06 International Business Machines Corporation Maintaining multiple target copies
US9063768B2 (en) 2011-10-10 2015-06-23 Vmware, Inc. Method and apparatus for comparing configuration and topology of virtualized datacenter inventories
US9058120B2 (en) * 2011-11-09 2015-06-16 International Business Machines Corporation Setting optimal space allocation policy for creating dependent snapshots to enhance application write performance and reduce resource usage
US9087201B2 (en) 2012-01-05 2015-07-21 Infinidat Ltd. System and methods for host enabled management in a storage system
IN2014DN05977A (ko) * 2012-02-08 2015-06-26 Hitachi Ltd
WO2013159068A1 (en) 2012-04-20 2013-10-24 Enmotus Inc. Storage system with data management mechanism and method of operation thereof
US9311019B2 (en) 2013-07-29 2016-04-12 Infinidat Ltd. Storage system and method for accessing logical volumes
US9880786B1 (en) * 2014-05-30 2018-01-30 Amazon Technologies, Inc. Multi-tiered elastic block device performance
US10061915B1 (en) 2014-09-03 2018-08-28 Amazon Technologies, Inc. Posture assessment in a secure execution environment
US10176212B1 (en) 2014-10-15 2019-01-08 Seagate Technology Llc Top level tier management
CN104536909B (zh) * 2014-12-09 2018-01-23 华为技术有限公司 一种存储管理方法,存储管理装置及存储设备
EP3104086B1 (en) * 2015-06-11 2019-09-18 Electrolux Professional S.p.A. Flavoring device for use in a cooking chamber
CN105278878B (zh) * 2015-09-30 2018-09-21 成都华为技术有限公司 一种磁盘空间分配方法及装置
US10031675B1 (en) * 2016-03-31 2018-07-24 Emc Corporation Method and system for tiering data
US11210023B2 (en) * 2017-06-30 2021-12-28 Intel Corporation Technologies for data management in vehicle-based computing platforms
US11010091B2 (en) * 2019-08-29 2021-05-18 International Business Machines Corporation Multi-tier storage

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060010169A1 (en) 2004-07-07 2006-01-12 Hitachi, Ltd. Hierarchical storage management system
US7225211B1 (en) * 2003-12-31 2007-05-29 Veritas Operating Corporation Multi-class storage mechanism

Family Cites Families (29)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH096678A (ja) * 1995-06-19 1997-01-10 Toshiba Corp 階層記憶装置
US6311252B1 (en) 1997-06-30 2001-10-30 Emc Corporation Method and apparatus for moving data between storage levels of a hierarchically arranged data storage system
US6076143A (en) * 1997-09-02 2000-06-13 Emc Corporation Method and apparatus for managing the physical storage locations for blocks of information in a storage system to increase system performance
JP2001093220A (ja) * 1999-09-20 2001-04-06 Nec Eng Ltd 複数ハードディスクドライブ環境における省電力制御システム及び省電力制御方法
US6684231B1 (en) * 1999-11-29 2004-01-27 Microsoft Corporation Migration of friendly volumes
JP2002073383A (ja) 2000-08-31 2002-03-12 Matsushita Electric Ind Co Ltd 情報サービスの方法
US6961727B2 (en) * 2001-03-15 2005-11-01 International Business Machines Corporation Method of automatically generating and disbanding data mirrors according to workload conditions
US20040139125A1 (en) 2001-06-05 2004-07-15 Roger Strassburg Snapshot copy of data volume during data access
TWI231442B (en) * 2001-06-19 2005-04-21 Terraspring Inc Virtual storage layer approach for dynamically associating computer storage with processing hosts
US7168010B2 (en) * 2002-08-12 2007-01-23 Intel Corporation Various methods and apparatuses to track failing memory locations to enable implementations for invalidating repeatedly failing memory locations
US7191304B1 (en) * 2002-09-06 2007-03-13 3Pardata, Inc. Efficient and reliable virtual volume mapping
US6880053B2 (en) * 2002-12-19 2005-04-12 Veritas Operating Corporation Instant refresh of a data volume copy
JP3808851B2 (ja) * 2003-09-10 2006-08-16 株式会社東芝 ディスクアレイコントローラ、ディスクアレイ装置及びディスクアレイ制御プログラム
US20050240584A1 (en) * 2004-04-21 2005-10-27 Hewlett-Packard Development Company, L.P. Data protection using data distributed into snapshots
US7383406B2 (en) * 2004-11-19 2008-06-03 International Business Machines Corporation Application transparent autonomic availability on a storage area network aware file system
GB0514529D0 (en) 2005-07-15 2005-08-24 Ibm Virtualisation engine and method, system, and computer program product for managing the storage of data
JP4261532B2 (ja) * 2005-09-13 2009-04-30 株式会社東芝 論理ディスク管理方法及び仮想化装置
US7823007B2 (en) * 2006-02-17 2010-10-26 International Business Machines Corporation Apparatus, system, and method for switching a volume address association in a point-in-time copy relationship
JP4890048B2 (ja) * 2006-02-24 2012-03-07 株式会社日立製作所 記憶制御装置及び記憶制御装置を用いたデータマイグレーション方法
US7734954B2 (en) * 2007-01-03 2010-06-08 International Business Machines Corporation Method, computer program product, and system for providing a multi-tiered snapshot of virtual disks
JP2008197779A (ja) 2007-02-09 2008-08-28 Fujitsu Ltd 階層型ストレージ管理システム、階層制御装置、階層間ファイル移動方法、及びプログラム
CN101034375A (zh) * 2007-02-12 2007-09-12 忆正存储技术(深圳)有限公司 计算机存储系统
US7822939B1 (en) * 2007-09-25 2010-10-26 Emc Corporation Data de-duplication using thin provisioning
US8527720B2 (en) * 2008-12-03 2013-09-03 Lsi Corporation Methods of capturing and naming dynamic storage tiering configurations to support data pre-staging
US8713267B2 (en) * 2009-01-23 2014-04-29 Lsi Corporation Method and system for dynamic storage tiering using allocate-on-write snapshots
CN102272742B (zh) * 2009-01-29 2015-08-05 Lsi公司 为卷提供动态存储分级的在线数据放置的写时分配快照机制
US20120047108A1 (en) * 2010-08-23 2012-02-23 Ron Mandel Point-in-time (pit) based thin reclamation support for systems with a storage usage map api
US8892838B2 (en) * 2011-06-21 2014-11-18 International Business Machines Corporation Point-in-time copying of virtual storage and point-in-time dumping
US8898413B2 (en) * 2011-06-21 2014-11-25 International Business Machines Corporation Point-in-time copying of virtual storage

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7225211B1 (en) * 2003-12-31 2007-05-29 Veritas Operating Corporation Multi-class storage mechanism
US20060010169A1 (en) 2004-07-07 2006-01-12 Hitachi, Ltd. Hierarchical storage management system

Also Published As

Publication number Publication date
WO2010085228A1 (en) 2010-07-29
TWI475393B (zh) 2015-03-01
CN102150144B (zh) 2014-12-24
KR20110117057A (ko) 2011-10-26
TW201028859A (en) 2010-08-01
JP5456063B2 (ja) 2014-03-26
EP2382548A1 (en) 2011-11-02
US8713267B2 (en) 2014-04-29
CN102150144A (zh) 2011-08-10
JP2012515969A (ja) 2012-07-12
EP2382548A4 (en) 2012-08-15
US20110078398A1 (en) 2011-03-31

Similar Documents

Publication Publication Date Title
KR101405729B1 (ko) 동적 저장장치 계층화 방법 및 시스템
US9170756B2 (en) Method and system for dynamic storage tiering using allocate-on-write snapshots
US10176212B1 (en) Top level tier management
US8627035B2 (en) Dynamic storage tiering
US10031703B1 (en) Extent-based tiering for virtual storage using full LUNs
US7441096B2 (en) Hierarchical storage management system
US8914597B2 (en) Data archiving using data compression of a flash copy
CN107526689B (zh) 读高速缓存管理
JP5891027B2 (ja) 記憶装置をサニタイズする方法及び装置
US10929066B1 (en) User stream aware file systems with user stream detection
US11461287B2 (en) Managing a file system within multiple LUNS while different LUN level policies are applied to the LUNS
JP2014519062A (ja) ストレージシステム及びその論理ユニット管理方法
US20130054883A1 (en) Method and system for shared high speed cache in sas switches
US10365846B2 (en) Storage controller, system and method using management information indicating data writing to logical blocks for deduplication and shortened logical volume deletion processing
US11947803B2 (en) Effective utilization of different drive capacities
US12147678B2 (en) Handling data with different lifetime characteristics in stream-aware data storage equipment
US20230176743A1 (en) Handling data with different lifetime characteristics in stream-aware data storage equipment
JP2004355040A (ja) ディスク制御装置およびデータ先読み方法
WO2015145707A1 (ja) 追記型記憶装置への書き込みデータ決定方法

Legal Events

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

Payment date: 20180601

Year of fee payment: 5

LAPS Lapse due to unpaid annual fee