USN(업데이트 시퀀스 번호) 변경 저널 버전 4.0 레코드에 대한 정보를 포함합니다. 버전 2.0 및 3.0 레코드는 각각 USN_RECORD_V2(USN_RECORD라고도 함) 및 USN_RECORD_V3 구조로 정의됩니다.
구문
typedef struct {
USN_RECORD_COMMON_HEADER Header;
FILE_ID_128 FileReferenceNumber;
FILE_ID_128 ParentFileReferenceNumber;
USN Usn;
DWORD Reason;
DWORD SourceInfo;
DWORD RemainingExtents;
WORD NumberOfExtents;
WORD ExtentSize;
USN_RECORD_EXTENT Extents[1];
} USN_RECORD_V4, *PUSN_RECORD_V4;
멤버
Header
레코드의 레코드 길이, 주 버전 및 부 버전을 설명하는 USN_RECORD_COMMON_HEADER 구조체입니다.
FileReferenceNumber
이 레코드 노트가 변경되는 파일 또는 디렉터리의 128비트 서수입니다.
이 값은 저널 레코드를 파일과 연결하는 임의로 할당된 값입니다.
ParentFileReferenceNumber
이 레코드와 연결된 파일 또는 디렉터리가 있는 디렉터리의 128비트 서수입니다.
이 값은 저널 레코드를 부모 디렉터리에 연결하는 임의로 할당된 값입니다.
Usn
이 레코드의 USN입니다.
Reason
파일 또는 디렉터리가 열린 이후 이 파일 또는 디렉터리 저널 레코드에 누적된 변경 이유를 식별하는 플래그입니다.
파일 또는 디렉터리가 닫히면 USN_REASON_CLOSE 플래그 집합을 사용하여 최종 USN 레코드가 생성됩니다. 다음 변경(예: 다음 열린 작업 또는 삭제 후)은 새 이유 플래그 집합을 사용하여 새 레코드를 시작합니다.
이름 바꾸기 또는 이동 작업은 항목에 대한 이전 부모 디렉터리를 기록하는 레코드와 새 부모를 기록하는 두 개의 USN 레코드를 생성합니다.
다음 표에서는 가능한 플래그를 식별합니다.
참고 사용하지 않는 비트는 예약되어 있습니다.
| 값 |
의미 |
-
USN_REASON_BASIC_INFO_CHANGE
- 0x00008000
|
사용자가 하나 이상의 파일 또는 디렉터리 특성(예: 읽기 전용, 숨겨진, 시스템, 보관 또는 스파스 특성) 또는 하나 이상의 타임스탬프를 변경했습니다.
|
-
USN_REASON_CLOSE
- 0x80000000
|
파일 또는 디렉터리가 닫혔습니다.
|
-
USN_REASON_COMPRESSION_CHANGE
- 0x00020000
|
파일 또는 디렉터리의 압축 상태가 또는 에서 압축됨으로 변경됩니다.
|
-
USN_REASON_DATA_EXTEND
- 0x00000002
|
파일 또는 디렉터리가 확장됩니다(에 추가됨).
|
-
USN_REASON_DATA_OVERWRITE
- 0x00000001
|
파일 또는 디렉터리의 데이터를 덮어씁니다.
|
-
USN_REASON_DATA_TRUNCATION
- 0x00000004
|
파일 또는 디렉터리가 잘립니다.
|
-
USN_REASON_EA_CHANGE
- 0x00000400
|
사용자가 파일 또는 디렉터리의 확장 특성을 변경했습니다.
이러한 NTFS 파일 시스템 특성은 Windows 기반 애플리케이션에서 액세스할 수 없습니다.
|
-
USN_REASON_ENCRYPTION_CHANGE
- 0x00040000
|
파일 또는 디렉터리가 암호화되거나 암호 해독됩니다.
|
-
USN_REASON_FILE_CREATE
- 0x00000100
|
파일 또는 디렉터리가 처음으로 만들어집니다.
|
-
USN_REASON_FILE_DELETE
- 0x00000200
|
파일 또는 디렉터리가 삭제됩니다.
|
-
USN_REASON_HARD_LINK_CHANGE
- 0x00010000
|
NTFS 파일 시스템 하드 링크가 파일 또는 디렉터리에 추가되거나 제거됩니다.
POSIX 하드 링크와 유사한 NTFS 파일 시스템 하드 링크는 동일한 파일 또는 디렉터리를 표시하는 여러 디렉터리 항목 중 하나입니다.
|
-
USN_REASON_INDEXABLE_CHANGE
- 0x00004000
|
사용자가 FILE_ATTRIBUTE_NOT_CONTENT_INDEXED 특성을 변경합니다.
즉, 사용자는 콘텐츠를 인덱싱할 수 없는 파일 또는 디렉터리를 인덱싱할 수 있는 파일 또는 디렉터리를 변경하거나 그 반대로 변경합니다. 콘텐츠 인덱싱을 사용하면 선택한 콘텐츠의 데이터베이스를 빌드하여 데이터를 빠르게 검색할 수 있습니다.
|
-
USN_REASON_INTEGRITY_CHANGE
- 0x00800000
|
사용자가 지정된 스트림에 대한 FILE_ATTRIBUTE_INTEGRITY_STREAM 특성의 상태를 변경했습니다.
ReFS 파일 시스템에서 무결성 스트림은 해당 스트림에 대한 모든 데이터의 체크섬을 유지 관리하므로 읽기 또는 쓰기 작업 중에 파일 내용의 유효성을 검사할 수 있습니다.
|
-
USN_REASON_NAMED_DATA_EXTEND
- 0x00000020
|
파일에 대한 하나 이상의 명명된 데이터 스트림이 확장(에 추가됨)됩니다.
|
-
USN_REASON_NAMED_DATA_OVERWRITE
- 0x00000010
|
파일에 대한 하나 이상의 명명된 데이터 스트림의 데이터를 덮어씁니다.
|
-
USN_REASON_NAMED_DATA_TRUNCATION
- 0x00000040
|
파일에 대한 하나 이상의 명명된 데이터 스트림이 잘립니다.
|
-
USN_REASON_OBJECT_ID_CHANGE
- 0x00080000
|
파일 또는 디렉터리의 개체 식별자가 변경되었습니다.
|
-
USN_REASON_RENAME_NEW_NAME
- 0x00002000
|
파일 또는 디렉터리의 이름이 바뀌고 USN_RECORD_V4 구조의 파일 이름이 새 이름입니다.
|
-
USN_REASON_RENAME_OLD_NAME
- 0x00001000
|
파일 또는 디렉터리의 이름이 바뀌고 USN_RECORD_V4 구조의 파일 이름은 이전 이름입니다.
|
-
USN_REASON_REPARSE_POINT_CHANGE
- 0x00100000
|
파일 또는 디렉터리에 포함된 재분석 지점이 변경되거나 파일 또는 디렉터리에서 재분석 지점이 추가되거나 삭제됩니다.
|
-
USN_REASON_SECURITY_CHANGE
- 0x00000800
|
파일 또는 디렉터리에 대한 액세스 권한에서 변경됩니다.
|
-
USN_REASON_STREAM_CHANGE
- 0x00200000
|
명명된 스트림이 파일에 추가되거나 파일에서 제거되거나 명명된 스트림의 이름이 바뀝니다.
|
-
USN_REASON_TRANSACTED_CHANGE
- 0x00400000
|
지정된 스트림은 커밋된 TxF 트랜잭션을 통해 수정됩니다.
|
SourceInfo
DeviceIoControl 작업의 FSCTL_MARK_HANDLE 설정되는 변경 원본에 대한 추가 정보입니다.
스레드가 새 USN 레코드를 작성할 때 스레드가 해당 플래그를 설정하는 경우에만 이전 레코드의 원본 정보 플래그가 계속 존재합니다. 따라서 원본 정보 구조를 사용하면 애플리케이션이 알려진 원본(예: 바이러스 백신 필터)에서만 설정된 USN 레코드를 필터링할 수 있습니다.
다음 값 중 하나를 설정할 수 있습니다.
| 값 |
의미 |
-
USN_SOURCE_AUXILIARY_DATA
- 0x00000002
|
작업은 파일 또는 디렉터리에 프라이빗 데이터 스트림을 추가합니다.
한 가지 예는 체크섬 정보를 추가하는 바이러스 탐지기입니다. 바이러스 탐지기가 항목을 수정하면 시스템에서 USN 레코드를 생성합니다.
USN_SOURCE_AUXILIARY_DATA 수정으로 인해 애플리케이션 데이터가 변경되지 않았음을 나타냅니다.
|
-
USN_SOURCE_DATA_MANAGEMENT
- 0x00000001
|
이 작업은 운영 체제에서 수행한 파일 또는 디렉터리의 변경 내용에 대한 정보를 제공합니다.
일반적인 용도는 원격 스토리지 시스템이 데이터를 외부에서 로컬 스토리지로 이동하는 경우입니다. 원격 스토리지는 계층적 스토리지 관리 소프트웨어입니다. 이러한 이동은 일반적으로 최소한 USN 레코드에 USN_REASON_DATA_OVERWRITE 플래그를 추가합니다. 그러나 데이터는 사용자의 관점에서 변경되지 않았습니다.
SourceInfo 멤버의 USN_SOURCE_DATA_MANAGEMENT 기록 작업을 수행하지만 데이터가 변경되지 않은 것을 확인할 수 있습니다.
|
-
USN_SOURCE_REPLICATION_MANAGEMENT
- 0x00000004
|
작업은 복제본(replica) 집합의 다른 멤버에 있는 동일한 파일의 내용과 일치하도록 파일을 수정합니다.
|
-
USN_SOURCE_CLIENT_REPLICATION_MANAGEMENT
- 0x00000008
|
작업은 클라우드에 있는 동일한 파일의 내용과 일치하도록 클라이언트 시스템의 파일을 수정하는 것입니다.
|
RemainingExtents
현재 USN_RECORD_V4 레코드 다음에 남아 있는 익스텐트 수입니다. 지정된 파일에 대해 수정된 모든 익스텐트 설명에는 여러 버전 4.0 레코드가 필요할 수 있습니다.
RemainingExtents 멤버가 0이면 현재 USN_RECORD_V4 레코드가 파일에 대한 마지막 USN_RECORD_V4 레코드입니다. 지정된 파일에 대한 마지막 USN_RECORD_V4 항목 뒤에는 항상 USN_REASON_CLOSE 플래그 집합이 있는 USN_RECORD_V3 레코드가 잇습니다.
NumberOfExtents
현재 USN_RECORD_V4 항목의 익스텐트 수입니다.
ExtentSize
Extents 멤버의 각 USN_RECORD_EXTENT 구조체 크기(바이트)입니다.
Extents[1]
USN_RECORD_V4 항목의 익스텐트를 나타내는 USN_RECORD_EXTENT 구조체의 배열입니다.
USN_RECORD_V4 레코드는 범위 추적이 켜져 있고 파일 크기가 RangeTrackFileSizeThreshold 멤버의 값보다 크거나 같은 경우에만 출력됩니다. 사용자는 항상 하나 이상의 USN_RECORD_V4 레코드와 하나의 USN_RECORD_V3 레코드를 받습니다.
변경 저널 클라이언트에서 경로 전달 호환성을 제공하기 위해 Microsoft는 USN_RECORD_V4 구조에 변경 저널 소프트웨어의 주 버전 및 부 버전 번호를 제공합니다. 코드는 이러한 값을 검사하고, 변경 저널 소프트웨어와의 자체 호환성을 검사하고, 필요한 경우 비호환성을 정상적으로 처리해야 합니다.
부 버전 번호가 변경되면 기존 USN_RECORD_V4 구조체 멤버가 여전히 유효하지만 마지막 멤버와 가변 길이 문자열인 마지막 멤버 사이에 새 멤버가 추가되었을 수 있음을 나타냅니다.
이러한 변경을 정상적으로 처리하기 위해 코드는 마지막 멤버의 위치에 의존하는 컴파일 시간 포인터 산술 연산을 수행해서는 안 됩니다. 예를 들어 부 버전 번호를 변경하면 호출이 sizeof(USN_RECORD) 신뢰할 수 없게 됩니다. 대신 RecordLength 멤버를 사용하는 런타임 계산을 사용합니다.
변경 저널 소프트웨어의 주 버전 수가 증가하면 USN_RECORD_V4 구조가 크게 변경되었을 수 있으며 현재 정의가 신뢰할 수 없음을 나타냅니다. 코드가 변경 저널 소프트웨어의 주 버전 번호 변경을 감지하는 경우 코드는 변경 저널에서 작동하지 않아야 합니다.
자세한 내용은 변경 저널 만들기, 수정 및 삭제를 참조하세요.
요구 사항
| 요구 사항 |
값 |
|
지원되는 최소 클라이언트 |
Windows 8.1 [데스크톱 앱만 해당] |
|
지원되는 최소 서버 |
Windows Server 2012 R2 [데스크톱 앱만 해당] |
|
머리글 |
winioctl.h(Windows.h 포함) |
추가 정보
FSCTL_MARK_HANDLE
FSCTL_READ_USN_JOURNAL
FSCTL_USN_TRACK_MODIFIED_RANGES
GetFileAttributes
GetVolumeInformation
READ_USN_JOURNAL_DATA
USN_RECORD_COMMON_HEADER
USN_RECORD_EXTENT
USN_RECORD_V2
USN_RECORD_V3
볼륨 관리 구조