KR102159835B1 - 보조기억장치의 복구정보 관리 장치 및 방법 - Google Patents

보조기억장치의 복구정보 관리 장치 및 방법 Download PDF

Info

Publication number
KR102159835B1
KR102159835B1 KR1020190051807A KR20190051807A KR102159835B1 KR 102159835 B1 KR102159835 B1 KR 102159835B1 KR 1020190051807 A KR1020190051807 A KR 1020190051807A KR 20190051807 A KR20190051807 A KR 20190051807A KR 102159835 B1 KR102159835 B1 KR 102159835B1
Authority
KR
South Korea
Prior art keywords
recovery information
auxiliary storage
storage device
file system
system object
Prior art date
Application number
KR1020190051807A
Other languages
English (en)
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 김덕우
Priority to KR1020190051807A priority Critical patent/KR102159835B1/ko
Priority to US17/608,259 priority patent/US20220206904A1/en
Priority to EP20798273.7A priority patent/EP3964962A4/en
Priority to JP2021564867A priority patent/JP2022530169A/ja
Priority to PCT/KR2020/005254 priority patent/WO2020222453A1/ko
Priority to CN202080040915.9A priority patent/CN114174998A/zh
Application granted granted Critical
Publication of KR102159835B1 publication Critical patent/KR102159835B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1446Point-in-time backing up or restoration of persistent data
    • G06F11/1448Management of the data involved in backup or backup restore
    • G06F11/1451Management of the data involved in backup or backup restore by selection of backup contents
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1415Saving, restoring, recovering or retrying at system level
    • G06F11/1417Boot up procedures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1415Saving, restoring, recovering or retrying at system level
    • G06F11/142Reconfiguring to eliminate the error
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1446Point-in-time backing up or restoration of persistent data
    • G06F11/1458Management of the backup or restore process
    • 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/0614Improving the reliability of storage systems
    • G06F3/0619Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
    • 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/062Securing storage systems
    • G06F3/0622Securing storage systems in relation to access
    • 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/0629Configuration or reconfiguration of storage systems
    • G06F3/0637Permissions
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Human Computer Interaction (AREA)
  • Computer Security & Cryptography (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

본 발명은 보조기억장치 내의 백업 보조기억장치의 용량을 효율적으로 관리할 수 있는 장치 및 방법에 관한 것이다. 보조기억장치(20)에 원본 보조기억장치(30)와 백업 보조기억장치(40)가 포함되어 있고, 또한, 원본 보조기억장치(30) 및 백업 보조기억장치(40) 이외에 사용자입력장치(50)가 있다. 이들 원본 보조기억장치(30), 백업 보조기억장치(40), 사용자입력장치(50)는 제어장치(60)에 의해 제어된다. 백업 보조기억장치(40)는 원본 보조기억장치(30)의 복구정보를 저장한다. 사용자입력장치(50)는 정상모드와 백업모드를 전환하기 위한 사용자 입력을 받는 장치이다. 정상모드일 때에 제어장치(60는 호스트컴퓨터(10)가 원본 보조기억장치(30)의 OS를 이용하여 부팅되고 백업 보조기억장치(40)에는 접근이 불가능하도록 보조기억장치(20)를 제어한다. 그리고, 백업모드일 때 제어장치(60)는 호스트컴퓨터(10)가 백업 보조기억장치(40)에 보관된 OS의 사본 또는 보조기억장치(20)가 별도로 제공하는 OS로 부팅되도록 보조기억장치(20)를 제어하고, 백업 보조기억장치(40)가 기록한 복구정보를 기반으로 원본 보조기억장치(30)의 복구를 수행한다.

Description

보조기억장치의 복구정보 관리 장치 및 방법 {Apparatus and method for managing recovery information of auxiliary storage device}
본 발명은 원본 보조기억장치와 백업 보조기억장치를 포함하는 보조기억장치의 복구정보를 관리하여 백업 보조기억장치의 용량을 효과적으로 활용할 수 있는 장치 및 방법에 관한 것이다.
최근 랜섬웨어와 같은 악성코드들이 사용자파일을 암호화시키는 것은 물론 시스템복구정보가 담긴 파티션이나 폴더까지 삭제하는 경우가 발생하고 있다. 이처럼 기존의 컴퓨터구조처럼 시스템 전체가 하나의 OS로 통제되는 경우에 해킹프로그램이나 컴퓨터바이러스와 같은 악성코드가 최상위 관리자의 자격으로 시스템을 장악하게 되면 시스템의 형상변경을 막을 수 없게 된다. 또한 악의를 가진 제삼자가 일시적으로 접근권한을 얻어 시스템에 위해를 가하는 경우에도 대응이 불가능하다.
이러한 문제에 대응하여 본 출원인은 몇 가지 발명을 출원한바 있다(출원번호 10-2017-0057998, 특허 10-1920866 및 10-1920867). 이들 선출원 발명은 원본 보조기억장치와 백업용 보조기억장치를 포함하는 보조기억장치를 다루고 있는데, 원본 보조기억장치는 호스트컴퓨터가 상시 액세스 가능하지만 백업용 보조기억장치는 특정조건(예를 들면 복구모드의 조건)에서만 사용자의 액세스가 가능하도록 제한되는 특징이 있다. 따라서 이들 선출원 발명을 이용하면 안전한 백업 및 복구가 가능하다. 그러나 호스트컴퓨터가 보조기억장치를 액세스할 때마다 백업을 위한 정보를 기록한다면 매우 큰 용량의 백업 보조기억장치가 필요하게 된다. 특히 OS나 어플리케이션프로그램 등은 임시파일들을 빈번하게 만드는데 이때 이들 임시파일들에 대해서는 백업을 위한 정보를 만들어 저장할 필요가 없으며, 나아가 사용자가 백업이 필요하지 않다고 판단하는 저장공간이 있다면 이 저장공간도 백업이 불필요하다. 상기 선출원 발명에서는 이러한 부분을 다루고 있지 않지만 이는 선출원 발명들의 기술이 적용된 또는 그와 유사한 보조기억장치에서 매우 중요하다. 특히 노트북과 같이 SSD(Solid State Drive)를 보조기억장치에 사용하는 경우나 대용량서버의 대용량 보조기억장치의 경우에는 용량에 따라 가격에 큰 차이가 나므로 백업 보조기억장치의 저장공간을 효율적으로 관리할 수 있는 기술이 제공된다면 비용을 크게 줄일 수 있게 될 것이다.
본 발명은 상기 선등록발명 또는 이와 유사한 방식으로 백업 보조기억장치를 포함시켜 설계된 컴퓨터 보조기억장치의 복구 구조의 단점을 보완하여, 분석에 따라 백업여부 자체를 판단하거나 백업된 복구정보를 삭제함으로써 보조기억장치 내의 백업 보조기억장치의 용량을 효율적으로 관리할 수 있는 장치를 제안함을 목적으로 한다.
이와 같이 선출원 발명들에 따른 보조기억장치에 선별적으로 백업정보를 만들어 저장하는 기능을 부여한다면 백업 보조기억장치의 용량을 줄일 수 있어 가격면에서 매우 큰 장점이 있다. 그러나 선별적으로 백업정보를 만들기 위해서는 호스트컴퓨터가 보조기억장치를 액세스할 때 전달되는 액세스정보의 분석이 반드시 필요하다. 예를 들어 OS가 임시파일을 지우고 새로운 임시파일을 만드는 중이라면 이와 관련된 정보는 백업이 필요없을 것이다. 그러나 이를 판단할 수 있는 어떠한 기능도 기존의 보조기억장치와 선출원 발명의 보조기억장치에는 구현되어 있지 않다. 이를 자세히 살펴보면 다음과 같다.
일반적으로 보조기억장치는 호스트 컴퓨터로부터 전달받은 접근정보를 이용하여 읽기나 쓰기와 같은 동작을 수행한다. 이때 호스트 컴퓨터는, 주로 파일이름이나 폴더이름이 아닌 CHS(Cylinder Head Sector) 어드레스 방식이나 LBA(Logical Block Address) 방식으로 액세스가 필요한 데이타영역의 어드레스를 지정하여 액세스하게 된다.
결국 어떤 방식이든 클러스터번호, 헤드번호, 섹터번호와 같은 저장공간의 특정 영역을 직간접으로 지정하는 어드레스를 이용하게 되는데, 이는 호스트 컴퓨터의 파일시스템이 보조기억장치가 아니라 호스트컴퓨터에서 관리되기 때문이다. 물론 일부 보조기억장치들은 별도의 프로토콜을 이용하여 파일단위 정보도 주고받을 수 있으나 일반적으로 데스크탑 PC나 노트북에 널리 쓰이는 HDD와 SSD 등의 제품들은 어드레스를 직접 제공하는 방식으로 보조기억장치에 액세스한다.
그런데 이때 전달되는 액세스정보들에는 일반적으로 파일 이름이나 파일 경로와 같은 정보가 사실상 없으므로 파일이나 디렉토리, MBR(Master Boot Record) 등과 같은 파일시스템 객체에 대한 액세스여부를 확인하려면 보조기억장치 쪽에서 액세스정보를 분석하여야 한다. 그러나 일반적인 기존 보조기억장치에서는 이러한 작업이 불필요하고 만일 이러한 작업을 수행하면 보조기억장치의 처리속도만 늦어질 뿐 아무런 이익이 없다.
그에 비하여 본 발명에 따른 보조기억장치는 이러한 작업을 수행함으로써 처리속도는 조금 늦어지게 되지만 복구정보의 저장공간을 매우 효율적으로 관리할 수 있어 제작 비용을 크게 줄일 수 있으며 사용자에게는 자신이 원하는 파일이나 디렉토리만을 백업할 수 있는 수단 제공이 가능하다. 더구나 시간이 많이 걸리는 작업은 백그라운드작업으로 처리하게 되면 처리속도의 하락도 막을 수 있어 보다 효율적일 것으로 판단된다.
전술한 과제해결을 위하여 이상의 개념을 구체화하여 완성한 본 발명의 제1측면에 따른 컴퓨터 보조기억장치는, 호스트컴퓨터가 보조기억장치에 액세스(접근)하는 구성으로, 보조기억장치는 원본 보조기억장치; 원본 보조기억장치의 복구정보를 저장하는 백업 보조기억장치; 정상모드와 백업모드를 전환하기 위한 사용자 입력등을 받는 사용자입력장치; 그리고 상기 원본 보조기억장치, 백업 보조기억장치, 및 사용자입력장치와 연결되어 보조기억장치의 상기 정상모드와 백업모드를 제어하거나 사용자명령에 따라 복구정보를 관리하는 제어장치를 포함한다.
상기 제어장치에 의해 제어되는 보조기억장치는 정상모드와 백업모드로 동작한다. 이 정상모드와 백업모드는 상기 사용자입력장치에 의해 사용자가 선택할 수 있다. 정상모드일 때 상기 제어장치는 호스트컴퓨터가 원본 보조기억장치의 OS를 이용하여 부팅되고 백업 보조기억장치에는 접근이 불가능하도록 보조기억장치를 제어한다. 백업모드일 때 상기 제어장치는 호스트컴퓨터가 백업 보조기억장치에 보관된 OS의 사본 또는 보조기억장치가 별도로 제공하는 OS로 부팅되도록 보조기억장치를 제어하고, 백업 보조기억장치가 기록한 복구정보를 기반으로 원본 보조기억장치의 복구를 수행한다.
상기 제어장치는 보조기억장치를 제어하는 CPU의 기능 연산을 담당하는 소프트웨어와 관련하드웨어로 구현가능한데 선행발명에서와 같이 원본보조기억장치및 백업보조기억장치, 사용자입력장치와 다양한 형태로 연결될 수 있고, 사용자입력장치는 사용자에 의해 조작되는 전기적인 스위치로 구현될 수 있다. 다른 한편으로 사용자입력장치는 통신모듈로 구성하여 유무선으로 전달받은 정보를 바탕으로 단수 또는 복수의 사용자입력을 확인하는 방식으로 구현될 수도 있다.
발명의 한 실시형태에서 상기 제어장치는 원본보조기억장치의 복구정보를 만들어 저장할지를 관리하는 복구정보관리모듈을 포함한다.
여기서, 상기 복구정보관리모듈은 원본 보조기억장치를 액세스하기 위하여 호스트컴퓨터가 제공한 액세스정보를 분석하는 액세스정보분석부; 상기 액세스정보에 포함된 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부; 확인된 파일시스템객체가 사용자가 지정한 복구필요객체인 경우, 상기 액세스어드레스의 저장공간에 대한 복구정보를 만들어 기록하는 복구정보기록부를 포함할 수 있다.
한편 상기 복구정보관리모듈은, 다른 실시형태로, 원본 보조기억장치를 액세스하기 위하여 호스트컴퓨터가 제공한 액세스정보를 분석하는 액세스정보분석부; 상기 액세스정보에 포함된 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를, 호스트컴퓨터의 파일시스템을 분석하여 파일이나 디렉토리에 할당된 섹터나 클러스터정보가 표로써 작성된 검색테이블과 비교하여 확인하는 파일시스템객체확인부; 확인된 파일시스템객체가 사용자가 지정한 복구필요객체인 경우, 상기 액세스어드레스의 저장공간에 대한 복구정보를 만들어 기록하는 복구정보기록부를 포함할 수 있다.
또한, 발명의 다른 실시형태에서 상기 제어장치는 기 저장된 원본보조기억장치의 복구정보를 삭제하는 복구정보삭제모듈을 포함할 수 있다.
이 복구정보삭제모듈은, 백업 보조기억장치에 기저장된 복구정보의 액세스어드레스를 추출하는 복구정보분석부; 상기 복구정보에 포함된 액세스어드레스를 사용하는 파일시스템 객체를 확인하는 파일시스템객체확인부; 확인된 파일시스템객체가 사용자가 지정한 복구불필요객체인 경우에 기저장된 복구정보를 삭제하는 복구정보삭제부를 포함할 수 있다.
전술한 과제해결을 위한 본 발명의 제2측면에 따른 보조기억장치는 상기 제1측면의 보조기억장치에 표시장치를 추가로 포함한다. 여기서, 표시장치는 LED나 디스플레이, 알람장치 등으로 구성될 수 있고, 다른 실시형태에 따르면, 사용자입력장치와 유사한 방식으로 통신모듈로 구성하여 유무선으로 전달받은 정보를 바탕으로 사용자입력을 확인하는 방식으로 구현할 수 있다. 또는 사용자입력장치와 표시장치를 하나의 입출력장치로 통합하여 구성하는 것도 가능하다.
이 제2측면에 따른 보조기억장치의 제어장치는 사용자입력장치로부터 사용자명령을 입력받는 사용자명령입력모듈; 표시장치를 구동하는 표시장치구동모듈; 입력된 사용자명령에 따라 복구정보를 삭제하거나 압축하는 복구정보정비모듈을 추가로 포함하여 구성될 수 있다.
상기 복구정보정비모듈은 백업 보조기억장치에 기저장된 복구정보를 분석하여 액세스어드레스를 추출하는 복구정보분석부; 상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부; 확인된 파일시스템객체가 사용자명령에서 삭제대상으로 지정된 파일시스템 객체인지를 판단하여 일치하는 경우, 상기 복구정보를 삭제하는 복구정보삭제부를 포함할 수 있다.
한편, 상기 복구정보정비모듈은, 다른 실시형태로서, 백업 보조기억장치에 기저장된 복구정보를 분석하여 액세스어드레스를 추출하는 복구정보분석부; 상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부; 확인된 파일시스템객체가 사용자명령에서 압축대상으로 지정된 파일시스템 객체인지를 판단하여 일치하는 경우, 상기 복구정보를 압축하는 복구정보압축부를 포함할 수 있다.
여기서 상기 두 가지 실시형태의 복구정보정비모듈은 사용자명령을 분석하는 사용자명령분석부; 분석된 사용자명령에 해당하는 기 설정된 알고리즘에 따라 백업보조기억장치에 기저장된 복구정보를 삭제하거나 압축하거나 전송하는 등의 기능을 수행하는 정비알고리즘실행부를 포함할 수 있다. 또한 상기 두 가지 실시형태의 복구정보정비모듈은 상기와 같은 작업들을 수행하는 과정에서 발생하는 정보제공이나 사용자의 추가입력 등을 위하여 상기 표시수단에 정보를 표시하는 정보표시부를 추가적으로 더 포함할 수 있다.
또한 본 발명의 또다른 측면에 따르면, 이상에서 설명한 보조기억장치의 복구정보 관리 장치를 방법적 수단으로 실행 또는 구현하는 복구정보 관리 방법이 제공된다.
또한 본 발명의 또다른 측면에 따르면, 이상에서 설명한 보조기억장치의 복구정보 관리 장치 및/또는 복구정보 관리 방법이 적용된 컴퓨터(PC), 서버 컴퓨터, 모바일폰, 자동제어장치 등의 응용기기들이 제공된다.
이상에서 소개한 본 발명의 포괄적인 구성은 차후에 도면과 함께 설명하는 구체적인 실시예를 통하여 보다 명확해질 것이다.
본 발명에 따른 원본 보조기억장치와 백업 보조기억장치를 포함하는 보조기억장치는 복구정보를 관리하여 백업 보조기억장치의 용량을 효과적으로 활용함으로써, 본 발명에 따른 기술이 적용되지 않는 제품에 비하여 백업에 필요한 저장영역을 획기적으로 줄여 생산비용을 크게 줄일 수 있다. 예를 들면 노트북이나 태블릿 컴퓨터의 경우는 휴대의 편의성 때문에 무게를 줄이기 위하여 가격이 비싸더라도 보조기억장치로 SSD(Solid State Drive)를 주로 쓰고 있고 대용량서버들은 매우 큰 용량의 보조기억장치들을 사용하고 있는데, 본 발명에 따른 기술이 적용된다면 큰 비용을 들이지 않고도 악성소프트웨어에 의한 데이터의 훼손을 복구할 수있는 보조기억장치를 장착할 수 있어 상업적, 사회적으로도 의미가 있다.
좀 더 구체적으로, 본 발명에 따른 보조기억장치는 복구정보의 저장공간을 매우 효율적으로 관리할 수 있어 제작 비용을 크게 줄일 수 있으며 사용자에게는 자신이 원하는 파일이나 디렉토리만들 백업할 수 있는 수단 제공이 가능한 장점이 있다. 더구나 시간이 많이 걸리는 작업은 백그라운드작업으로 처리하게 되면 처리속도의 하락도 막을 수 있어 보다 효율적일 것으로 판단된다.
도 1은 본 발명의 한 실시예에 따른 보조기억장치(20)의 개략도
도 2는 도 1의 보조기억장치(20)의 제어장치(60)의 구성도
도 3은 도 2에 나타낸 제어장치(60)의 복구정보관리모듈(620)의 일 실시예 구성도
도 4는 도 2에 나타낸 제어장치(60)의 복구정보관리모듈(620)의 다른 실시예에 따른 복구정보관리모듈(620')의 구성도
도 5는 도 2에 나타낸 제어장치(60)의 복구정보삭제모듈(630)의 구성도
도 6은 본 발명의 다른 실시예에 따른 보조기억장치(20)의 개략도
도 7은 도 6의 보조기억장치(20)의 제어장치(60)의 구성도
도 8은 도 7의 복구정보정비모듈(650)의 구성도
도 9는 다른 실시예에 따른 복구정보정비모듈(650')의 구성도
도 10은 복구정보정비모듈(650, 650')에 추가로 포함되는 구성요소들
본 발명의 이점 및 특징, 그리고 그것들을 달성하는 방법은 첨부되는 도면과 함께 상세하게 기술되어 있는 실시예를 참조하면 명확해질 것이다. 그러나 본 발명은 이하에서 개시되는 실시예에 한정되는 것이 아니라 서로 다른 다양한 형태로 구현될 수 있는 것이며, 단지 본 실시예는 본 발명의 개시가 완전하도록 하여 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 발명의 범주를 완전하게 알려주기 위해 제공되는 것이다. 본 발명의 기술적 범위는 청구항의 기재에 의해 정의된다.
한편, 본 명세서에서 사용된 용어는 실시예를 설명하기 위한 것이며 본 발명을 제한하고자 하는 것이 아니다. 본 명세서에서, 단수형은 문구에서 특별히 언급하지 않는 한 복수형도 포함한다. 명세서에서 사용되는 "포함한다(comprises)" 또는 "포함하는(comprising)"은 언급된 구성요소, 단계, 동작 및/또는 소자 이외의 하나 이상의 다른 구성요소, 단계, 동작 및/또는 소자의 존재 또는 추가를 배제하지 않는다.
이하, 본 발명의 바람직한 실시예를 첨부 도면을 참조하여 상세히 설명한다. 각 도면의 구성요소들에 참조부호를 부가함에 있어서, 동일한 구성요소들에 대해서는 비록 다른 도면상에 표시되더라도 가급적 동일한 부호를 부여하고 또한 본 발명을 설명함에 있어, 관련된 공지 구성 또는 기능에 대한 구체적인 설명이 본 발명의 요지를 흐릴 수 있는 경우에는 그 상세한 설명을 생략한다.
도 1은 본 발명의 한 실시예에 따른 보조기억장치(20)의 개략도이다. 기본적으로 호스트컴퓨터(10)가 보조기억장치(20)에 액세스(접근)하는 구성이다.
보조기억장치(20)에 원본 보조기억장치(30)와 백업 보조기억장치(40)가 포함되어 있고, 또한, 원본 보조기억장치(30) 및 백업 보조기억장치(40) 이외에 사용자입력장치(50)가 있다. 이들 원본 보조기억장치(30), 백업 보조기억장치(40), 사용자입력장치(50)는 제어장치(60)에 의해 제어된다.
백업 보조기억장치(40)는 원본 보조기억장치(30)의 복구정보를 저장한다.
사용자입력장치(50)는 사용자의 명령들을 입력받는 장치로써 예를 들면 정상모드와 백업모드를 전환하기 위한 사용자 입력이나, 제어장치에 복구정보정비를 위한 명령을 입력하는 용도 등으로 사용된다. 사용자입력장치(50)는 모드 선택 스위치와 같이 전기적인 스위치로 구성되는 것도 가능하고, 통신모듈로 구성하여 유무선으로 전달받은 정보를 바탕으로 사용자입력을 확인하는 방식으로도 구현할 수도 있다. 이때의 통신프로토콜은 암호화된 방식으로 진행하여 안전을 강화하는 것이 보다 바람직하다.
제어장치(60)는 보조기억장치(20)를 제어하는 CPU의 기능 연산을 담당하는 소프트웨어와 관련하드웨어로 구현되는 것이 보통이나 고속처리를 위하여 원본보조기억장치의 액세스통로를 관리하는 부분은 FPGA(Field Programmable Gate Array)를 이용한 하드웨어로 구현하는 것도 좋은 방법이다. 사용자입력장치(50)에 의해 사용자가 선택하는 모드가 정상모드일 때에 제어장치(60는 호스트컴퓨터(10)가 원본 보조기억장치(30)의 OS를 이용하여 부팅되고 백업 보조기억장치(40)에는 접근이 불가능하도록 보조기억장치(20)를 제어한다. 그리고, 사용자입력장치(50)에 의해 사용자가 백업모드를 선택할 때 제어장치(60)는 호스트컴퓨터(10)가 백업 보조기억장치(40)에 보관된 OS의 사본 또는 보조기억장치(20)가 별도로 제공하는 OS로 부팅되도록 보조기억장치(20)를 제어하고, 백업 보조기억장치(40)가 기록한 복구정보를 기반으로 원본 보조기억장치(30)의 복구와 관련된 작업 등을 수행한다.
이러한 구성은 기존에 시판중인 보조기억장치와는 근본적으로 구성이 다르고 기능도 다르다. 그러나 상기 구성을 지니는 보조기억장치(20)는 호스트컴퓨터(10)가 악성프로그램의 침입으로 원본 보조기억장치(30)를 파괴하더라도 물리적으로 완전하게 차단된 백업 보조기억장치(40)가 보관중인 백업 정보로 상시 복구가 가능한 장점이 있다. 본 발명은 그 장점에 더하여 백업정보를 선택적으로 관리하여 백업정보의 양을 효율적으로 줄일 수 있는 구성을 제시하고 있다.
도 1의 원본 보조기억장치(30)와 백업 보조기억장치(40)는 일반적인 상용 HDD나 SSD를 사용할 수 있으며 비휘발성메모리로 직접구현하는 것도 가능하다. 제어장치(60)는 도 2, 도 6과 같이 구성된다.
도 2는 도 1의 보조기억장치(20)의 제어장치(60)의 구성도이다.
사용자입력장치(50)로부터 명령을 입력받는 사용자명령입력모듈(610)과, 백업 보조기억장치(40)의 복구정보를 관리하는 복구정보관리모듈(620), 그리고 저장된 복구정보를 삭제하는 복구정보삭제모듈(630)이 포함된다. 이들 모듈들은 제어장치(60) 내에 소프트웨어로 구현되는 것이 용이하나 일부는 하드웨어로 구현하면 처리속도를 높일 수 있어 보다 바람직하다.
도 3은 도 2에 나타낸 제어장치(60) 내의 복구정보관리모듈(620)의 한 실시예 구성도이다.
도 3의 실시예에 따른 복구정보관리모듈(620)은 원본 보조기억장치(30)를 액세스하기 위하여 호스트컴퓨터(10)가 제공한 액세스정보를 분석하는 액세스정보분석부(622); 상기 액세스정보에 포함된 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부(624); 확인된 파일시스템객체가 사용자가 지정한 복구필요객체인 경우, 상기 액세스어드레스의 저장공간에 대한 복구정보를 만들어 기록하는 복구정보기록부(626)로 구성된다. 이들 각 부는 소프트웨어 모듈로 만들어 제어장치(60)에서 수행시키는 것이 용이하나 플래쉬메모리와 같은 NVM(Non Volatile Memory)의 수명관리방법처럼 하드웨어로 구현하면 고속처리가 가능하다.
이때 액세스정보는 데이터 저장을 위한 액세스인 경우 액세스시각, CHS나 LBA방식 등으로 표시된 액세스어드레스, 쓰기와 읽기 등 호스트의 작업명령종류, 쓰기작업인 경우 쓰기데이타 등으로 구성될 수 있다. 이들 정보는 호스트컴퓨터(10)와 보조기억장치가 통신을 위해 사용하는 프로토콜에 따라 순차적으로 전달되거나 블록데이타형태로 한번에 전달될 수 있다. 또한, 복구정보는 상기 액세스 정보에 포함된 액세스시각, 액세스어드레스, 작업명령종류와 액세스어드레스가 지정한 저장공간에 기저장되어 있는 데이터를 포함하여 구성될 수 있다.
예를 들어 NTFS파일 시스템을 가지는 호스트컴퓨터에서 보조기억장치로 기존정보 DATA_OLD가 저장되어있는 섹터A에 새로운 데이터 DATA_NEW를 쓰는 명령을 내렸다고 가정해 보자. 백업기능이 없는 기존 상용 보조기억장치는 섹터A의 기존 정보를 옮기거나 관리하는 단계없이 바로 섹터A에 DATA_NEW를 쓰게 된다. 이로써 DATA_OLD는 사라졌고 복구는 불가능할 것이다. 그러나 백업기능을 보유한 본 발명의 보조기억장치들은 섹터A가 복구필요객체의 사용공간인 경우 섹터A에 대한 복구정보를 만들어 백업 보조기억장치(40)에 선택적으로 저장하게 된다.
한편 섹터A에 대한 복구정보는 아래와 같이 만들어 백업 보조기억장치(40)에 저장할 수 있다. 이 복구정보는 정상모드에서는 호스트컴퓨터(10)에서 액세스가 불가능하므로 악성소프트웨어가 이를 지울 수 없다.
<복구정보의 구성예 1>
- 액세스시간: 2018-12-31 17:00:00
- 물리적주소: 섹터A
- 보관데이타: DATA_OLD
여기서 보관데이타는 보관방식에 따라 DATA_NEW가 될 수도 있으나 본 실시예에서는 기존 섹터A에 저장되어있는 기존정보를 보관하는 것으로 가정하자. 이런방식으로 복구정보를 만들어 백업 보조기억장치(40)에 기록하고 이제 원본 보조기억장치(30)의 섹터A에 DATA_NEW를 쓰게 된다. 따라서 DATA_OLD는 보존되어 있으므로 나중에 복구가 가능하다.
한편, 본 발명에 따른 보조기억장치에서는 이러한 복구정보 구성작업을 복구정보관리모듈(620)이 담당한다. 복구정보관리모듈(620)은 액세스정보분석부(622)에서 상기 액세스가 엑세스어드레스 섹터A에 대한 것임을 분석하고, 상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 파일시스템객체확인부(624)에 의해 확인하여 섹터A를 사용하는 파일시스템 객체를 찾아낸다.
참고로 파일시스템 객체는 기본적으로 파일시스템을 구성하는 요소나 요소들의 결합을 의미한다. 따라서 파일시스템 객체에는 섹터, 클러스터, 파일경로, 파일이름, 디렉토리, 파티션, 드라이브 그 자체일 수 있고 이들이 모여 구성될 수도 있다. 따라서 파일 시스템 자체를 구성하는 요소, 즉 NTFS의 경우의 MBR(Master Boot Record), PBR(Partition Boot Record), MFT(Master File Table), 그리고 FAT(File Allocation Table) 파일시스템의 경우의 FAT 등도 파일시스템 객체가 될 수 있다. 따라서 파일시스템 객체는 CHS나 LBA로 지정되는 섹터, 클러스터와 같은 저장공간일 수도 있고 c:/users/documents/korea.doc와 같이 특정파일을 의미할 수도 있고, /temporary와 같이 임시사용을 의미하는 디렉토리의 파일들과 디렉토리 전체를 의미할 수도 있으며, 드라이브 D:와 같은 파티션이나 드라이브일 수도 있고 MBR같은 클러스터일 수도 있다.
따라서 섹터A라는 정보를 가지고 파일시스템객체를 확인하는 작업은 역추적하는 형태라 시간이 많이 걸린다. 그러나 사전에 NTFS의 섹터/클러스터 할당정보를 검색테이블로 만들어 둔다면 시간을 크게 단축할 수 있다. 또한 이 작업을 실시간으로 수행하는 것은 생략하고 일반 복구정보를 만들어 무조건 기록한 후에, 복구정보삭제모듈을 백그라운드 작업으로 수행시키는 방식으로 처리시간을 줄이는 것도 가능할 것이다. 이는 아래에서 상세하게 기술하기로 한다. 만일 파일시스템객체정보를 포함하는 경우에는 아래와 같이 복구정보를 구성하는 것이 가능하다.
<복구정보의 구성예 2>
- 액세스시간: 2018-12-31 17:00:00
- 물리적주소: 섹터A, 파일시스템정보: c:/User/Korea.doc
- 영역정보: 22334455......(512bytes)
이후 복구정보관리모듈(620)은 확인된 파일시스템객체가 사용자가 지정한 복구필요객체인 경우, 상기 복구정보 구성예들과 같이 섹터A의 복구정보를 만들어 백업 보조기억장치(40)에 복구정보를 기록하는 단계를 수행하게 된다.
즉 본 발명에 따른 보조기억장치들은 복구에 필요하다고 지정된 복구필요객체의 복구정보만 만들어 저장하므로 백업 보조기억장치(40)의 저장공간을 크게 줄일 수 있는 장점이 있다. (이에 비하여 선출원 발명에 따른 보조기억장치들은 이 정보들을 만들지도 관리하지도 않는다.)
복구필요객체와 복구불필요객체의 지정은 사용자에게 초기화프로그램같은 수단을 제공함으로써 가능하다. 예를 들어 사용자는 간단하게 부트파티션(드라이브) C:는 복구불필요객체로, 사용자파티션(드라이브) D:는 복구필요객체로 지정하여 관리할 수 있다. 이러한 경우 시스템프로그램과 OS가 부트파티션에 담겨있으므로 보조기억장치는 사용자파일만 복구정보를 만들어 기록하게 된다.
보다 자세히 살펴보면 본 발명의 장점이 명확하게 드러난다. 예를 들어 Windows OS의 경우 PAGEFILE.SYS라는 시스템파일은 일종의 디스크 캐쉬로 사용되는 파일로, OS가 임시로 정보를 저장하기 위하여 수시로 액세스를 하게 된다. 또한 어플리케이션 프로그램들은 C:/Windows/Temp 디렉토리에 로그정보들을 포함한 많은 데이터들을 파일로 만들어 수시로 액세스하게 된다. 또한 Windows OS가 자체적인 복구기능을 위하여 /System Volume Information이라는 디렉토리에 시스템의 형상이 변경될 때마다 복구정보를 만들어 저장하기도한다.
그런데 이처럼 OS의 실행중에 임시로 만들어지거나 삭제되는 파일들은 백업이 필요없다. 위의 예에서 섹터A를 사용하는 파일시스템 객체가 만일 PAGAFILE.SYS와 /temp의 파일들이라면 백업이 필요없다. 또한 /System Volume Information의 정보도 과거정보는 아무 의미가 없는 정보로, 복구할 필요가 전혀 없다.
본 발명에서는 상기와 같이 복구정보를 관리할 필요가 없는 섹터, 클러스터, 파일, 디렉토리 또는 파티션, 드라이브들을 사용자가 복구불필요객체로 지정하여 관리가 가능하다. 즉 섹터A 자체가 복구불필요객체에 속하거나 섹터A가 복구불필요객체 파일이나 디렉토리 등에 속한다면, 호스트컴퓨터(10)로부터 섹터A에 대한 쓰기 명령을 받았을 때 파일시스템객체확인부(624)를 통해서 복구가 불필요한 객체인지를 바로 확인하여 복구정보를 만드는 절차를 생략할 수 있다. 또한 일단 복구정보를 만들어 기록한 후 백그라운드 프로그램에서 복구불필요 대상인지를 확인하여 해당정보를 삭제하는 방법으로도 구현이 가능하므로 백업 보조기억장치(40)의 효율적인 관리가 가능하다.
도 4는 도 2에 나타낸 제어장치(60) 내의 복구정보관리모듈(620)의 다른 실시예에 따른 복구정보관리모듈(620')의 구성도이다. 이 실시예는 앞에서 언급한 것과 같이 사전에 NTFS의 섹터/클러스터 할당정보를 섹터/클러스터정보를 알면 쉽게 파일이름과 경로를 확인할 수 있는 방식으로 검색테이블로 만들어 시간을 단축하기 위한 것이다.
이 실시예에 따른 복구정보관리모듈(620')은 호스트컴퓨터(10)의 파일시스템을 분석하여 파일이나 디렉토리 등에 할당된 섹터나 클러스터정보를 표로 만드는 검색테이블작성부(621); 원본 보조기억장치를 액세스하기 위하여 호스트컴퓨터(10)가 제공한 액세스정보를 분석하는 액세스정보분석부(623); 상기 액세스정보에 포함된 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 상기 검색 검색테이블과 비교하여 확인하는 파일시스템객체확인부(625); 확인된 파일시스템객체가 사용자가 지정한 복구필요객체인 경우, 상기 액세스어드레스의 저장공간에 대한 복구정보를 만들어 기록하는 복구정보기록부(627)로 구성된다. 여기서, 사실상 검색테이블작성부(621)는 기작성된 검색테이블을 사용하기만 해도 되는 경우도 있으므로 작성의 기능은 없을 수도 있으나, 검색테이블은 항시 파일시스템의 현재 상태를 나타내고 있어야하므로 미반영된 파일시스템의 변경내용을 반영하는 기능을 담당할 수도 있다.
여기서 복구정보관리모듈(620')은 소프트웨어로 구현되어 제어장치에서 수행되는 것이 용이하나 플래쉬메모리와 같은 NVM(Non Volatile Memory)의 관리방법처럼 하드웨어로 구현하면 고속처리가 가능하다.
본 실시예의 검색테이블작성부(621)는 윈도즈의 NTFS와 같은 파일시스템에서는 필요하다. NTFS는 기본적으로 파일과 디렉토리들의 다양한 속성 및 이들의 데이타위치를 표시하는 MFT(Master File Table)을 사용한다. 그런데 MFT는 엔트리개념으로 정보들을 표시하고 있어 FAT(File Allocation Table)에 비해서 파일이나 디렉토리의 위치를 직관적으로 확인하는 것이 어렵다.
따라서 파일시스템객체확인부(625)에서 소요되는 시간을 줄이기 위하여 NTFS의 MFT(Master File Table)를 분석하여 섹터나 클러스터의 점유상황을 섹터/클러스터정보를 알면 쉽게 파일이름과 경로를 확인할 수 있는 방식이나 FAT(File Allocation Table) 형식의 검색테이블을 만들어 두는 것이 바람직하다. 이때 MFT가 클러스터나 섹터의 점유현황을 일종의 연결된 데이타형식으로 관리하는 데 비하여 검색테이블은 클러스터나 섹터의 점유현황을 간단한 테이블로 관리하므로 검색테이블이 없는 경우보다 빠른 객체확인이 가능하다.
그런데 이와 같이 파일이나 디렉토리가 점유한 디스크의 실제영역을 찾아 검색테이블로 만드는 작업도 매번 하기에는 시간이 많이 소요된다. 따라서 부트시나 시스템초기화 등의 경우에 전체 저장영역을 스캔하여 한번에 만들어 이를 관리하는 것이 바람직하다. 또한 검색테이블은 파일이나 디렉토리 등이 새로 생성되거나 삭제될 때마다 변경하여 관리할 수 있다. 이와 같은 방법은 MAC의 HFS와 같은 파일시스템에서도 판단시간을 줄이는 데 필요하다.
도 5는 도 2에 나타낸 제어장치(60) 내의 복구정보삭제모듈(630)의 구성도이다. 복구정보삭제모듈(630)은, 백업 보조기억장치(40)에 기저장된 복구정보의 액세스어드레스를 추출하는 복구정보분석부(632); 상기 복구정보에 포함된 액세스어드레스를 사용하는 파일시스템 객체를 확인하는 파일시스템객체확인부(634); 확인된 파일시스템객체가 사용자가 지정한 복구불필요객체인 경우에 기저장된 복구정보를 삭제하는 복구정보삭제부(636)로 구성된다. 이때 파일시스템객체확인부(634)는 객체확인작업시 검색테이블을 사용할수도 있다.
선출원 발명들의 보조기억장치들은 기본적으로 호스트컴퓨터(10)의 쓰기작업명령이 담긴 모든 액세스에 대하여 복구정보를 만들어 저장하게 되는데 저장 후에 본 발명에 따른 객체확인작업을 거쳐 저장된 복구정보를 선별적으로 삭제하는 방법으로 본 발명의 기술을 적용할 수 있다. 이때 복구정보삭제모듈(630)은 백그라운드 작업으로 실행되는 것이 바람직하다. 예를 들어 백그라운드 작업으로 복구정보삭제모듈(630)을 수행시킨다고 가정하여 보자. 복구정보삭제모듈(630)은 복구정보를 차례대로 확인하여 액세스어드레스를 추출하고 이를 검색테이블과 비교하여 복구불필요객체인지를 확인한다음 만일 복구불필요객체라면 이를 삭제함으로써 백업 보조기억장치(40)의 저장공간 낭비를 막을 수 있다.
도 6은 본 발명의 다른 실시예에 따른 보조기억장치(20)의 개략도이다. 도 1의 보조기억장치(20)에 추가로 표시장치(70)가 구비된 실시예를 나타낸다.
여기서, 표시장치(70)는 LED나 디스플레이, 알람장치 등으로 구성되는 것이 일반적이나, 사용자입력장치(50)와 유사한 방식으로 통신모듈로 구성하여 유무선으로 전달받은 정보를 바탕으로 사용자입력을 확인하는 방식으로 구현할 수도 있다. 또한 사용자입력장치(50)와 표시장치(70)를 하나의 입출력장치로 통합하여 구성하는 것도 가능할 것이다.
도 7은 도 6의 보조기억장치(20)의 제어장치(60)의 구성도이다. 사용자명령입력모듈(610)과, 표시장치(70)를 구동하는 표시장치구동모듈(640)과, 입력된 사용자명령에 따라 복구정보를 삭제하거나 압축하는 복구정보정비모듈(650)을 포함한다. 복구정보정비모듈(650)에 대해서 이하 설명한다.
도 8은 도 7의 복구정보정비모듈(650)의 한 실시예의 구성도이다. 이 복구정보정비모듈1(650)은 백업 보조기억장치(40)에 기저장된 복구정보를 분석하여 액세스어드레스를 추출하는 복구정보분석부(652); 상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부(654); 확인된 파일시스템객체가 사용자명령에서 삭제대상으로 지정된 파일시스템 객체인지를 판단하여 일치하는 경우, 상기 복구정보를 삭제하는 복구정보삭제부(656)로 구성된다. 이때 파일시스템객체확인부(654)는 객체확인작업시 검색테이블을 사용할수도 있다.
도 9는 도 7의 복구정보정비모듈(650)의 다른 실시예의 구성도이다. 이 복구정보정비모듈2(650')는, 백업 보조기억장치(30)에 기저장된 복구정보를 분석하여 액세스어드레스를 추출하는 복구정보분석부(651); 상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부(653); 확인된 파일시스템객체가 사용자명령에서 압축대상으로 지정된 파일시스템 객체인지를 판단하여 일치하는 경우, 상기 복구정보를 압축하는 복구정보압축부(655)로 구성된다. 이때 파일시스템객체확인부(653)는 객체확인작업시 검색테이블을 사용할수도 있다.
도 10은 도 8과 9의 복구정보정비모듈1 또는 2(650, 650')에 추가로 포함될 수 있는 요소들을 나타낸다. 복구정보정비모듈1 또는 2(650, 650')(650')의 구성요소에 추가적으로, 사용자명령을 분석하는 사용자명령분석부(657); 분석된 사용자명령이 지정하는 기 저장된 알고리즘에 따라 백업보조기억장치에 기저장된 복구정보를 삭제하거나 압축하는 정비알고리즘실행부(658)가 더 포함될 수 있다. 또한 이와 같이 복구정보정비모듈1 또는 2(650, 650')가 구성되는 경우에는 선택적으로, 상기와 같은 작업들을 수행하는 과정에서 발생하는 정보제공이나 사용자의 추가입력 등을 위하여 도 6의 표시장치(70)에 정보를 표시하는 정보표시부(659)가 더 추가적으로 포함될 수 있다.
한편 상술한 복구정보관리모듈(620, 620')과 복구정보삭제모듈(630), 그리고 복구정보정비모듈(650, 650'), 그리고 정비알고리즘실행부(658)는 별도의 하드웨어나 단일칩으로 제작이 가능하다. 또한 이들 각 모듈들의 일부 기능 예를 들어 검색테이블을 통해 파일시스템객체를 확인하는 기능(625)만 따로 떼어내어 하드웨어나 단일칩으로 제작이 가능하다. 복구정보통합관리칩은 독자적인 메모리와 CPU 인터페이스회로와 고속연산회로 등을 가지고 복구정보관리기능이나 복구정보삭제기능, 복구정보정비기능 또는 정비알고리즘실행 기능등이 구현된 프로그램코드를 수행하는 형태로 구현할 수 있다. 특히 정보를 압축하거나 푸는 작업은 하드웨어로 처리할 경우 고속처리가 가능해서 큰 장점이 있다.
다른 한편으로는 검색테이블을 통해 파일시스템객체를 확인하는 기능(625)만을 따로 떼어내어 FPGA(Field Programmable Gate Arrary)와 연산코어로 검색전용칩을 구현하는 것이 가능하다. 이때의 검색전용칩은 CPU 인터페이스회로와 독자적으로 공유메모리나 전용메모리를 또는 CPU의 메모리를 액세스할 수 있는 메모리인터페이스회로와 검색엔진이 탑재된 연산코어로 구성되어 검색테이블을 이용하여 섹터나 클러스터정보를 이용하여 파일시스템객체를 확인하는 작업을 수행할 수 있다.
한편, 본 발명은 이상 설명한 본 발명의 보조기억장치의 복구정보 관리 장치 및/또는 복구정보 관리 방법이 적용된 컴퓨터(PC), 서버 컴퓨터, 모바일폰, 자동제어장치 등의 응용기기가 제공된다.
이상에서, 본 발명의 바람직한 실시예를 통하여 본 발명의 구성을 상세히 설명하였으나, 본 발명이 속하는 기술분야의 통상의 지식을 가진 자는 본 발명이 그 기술적 사상이나 필수적인 특징을 변경하지 않고서 본 명세서에 개시된 내용과는 다른 구체적인 형태로 실시될 수 있다는 것을 이해할 수 있을 것이다. 이상에서 기술한 실시예들은 모든 면에서 예시적인 것이며 한정적이 아닌 것으로 이해해야만 한다. 본 발명의 보호범위는 상기 상세한 설명보다는 후술한 특허청구범위에 의하여 정해지며, 특허청구의 범위 그리고 그 균등 개념으로부터 도출되는 모든 변경 또는 변형된 형태는 본 발명의 기술적 범위에 포함되는 것으로 해석되어야 한다.

Claims (26)

  1. 호스트컴퓨터가 액세스하는 보조기억장치로,
    원본 보조기억장치;
    원본 보조기억장치의 복구정보를 저장하는 백업 보조기억장치;
    정상모드와 백업모드를 전환하기 위한 사용자 입력을 받는 사용자입력장치; 그리고
    상기 원본 보조기억장치, 백업 보조기억장치, 및 사용자입력장치와 연결되어, 정상모드일 때 호스트컴퓨터가 원본 보조기억장치의 OS를 이용하여 부팅되고 백업 보조기억장치에는 접근이 불가능하도록 보조기억장치를 제어하고, 백업모드일 때는 호스트컴퓨터가 백업 보조기억장치에 보관된 OS의 사본 또는 보조기억장치가 별도로 제공하는 OS로 부팅되도록 보조기억장치를 제어하고, 백업 보조기억장치가 기록한 복구정보를 기반으로 원본 보조기억장치의 복구를 수행하는 제어장치를 포함하되,
    상기 제어장치는
    원본 보조기억장치를 액세스하기 위하여 호스트컴퓨터가 제공한 액세스정보를 분석하는 액세스정보분석부; 상기 액세스정보에 포함된 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부; 및 확인된 파일시스템객체가 사용자가 지정한 복구필요객체인 경우, 상기 액세스어드레스의 저장공간에 대한 복구정보를 만들어 기록하는 복구정보기록부가 포함된 복구정보관리모듈과,
    백업 보조기억장치에 기저장된 복구정보의 액세스어드레스를 추출하는 복구정보분석부; 상기 복구정보에 포함된 액세스어드레스를 분석하여 해당 액세스어드레스를 사용하는 파일시스템 객체를 확인하는 파일시스템객체확인부; 및 확인된 파일시스템객체가 사용자가 지정한 복구불필요객체인 경우에 기저장된 복구정보를 삭제하는 복구정보삭제부가 포함된 복구정보삭제모듈을 포함하는, 보조기억장치의 복구정보 관리 장치.
  2. 삭제
  3. 삭제
  4. 제1항에서, 상기 복구정보관리모듈의 파일시스템객체확인부는
    상기 액세스정보에 포함된 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하기 위하여, 호스트컴퓨터의 파일시스템을 분석하여 파일이나 디렉토리에 할당된 섹터나 클러스터정보가 표로써 작성된 검색테이블과 비교하도록 구성되는, 보조기억장치의 복구정보 관리 장치.
  5. 제1항에서, 상기 파일시스템객체확인부는 검색전용칩으로 구성되는 것을 특징으로 하는, 보조기억장치의 복구정보 관리 장치.
  6. 삭제
  7. 삭제
  8. 제1항에서, 상기 제어장치의 제어동작의 결과를 표시하는 표시장치를 추가로 포함하고,
    상기 제어장치는
    사용자입력장치로부터 사용자명령을 입력받는 사용자명령입력모듈;
    상기 표시장치를 구동하는 표시장치구동모듈;
    입력된 사용자명령에 따라 복구정보를 삭제하거나 압축하는 복구정보정비모듈을 포함하는, 보조기억장치의 복구정보 관리 장치.
  9. 제8항에서, 상기 복구정보정비모듈은
    상기 백업 보조기억장치에 기저장된 복구정보를 분석하여 액세스어드레스를 추출하는 복구정보분석부;
    상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부;
    확인된 파일시스템객체가 사용자명령에서 삭제대상으로 지정된 파일시스템 객체인지를 판단하여 일치하는 경우, 상기 복구정보를 삭제하는 복구정보삭제부를 포함하는 보조기억장치의 복구정보 관리 장치.
  10. 제9항에서, 상기 복구정보정비모듈은
    상기 백업 보조기억장치에 기저장된 복구정보를 분석하여 액세스어드레스를 추출하는 복구정보분석부;
    상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인부;
    확인된 파일시스템객체가 사용자명령에서 압축대상으로 지정된 파일시스템 객체인지를 판단하여 일치하는 경우, 상기 복구정보를 압축하는 복구정보압축부를 포함하는 보조기억장치의 복구정보 관리 장치.
  11. 제9항 또는 제10항에서, 상기 복구정보정비모듈은
    사용자명령을 분석하는 사용자명령분석부;
    분석된 사용자명령이 지정하는 기 저장된 알고리즘에 따라 백업보조기억장치에 기저장된 복구정보를 삭제하거나 압축하거나 전송하는 등의 기능을 수행하는 정비알고리즘실행부를 추가로 포함하는, 보조기억장치의 복구정보 관리 장치.
  12. 제11항에서, 상기 표시장치는 작업들을 수행하는 과정에서 발생하는 정보제공 또는 사용자의 입력을 위한 정보표시부를 포함하는, 보조기억장치의 복구정보 관리 장치.
  13. 제8항에서, 상기 표시장치는 상기 사용자입력장치와 하나의 입출력장치로 통합하여 구성되는 것을 특징으로 하는 보조기억장치의 복구정보 관리 장치.
  14. 제1항, 제4항, 제5항, 및 제8항 내지 제10항 중 어느 한 항의 보조기억장치의 복구정보 관리 장치를 적용한 기기.
  15. 원본 보조기억장치; 원본 보조기억장치의 복구정보를 저장하는 백업 보조기억장치; 정상모드와 백업모드를 전환하기 위한 사용자 입력을 받는 사용자입력장치를 포함하여 호스트컴퓨터가 액세스하는 보조기억장치에서 수행되는 복구정보 관리 방법으로서,
    상기 사용자입력장치에 의해 정상모드가 선택될 때 호스트컴퓨터가 원본 보조기억장치의 OS를 이용하여 부팅되고 백업 보조기억장치에는 접근이 불가능하도록 하는 절차; 그리고
    상기 사용자입력장치에 의해 백업모드가 선택될 때 호스트컴퓨터가 백업 보조기억장치에 보관된 OS의 사본 또는 보조기억장치가 별도로 제공하는 OS로 부팅되도록 하고, 백업 보조기억장치가 기록한 복구정보를 기반으로 원본 보조기억장치의 복구를 수행하는 복구정보관리절차; 및
    기저장된 원본보조기억장치의 복구정보를 삭제하는 복구정보삭제절차를 포함하되,
    상기 복구정보관리 절차는
    원본 보조기억장치를 액세스하기 위하여 호스트컴퓨터가 제공한 액세스정보를 분석하는 액세스정보분석 단계; 상기 액세스정보에 포함된 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인 단계; 및 확인된 파일시스템객체가 사용자가 지정한 복구필요객체인 경우, 상기 액세스어드레스의 저장공간에 대한 복구정보를 만들어 기록하는 복구정보기록 단계를 포함하고;
    상기 복구정보 삭제절차는
    백업 보조기억장치에 기저장된 복구정보의 액세스어드레스를 추출하는 복구정보분석 단계; 상기 복구정보에 포함된 액세스어드레스를 검색테이블과 비교하여 해당 액세스어드레스를 사용하는 파일시스템 객체를 확인하는 파일시스템객체확인 단계; 및 확인된 파일시스템객체가 사용자가 지정한 복구불필요객체인 경우에 기저장된 복구정보를 삭제하는 복구정보삭제 단계를 포함하는 보조기억장치의 복구정보 관리 방법.
  16. 삭제
  17. 삭제
  18. 제15항에서, 상기 복구정보관리절차의 파일시스템객체확인 단계는
    상기 액세스정보에 포함된 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하기 위하여, 호스트컴퓨터의 파일시스템을 분석하여 파일이나 디렉토리에 할당된 섹터나 클러스터정보가 표로써 작성된 검색테이블과 비교하는, 보조기억장치의 복구정보 관리 방법.
  19. 삭제
  20. 삭제
  21. 제15항에서, 상기 보조기억장치는 표시장치를 추가로 포함하고,
    상기 보조기억장치의 복구정보 관리 방법은
    사용자입력장치로부터 사용자명령을 입력받는 사용자명령입력절차;
    상기 표시장치를 구동하는 표시장치구동절차;
    입력된 사용자명령에 따라 복구정보를 삭제하거나 압축하는 복구정보정비절차를 포함하는, 보조기억장치의 복구정보 관리 방법.
  22. 제21항에서, 상기 복구정보정비절차는
    상기 백업 보조기억장치에 기저장된 복구정보를 분석하여 액세스어드레스를 추출하는 복구정보분석 단계;
    상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인 단계;
    확인된 파일시스템객체가 사용자명령에서 삭제대상으로 지정된 파일시스템 객체인지를 판단하여 일치하는 경우, 상기 복구정보를 삭제하는 복구정보삭제 단계를 포함하는 보조기억장치의 복구정보 관리 방법.
  23. 제22항에서, 상기 복구정보정비절차는
    상기 백업 보조기억장치에 기저장된 복구정보를 분석하여 액세스어드레스를 추출하는 복구정보분석 단계;
    상기 액세스어드레스의 저장공간을 사용중인 파일시스템 객체를 확인하는 파일시스템객체확인 단계;
    확인된 파일시스템객체가 사용자명령에서 압축대상으로 지정된 파일시스템 객체인지를 판단하여 일치하는 경우, 상기 복구정보를 압축하는 복구정보압축 단계를 포함하는 보조기억장치의 복구정보 관리 방법.
  24. 제22항 또는 제23항에서, 상기 복구정보정비절차는
    사용자명령을 분석하는 사용자명령분석 단계;
    분석된 사용자명령이 지정하는 기 저장된 알고리즘에 따라 백업보조기억장치에 기저장된 복구정보를 삭제하거나 압축하거나 전송하는 등의 기능을 수행하는 정비알고리즘실행 단계를 추가로 포함하는, 보조기억장치의 복구정보 관리 방법.
  25. 제21항에서, 상기 표시장치구동절차는
    상기 표시장치를 통해, 상기 절차들을 수행하는 과정에서 발생하는 정보제공 또는 사용자의 입력을 위한 정보를 표시하는 단계를 포함하는, 보조기억장치의 복구정보 관리 방법.
  26. 삭제
KR1020190051807A 2019-05-02 2019-05-02 보조기억장치의 복구정보 관리 장치 및 방법 KR102159835B1 (ko)

Priority Applications (6)

Application Number Priority Date Filing Date Title
KR1020190051807A KR102159835B1 (ko) 2019-05-02 2019-05-02 보조기억장치의 복구정보 관리 장치 및 방법
US17/608,259 US20220206904A1 (en) 2019-05-02 2020-04-21 Device and method for managing recovery information of auxiliary storage device
EP20798273.7A EP3964962A4 (en) 2019-05-02 2020-04-21 DEVICE AND METHOD FOR MANAGING RECOVERY INFORMATION OF AN AUXILIARY STORAGE DEVICE
JP2021564867A JP2022530169A (ja) 2019-05-02 2020-04-21 補助記憶装置の復旧情報管理装置および方法
PCT/KR2020/005254 WO2020222453A1 (ko) 2019-05-02 2020-04-21 보조기억장치의 복구정보 관리 장치 및 방법
CN202080040915.9A CN114174998A (zh) 2019-05-02 2020-04-21 辅助存储装置的修复信息管理装置及方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020190051807A KR102159835B1 (ko) 2019-05-02 2019-05-02 보조기억장치의 복구정보 관리 장치 및 방법

Publications (1)

Publication Number Publication Date
KR102159835B1 true KR102159835B1 (ko) 2020-09-24

Family

ID=72706433

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020190051807A KR102159835B1 (ko) 2019-05-02 2019-05-02 보조기억장치의 복구정보 관리 장치 및 방법

Country Status (6)

Country Link
US (1) US20220206904A1 (ko)
EP (1) EP3964962A4 (ko)
JP (1) JP2022530169A (ko)
KR (1) KR102159835B1 (ko)
CN (1) CN114174998A (ko)
WO (1) WO2020222453A1 (ko)

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2010072740A (ja) * 2008-09-16 2010-04-02 Hitachi Software Eng Co Ltd インターネットバックアップにおける転送データ管理システム
JP2017167811A (ja) * 2016-03-16 2017-09-21 日本電気株式会社 バックアップ制御装置、バックアップ制御方法及びプログラム
KR101920867B1 (ko) * 2017-07-05 2018-11-21 김덕우 독립된 백업 및 복구 기능을 제공하는 보조기억장치 및 이를 적용한 기기
KR101920866B1 (ko) * 2017-05-18 2018-11-21 김덕우 독립된 복원영역을 갖는 보조기억장치

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6647399B2 (en) * 1999-11-29 2003-11-11 International Business Machines Corporation Method, system, program, and data structures for naming full backup versions of files and related deltas of the full backup versions
US6826710B2 (en) * 2001-01-25 2004-11-30 Dell Products L.P. System and method for providing a fault-resilient boot
KR101115486B1 (ko) * 2003-08-08 2012-02-27 엘지전자 주식회사 컴퓨터 시스템의 부팅 제어 장치 및 방법
US20060069902A1 (en) * 2004-09-30 2006-03-30 Yu Rui Method for recovering operating system and user data executed in a computer and its recovery system thereof
US20060112303A1 (en) * 2004-11-09 2006-05-25 Arco Computer Products, Llc. Local backup device with remote management capability and method for remote backup management
US7921077B2 (en) * 2006-06-29 2011-04-05 Netapp, Inc. System and method for managing data deduplication of storage systems utilizing persistent consistency point images
US9507670B2 (en) * 2010-06-14 2016-11-29 Veeam Software Ag Selective processing of file system objects for image level backups
KR101807535B1 (ko) 2015-11-18 2017-12-11 한국항공우주연구원 스크램제트 엔진용 시험 장치

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2010072740A (ja) * 2008-09-16 2010-04-02 Hitachi Software Eng Co Ltd インターネットバックアップにおける転送データ管理システム
JP2017167811A (ja) * 2016-03-16 2017-09-21 日本電気株式会社 バックアップ制御装置、バックアップ制御方法及びプログラム
KR101920866B1 (ko) * 2017-05-18 2018-11-21 김덕우 독립된 복원영역을 갖는 보조기억장치
KR101920867B1 (ko) * 2017-07-05 2018-11-21 김덕우 독립된 백업 및 복구 기능을 제공하는 보조기억장치 및 이를 적용한 기기

Also Published As

Publication number Publication date
EP3964962A4 (en) 2022-06-22
WO2020222453A1 (ko) 2020-11-05
JP2022530169A (ja) 2022-06-27
US20220206904A1 (en) 2022-06-30
CN114174998A (zh) 2022-03-11
EP3964962A1 (en) 2022-03-09

Similar Documents

Publication Publication Date Title
US10430286B2 (en) Storage control device and storage system
US9880759B2 (en) Metadata for data storage array
US8214606B2 (en) Storage system and control method thereof
US9934108B2 (en) System and method for optimizing mirror creation
US8621165B1 (en) Method and apparatus for providing a volume image backup of selected objects
US20060155944A1 (en) System and method for data migration and shredding
US8725945B2 (en) Method and system for governing an enterprise level green storage system drive technique
US20030225993A1 (en) Computer system
US8380666B2 (en) File management device and storage device for managing mapping information between a first file system and a second file system
KR20080075707A (ko) 플래시 저장 장치로 삭제 정보를 전달할 수 있는 컴퓨팅시스템
US20110093437A1 (en) Method and system for generating a space-efficient snapshot or snapclone of logical disks
US20050246490A1 (en) Disk control system and control method of disk control system
CN103999058A (zh) 带驱动器系统服务器
US8539156B2 (en) Storage subsystem and its logical unit processing method
US8595426B2 (en) Handling commands within a write-once read-many storage device configuration
KR102277731B1 (ko) 스토리지 시스템의 구동 방법 및 스토리지 컨트롤러
KR102159835B1 (ko) 보조기억장치의 복구정보 관리 장치 및 방법
CN101893999A (zh) 一种将存储设备虚拟划分为多个设备的系统
US11249666B2 (en) Storage control apparatus
KR20100011137A (ko) 고속 파일 복구가 가능한 fat 파일시스템을 사용한데이터 처리장치 및 데이터 처리방법
US20210081126A1 (en) Method and apparatus for performing data-accessing management in a storage server
TW201443647A (zh) 具有資料管理的層疊式資料儲存系統及其操作方法
US20110296119A1 (en) Stored Data Reading Apparatus, Method and Computer Apparatus
TWI731515B (zh) 電腦系統及用於儲存裝置的開機控制方法
Nimmala Forensic Research on Solid State Drives using Trim Analysis

Legal Events

Date Code Title Description
GRNT Written decision to grant