학습
충돌 및 우선 순위
파일 및 설정을 포함, 제외 및 다시 라우팅하는 경우 USMT(사용자 상태 마이그레이션 도구)가 충돌 및 우선 순위를 처리하는 방법을 알고 있는 것이 중요합니다. 다음은 USMT를 사용할 때 유의해야 할 가장 중요한 충돌 및 우선 순위 지침입니다.
구성 요소 내에 충돌하는 규칙이 있는 경우 가장 구체적인 규칙이 적용됩니다. 그러나 <unconditionalExclude> 규칙은 다른 모든 규칙보다 우선하기 때문에 예외입니다. 디렉터리 이름은 파일 확장명보다 우선합니다. 예를 들어 충돌<하는 포함> 및 <제외> 규칙이 있으면 어떻게 되나요?를 참조하고 이 문서의 뒷부분에 나오는< 규칙 우선 순위 예제 포함> 및 <제외>의 첫 번째 예제를 참조하세요.
특정성에 따라 동일한 구성 요소 내의 규칙만 서로 영향을 줄 수 있습니다. 서로 다른 구성 요소에 있는 규칙은 unconditionalExclude> 규칙을 제외하고< 서로 영향을 주지 않습니다.
규칙이 동일하게 특정<한 경우 제외>가 include>보다 <우선합니다. 예를 들어 제외> 규칙을 사용하여 파일을 제외하고 include 규칙을 사용하여 동일한 파일을 포함하는 경우< 파일은 제외됩니다.<>
구성 요소의 순서는 중요하지 않습니다. 각 구성 요소는 모든 .xml 파일에서 다른 구성 요소와 독립적으로 처리되므로 .xml파일에 나열 된 구성 요소는 중요하지 않습니다.
구성 요소 내의 <포함> 및 <제외> 규칙 순서는 중요하지 않습니다.
<unconditionalExclude> 요소를 사용하여 데이터를 전역적으로 제외할 수 있습니다. 이 요소는 .xml 파일에 있는 다른 <포함> 규칙에 관계없이 개체를 제외합니다. 예를 들어 unconditionalExclude> 요소를 사용하여 컴퓨터의< 모든 MP3 파일을 제외하거나 에서
C:\UserData
모든 파일을 제외할 수 있습니다.
unconditionalExclude> 규칙을 제외하고 동일한 구성 요소 내의< 규칙만 특이성에 따라 서로 영향을 줄 수 있습니다. 서로 다른 구성 요소에 있는 규칙은 서로 영향을 주지 않습니다. 한 구성 요소에 포함> 규칙이 있고 다른 구성 요소에 동일한 제외 규칙이 있는 경우 두 규칙이 서로 독립적이기 때문에 데이터가 마이그레이션됩니다.<<>
<포함> 규칙이 한 구성 요소에 있고 <locationModify> 규칙이 동일한 파일의 다른 구성 요소에 있는 경우 파일은 두 위치에서 모두 마이그레이션됩니다. 즉, 파일은 포함> 규칙에 따라< 포함되며, 파일은 locationModify> 규칙에 따라< 마이그레이션됩니다.
다음 .xml 파일은 제외> 규칙이 별도의 구성 요소에 지정되어 있으므로<.mp3 파일을 포함하여 C:\Userdocs의 모든 파일을 마이그레이션합니다.
<migration urlid="http://www.microsoft.com/migration/1.0/migxmlext/UserDocs">
<component type="Documents" context="System">
<displayName>User Documents</displayName>
<role role="Data">
<rules>
<exclude>
<objectSet>
<pattern type="File">C:\Userdocs\* [*.mp3]</pattern>
</objectSet>
</exclude>
</rules>
</role>
</component>
<component type="Documents" context="System">
<displayName> User documents to include </displayName>
<role role="Data">
<rules>
<include>
<objectSet>
<pattern type="File"> C:\Userdocs\ [*]</pattern>
</objectSet>
</include>
</rules>
</role>
</component>
</migration>
파일에서 Config.xml
지정하는 migrate="no"
것은 마이그레이션 .xml 파일에서 해당 구성 요소를 삭제하는 것과 같습니다. 그러나 이 Documents 폴더에 대해 설정되어 있지만 다음 규칙과 유사한 규칙이 마이그레이션 .xml 파일(Documents 폴더의 모든 .doc 파일 포함)에 있는 경우 migrate="no"
.doc 파일만 마이그레이션되고 다른 모든 파일은 제외됩니다.
<include>
<objectSet>
<pattern type="File">%CSIDL_PERSONAL%\* [*.doc] </pattern>
</objectSet>
</include>
구성 요소의 순서는 중요하지 않습니다. 각 구성 요소는 다른 구성 요소와 독립적으로 처리됩니다. 예를 들어 포함> 규칙이 한 구성 요소에 있고 locationModify 규칙이 동일한 파일의 다른 구성 요소에 있는 경우< 파일은 두 위치에서 모두 마이그레이션됩니다.>< 즉, 파일은 포함> 규칙에 따라< 포함되며, 파일은 locationModify> 규칙에 따라< 마이그레이션됩니다.
규칙의 두 가지 광범위한 범주가 있습니다.
ScanState 및 LoadState 도구의 동작에 영향을 주는 규칙입니다. 예를 들어 <include>, <exclude> 및 <unconditionalExclude> 규칙은 .xml 파일의 각 구성 요소에 대해 처리됩니다. 각 구성 요소에 대해 USMT는 포함 목록과 제외 목록을 만듭니다. 구성 요소의 일부 규칙은 특이성으로 인해 삭제될 수 있지만 나머지 규칙은 모두 처리됩니다. 각 <포함> 규칙에 대해 USMT는 요소를 반복하여 제외해야 하는 위치가 있는지 확인합니다. USMT는 모든 개체를 열거하고 각 사용자에 대해 수집할 개체 목록을 만듭니다. 목록이 완료되면 각 개체가 저장되거나 대상 컴퓨터로 마이그레이션됩니다.
LoadState 도구의 동작에만 영향을 주는 규칙입니다. 예를 들어 <locationModify>, <contentModify> 및 <destinationCleanup> 규칙은 ScanState에 영향을 주지 않습니다. LoadState에서만 처리됩니다. 먼저 LoadState 도구는 locationModify 및 contentModify> 규칙에 따라< 각 구성 요소의 콘텐츠와 <위치를 결정합니다.> 그런 다음 LoadState 는 모든 <destinationCleanup> 규칙을 처리하고 대상 컴퓨터에서 데이터를 삭제합니다. 마지막으로 LoadState 는 구성 요소를 컴퓨터에 적용합니다.
USMT는 이름 또는 콘텐츠에 따라 .xml 파일을 구분하지 않습니다. 파일 내의 각 구성 요소를 개별적으로 처리합니다. USMT는 여러 .xml 파일을 지원하여 구성 요소를 더 쉽게 유지 관리하고 구성할 수 있도록 합니다. USMT는 urlid를 사용하여 각 구성 요소를 다른 구성 요소와 구분하기 때문에 명령줄에 지정된 각 .xml 파일에 고유한 마이그레이션 urlid가 있는지 확인합니다.
구성 요소 내에 충돌하는 규칙이 있는 경우 다른 모든 규칙보다 우선하는 unconditionalExclude> 규칙을 제외하고< 가장 구체적인 규칙이 적용됩니다. 규칙이 동일하게 특정한 경우 데이터는 마이그레이션되지 않습니다. 예를 들어 동일한 파일이 모두 제외되고 포함된 경우 파일은 마이그레이션되지 않습니다. 서로 다른 구성 요소 내에 충돌하는 규칙이 있는 경우 각 구성 요소가 독립적으로 처리되므로 규칙이 서로 영향을 주지 않습니다.
다음 예제에서는 mp3 파일이 마이그레이션에서 제외되지 않습니다. 디렉터리 이름이 파일 확장명보다 우선하기 때문에 mp3 파일은 제외되지 않습니다.
<include>
<objectSet>
<pattern type="File">C:\Data\* [*]</pattern>
</objectSet>
</include>
<exclude>
<objectSet>
<pattern type="File"> C:\* [*.mp3]</pattern>
</objectSet>
</exclude>
이러한 예제에서는 USMT가 포함> 및 제외 규칙을 처리하는< 방법을 설명합니다.>< 규칙이 서로 다른 구성 요소에 있는 경우 구성 요소가 동일한지 또는 다른 마이그레이션 .xml 파일에 있는지 여부에 관계없이 결과 동작이 동일합니다.
다음 코드가 동일한 구성 요소에 있는 경우 | 결과 동작 | 설명 |
---|---|---|
|
Dir1의 모든 파일 및 하위 폴더를 마이그레이션합니다(C:의 모든 .txt 파일 포함). | <제외> 규칙은 포함> 규칙이 더 구체적이기 때문에 마이그레이션에< 영향을 주지 않습니다. |
|
C:\Dir1\Dir2의 .txt 파일과 하위 폴더를 제외하고 C:\Dir1의 모든 파일과 하위 폴더를 마이그레이션합니다. | 두 규칙은 모두 의도한 대로 처리됩니다. |
|
C:\Dir1의 .txt 파일과 해당 하위 폴더를 제외하고 C:\Dir1의 모든 파일 및 하위 폴더를 마이그레이션합니다. | 두 규칙은 모두 의도한 대로 처리됩니다. |
|
아무것도 마이그레이션되지 않습니다. | 규칙은 동일하게 구체적이므로 <제외> 규칙이 포함> 규칙보다< 우선합니다. |
|
Dir1의 .txt 파일과 Dir2 이외의 하위 폴더에서 .txt 파일을 마이그레이션합니다. Dir2 또는 하위 폴더에서 마이그레이션된 파일이 없습니다. |
두 규칙은 모두 의도한 대로 처리됩니다. |
|
Dir1의 .txt 파일과 Dir1의 하위 폴더(Dir2 포함)를 제외한 Dir2의 모든 파일과 하위 폴더를 마이그레이션합니다. | 두 규칙은 모두 의도한 대로 처리됩니다. |
다음 코드가 다른 구성 요소에 있는 경우 | 결과 동작 | 설명 |
---|---|---|
구성 요소 1:
구성 요소 2:
|
C:\Dir1\의 모든 파일 및 하위 폴더(C:\Dir1\Dir2 포함)를 마이그레이션합니다. | 서로 다른 구성 요소에 있는 규칙은 unconditionalExclude> 규칙을 제외하고< 서로 영향을 주지 않습니다. 따라서 이 예제에서는 구성 요소 1이 처리될 때 일부 .txt 파일이 제외되었지만 구성 요소 2가 처리될 때 포함되었습니다. |
구성 요소 1:
구성 요소 2:
|
C:\Dir1의 .txt 파일과 하위 폴더를 제외한 모든 파일 및 하위 폴더를 Dir2에서 마이그레이션합니다. | 두 규칙은 모두 의도한 대로 처리됩니다. |
구성 요소 1:
구성 요소 2:
|
Dir1의 모든 .txt 파일과 하위 폴더를 마이그레이션합니다. | 구성 요소 1에는 포함> 규칙이 없<으므로 <제외> 규칙이 처리되지 않습니다. |
다음 코드가 동일한 구성 요소에 있는 경우 | 결과 동작 | 설명 |
---|---|---|
|
DefaultColor를 제외한 HKLM\Software\Microsoft\Command Processor의 모든 키를 마이그레이션합니다. | 두 규칙은 모두 의도한 대로 처리됩니다. |
|
HKLM\Software\Microsoft\Command Processor에서 DefaultColor만 마이그레이션합니다. | 포함> 규칙이 제외 규칙보다 더 구체적이기 때문에< DefaultColor가 <마이그레이션됩니다.> |
|
DefaultColor를 마이그레이션하지 않습니다. | 규칙은 동일하게 구체적이므로 <제외> 규칙이 포함> 규칙보다 <우선합니다. |
다음 코드가 다른 구성 요소에 있는 경우 | 결과 동작 | 설명 |
---|---|---|
구성 요소 1:
구성 요소 2:
|
HKLM\Software\Microsoft\Command Processor에서 모든 키/값을 마이그레이션합니다. | 서로 다른 구성 요소에 있는 규칙은 unconditionalExclude> 규칙을 제외하고< 서로 영향을 주지 않습니다. 이 예제에서는 구성 요소 1이 처리될 때 제외된 개체가 구성 요소 2를 처리할 때 포함되었습니다. |
병합> 규칙이 없는< 경우 레지스트리의 기본 동작은 원본이 대상을 덮어쓰는 것입니다. 파일의 기본 동작은 원본 이름을 증분 방식으로 바꾸는 것입니다(예: OriginalFileName(1)). OriginalExtension, OriginalFileName(2). OriginalExtension 등.
충돌이 감지되면 USMT는 가장 구체적인 <병합> 규칙을 선택하고 충돌을 resolve 적용합니다. 예를 들어 C:\* [*]에 대한 병합> 규칙이 sourcePriority()로 설정되고 C:\subfolder\* [*]에 대한 다른 병합 규칙이 destinationPriority() 로 설정된 경우< USMT는 가장 구체적이기 때문에 destinationPriority() 규칙을 사용합니다.<>
원본 컴퓨터에는 다음 파일이 포함되어 있습니다.
C:\Data\SampleA.txt
C:\Data\SampleB.txt
C:\Data\Folder\SampleB.txt
대상 컴퓨터에는 다음 파일이 포함됩니다.
C:\Data\SampleB.txt
C:\Data\SampleB.txt
사용자 지정 .xml 파일에는 다음 코드가 포함됩니다.
<include>
<objectSet>
<pattern type="File">c:\data\* [*]</pattern>
</objectSet>
</include>
이 예제에서 다음 정보는 코드가 사용자 지정 .xml 파일에 추가되는 경우의 결과 동작에 대해 설명합니다.
<merge script="MigXmlHelper.DestinationPriority()">
<objectSet>
<pattern type="File">c:\data* []</pattern>
</objectSet>
</merge>
결과: ScanState 중에 모든 파일이 저장소에 추가됩니다. LoadState 중에만 C:\Data\SampleA.txt
복원됩니다.
<merge script="MigXmlHelper.SourcePriority()">
<objectSet>
<pattern type="File">c:\data* []</pattern>
</objectSet>
</merge>
결과: ScanState 중에 모든 파일이 저장소에 추가됩니다. LoadState 중에는 모든 파일이 복원되어 대상 컴퓨터의 기존 파일을 덮어씁니다.
<merge script="MigXmlHelper.SourcePriority()">
<objectSet>
<pattern type="File">c:\data\ [*]</pattern>
</objectSet>
</merge>
결과: ScanState 중에 모든 파일이 저장소에 추가됩니다. LoadState 중에 다음 작업이 발생합니다.
-
C:\Data\SampleA.txt
가 복원됩니다. -
C:\Data\SampleB.txt
가 복원되어 대상 컴퓨터의 기존 파일을 덮어씁니다. -
C:\Data\Folder\SampleB.txt
복원되지 않습니다.
USMT XML 참조입니다.