1

У меня есть структура каталогов, которая выглядит как A1/B1/C1/files111* , A1/B1/C2/files112* , A1/B2/C1/files121* , A1/B2/C2/files122* и т.д., Так что все файлы во всех каталогах уникальны. Есть ли способ использовать scp (или другой инструмент), чтобы вытащить все файлы терминала files###* сразу?

3 ответа3

0

Поскольку вы не указали это в вопросе, я предполагаю, что структура каталогов удаленная, и вы хотите, чтобы она была локальной.

Вам нужно использовать подстановочные знаки, но избегать их на стороне клиента, чтобы ваша локальная оболочка игнорировала их и передавала их. Объедините это с рекурсивным флагом (-r), и он должен работать так, как вы хотите:

scp -r remotemachine:some/directory/files\*   /some/local/target/directory/

Важной частью является обратная косая черта, поскольку она заставляет вашу локальную оболочку игнорировать звездочку и вместо нее передавать ее. Это должно позволить вам извлекать все files* с удаленного компьютера, включая подкаталоги. Также будут извлекаться любые реальные файлы, чьи имена начинаются с files* .

0
ssh user@remote "find /target/A1 -iname \"*files*\" -exec scp {} user@local:/desitnation \;"
  • ssh подключается к удаленной машине и выполняет код, заключенный в двойные кавычки ""
  • find в каталоге /target/A1 всех файлов, содержащих ключевое слово "files". Обратите внимание, что вам нужно использовать обратную косую черту для параметра поиска без учета регистра -iname и двойных кавычек, чтобы не оставлять предыдущую пару слишком рано.
  • -exec - это еще один параметр find , используемый для выполнения кода. В нашем случае мы выполняем scp и передаем все результаты поиска из find в scp с помощью изогнутых скобок {} .
  • scp копирует найденные файлы на ваш локальный или любой другой компьютер.

Это сработало в моей тестовой настройке, так как я обменял открытые ключи, чтобы использовать аутентификацию без пароля.

0

Сначала вы должны подумать о том, что вы хотите случиться с файлами, которые копируются таким образом, и как это может повлиять на будущие операции копирования. Они собираются там остаться? Будут ли они удалены? Архивировано? Как только вы это знаете, вы можете создать команду копирования, а затем необходимые операции очистки. Вот пример сценария, который сначала копирует все существующие файлы, а затем удаляет их с удаленного сервера.

Существует риск, что файлы могут измениться между операциями копирования и удаления, поэтому я сначала переместил бы их во временный каталог, а затем скопировал и удалил их оттуда, чтобы рабочий каталог мог продолжать обычную работу.

Я также создал бы задание cron для автоматического извлечения этих файлов каждый день в одно и то же время и добавил бы некоторые проверки работоспособности, чтобы гарантировать успешное завершение операций.

#!/bin/bash
HOST="RemoteServerIPorHostName"
localDir="/some/local/dir"

for remoteTargets in "/A1/B1/C1/files111*" "/A1/B1/C2/files112*" "/A1/B2/C1/files121*" "/A1/B2/C2/files122*"
do
    scp -pr user@$HOST:$remoteTargets $localDir
    ssh -t user@$HOST 'rm -rf $remoteTargets'
done

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .