AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 704968
Accepted
EmmaV
EmmaV
Asked: 2022-06-05 04:02:50 +0800 CST2022-06-05 04:02:50 +0800 CST 2022-06-05 04:02:50 +0800 CST

'find -exec mv' perde 4 arquivos

  • 772

Eu queria mover cerca de 1000 arquivos mp3 de um diretório chamado 'music' contendo uma complicada estrutura de diretórios aninhada, para um único diretório chamado 'mp3s', para que eu pudesse ouvi-los no meu carro.

O comando que usei foi:

find music -name '*mp3' -exec mv -v -t mp3s {} +

Algo estranho aconteceu quando eu executei o comando no entanto. Após a conclusão do comando, notei que quatro arquivos foram omitidos. Esses arquivos foram:

"music/Michael Hedges/Michael Hedges - Taproot/06 - Chava's Song.mp3"
'music/Michael Hedges/Michael Hedges - Aerial Boundaries/04 - Ragamuffin.mp3'
'music/Jonas Hellborg/1988 - Bass/07. Blues For LW.flac.mp3'
'music/Jonas Hellborg/1988 - Axis/03. Roman.flac.mp3'

Executei exatamente o mesmo comando novamente e, desta vez, os quatro arquivos omitidos anteriormente foram movidos conforme o esperado.

Não consigo imaginar por que findpoderia fazer algo inesperado como isso. Por que isso pode ter acontecido?

Executado no shell bash no Ubuntu.

find mv
  • 1 1 respostas
  • 907 Views

1 respostas

  • Voted
  1. Best Answer
    Kamil Maciorowski
    2022-06-05T11:26:56+08:002022-06-05T11:26:56+08:00

    Hipótese: colisões de nomes

    Imagine que em algum momento o comando fosse assim:

    mv -v -t mp3s … …/some_dir/foo.mp3 … …/another_dir/foo.mp3 …
    

    foo.mp3from some_dirfoi movido para mp3s, mas foo.mp3de another_diracionado:

    mv: will not overwrite just created 'mp3s/foo.mp3' with '…/another_dir/foo.mp3'
    

    Aparentemente, a mensagem passou despercebida no rebanho de mensagens causadas por -v.

    Mais tarde o segundo findtentou se mover …/another_dir/foo.mp3novamente, mas desta vez não havia …/some_dir/foo.mp3, então mp3s/foo.mp3não foi considerado "apenas criado", foi sobrescrito.

    Note -exec mv … {} +pode executar mais de um mv. Se …/some_dir/foo.mp3e …/another_dir/foo.mp3fossem atribuídos a diferentes invocações de mv, o último mvnão seria considerado mp3s/foo.mp3como "recém criado". Isso significa que, no seu caso, pode ter havido mais colisões de nomes e alguns arquivos foram substituídos silenciosamente. Apenas colisões de nomes em que arquivos com nomes de base idênticos foram atribuídos ao mesmo mvfizeram com que alguns arquivos não fossem movidos.


    Prova de conceito

    $ mv --version
    mv (GNU coreutils) 8.30
    Copyright (C) 2018 Free Software Foundation, Inc.
    License GPLv3+: GNU GPL version 3 or later <https://gnu.org/licenses/gpl.html>.
    This is free software: you are free to change and redistribute it.
    There is NO WARRANTY, to the extent permitted by law.
    
    Written by Mike Parker, David MacKenzie, and Jim Meyering.
    $
    $ mkdir -p music/a music/b music/c mp3s
    $ touch music/a/A music/b/B music/c/A
    $ tree --noreport
    .
    |-- mp3s
    `-- music
        |-- a
        |   `-- A
        |-- b
        |   `-- B
        `-- c
            `-- A
    $ find music -type f -exec mv -v -t mp3s {} +
    renamed 'music/a/A' -> 'mp3s/A'
    renamed 'music/b/B' -> 'mp3s/B'
    mv: will not overwrite just-created 'mp3s/A' with 'music/c/A'
    $ tree --noreport
    .
    |-- mp3s
    |   |-- A
    |   `-- B
    `-- music
        |-- a
        |-- b
        `-- c
            `-- A
    $ find music -type f -exec mv -v -t mp3s {} +
    renamed 'music/c/A' -> 'mp3s/A'
    $ tree --noreport
    .
    |-- mp3s
    |   |-- A
    |   `-- B
    `-- music
        |-- a
        |-- b
        `-- c
    $ 
    
    • 21

relate perguntas

  • Comportamento estranho para localizar se o padrão seguinte -name não estiver entre aspas

  • Imprima variáveis ​​do subshell para o shell pai [duplicado]

  • verificando se existe uma pasta em determinado diretório

  • Localizar e substituir cores em arquivos CSS na linha de comando

  • GNU find: obtenha caminho absoluto e relativo em -exec

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve