Estou realizando um xcopy
backup de um disco no Windows usando a seguinte linha de comando:
xcopy "d:\" "r:\" /v /h /k /e /b /d
Eu sei que a opção de verificação não faz muito, mas uma comparação de tamanho de arquivo é melhor do que nada para a cópia inicial.
O problema que estou tendo é que xcopy
está dando um erro de verificação de arquivo e não sei porque. O arquivo em questão é um link simbólico e o arquivo para o qual ele aponta já existe.
Eu tenho o Cygwin presente e executei um diff
, diff --no-dereference
e cmp
em ambos os links, bem como o arquivo real para o qual ele aponta em ambos os discos sem diferença.
Ambos os arquivos têm exatamente 73 bytes.
Não consigo reproduzir isso criando uma pasta de teste com links válidos ou inválidos enquanto uso xcopy
com as mesmas opções para realizar uma cópia no mesmo disco ou em discos diferentes.
Por que xcopy
falharia desta forma?
O Xcopy não registra um tamanho de arquivo ao copiar um link simbólico, mas a passagem de verificação não reconhece os links simbólicos e tenta comparar o tamanho do arquivo de destino com o registro (não definido).
Isso pode ser observado com o Sysinternals Process Monitor . É mais esclarecedor copiar apenas um único arquivo de cada vez e começar a capturar eventos de E/S de arquivo do
xcopy.exe
processo apenas depois que o Xcopy perguntar se o destino é um diretório, mas antes de você responder - dessa forma, você pula todo o E/S de inicialização do processo. Quando/B
é passado, o Xcopy define a opção "Open Reparse Point" naCreateFile
operação que abre o arquivo de origem, informando ao Windows que, se o arquivo for um link simbólico (ponto de nova análise), ele deseja abrir o próprio link simbólico em vez do arquivo de destino . Mais tarde, depois de criar o arquivo de destino, defini-lo como um link simbólico e embaralhar alguns atributos de arquivo, se/V
for passado, o Xcopy emite outroCreateFile
para abrir o arquivo de destino novamente, mas sem a opção "Open Reparse Point". Se for um link simbólico, o resultado éREPARSE
e o Windows realmente abre o arquivo de destino para Xcopy naCreateFile
operação imediatamente seguinte. Logo, o Xcopy realiza umaQueryStandardInformationFile
operação, obtendo o tamanho do arquivo que ele pensava ser o destino. Mas, olhando de volta para o log, lembramos que nenhumaQueryStandardInformationFile
operação no/através do arquivo de origem ocorreu anteriormente para comparar o tamanho do arquivo. Por outro lado, se você monitorar uma Xcopy de um arquivo normal (mesmo com/B
), você verá umaQueryStandardInformationFile
operação no arquivo de origem logo após ser aberto comCreateFile
.Como suporte adicional a essa hipótese, o Xcopy pode copiar e verificar com êxito um link simbólico para um arquivo de zero byte. Aparentemente, o registro de tamanho do arquivo é inicializado com zero, portanto, mesmo que não seja definido ao copiar o link simbólico, quando a passagem de verificação abre cegamente o destino do link simbólico copiado para obter seu tamanho, a resposta de zero corresponde ao zero padrão.
A
/v
opção verifica cada arquivo conforme está escrito, com base em seu tamanho, para garantir que sejam idênticos.A verificação foi incorporada ao
xcopy
comando a partir do Windows XP, mas não deve fazer nada em versões posteriores do Windows. Ele é incluído apenas para compatibilidade com arquivos MS-DOS mais antigos.Não é de admirar que esse antigo código de verificação não funcione bem com um recurso mais recente, como links simbólicos.
Eu recomendaria não usar
xcopy
se você tiver links simbólicos. Use um aplicativo mais moderno que possa fazer a verificação, como o TeraCopy .