Ответы:
Короче говоря, SCP может использоваться только для передачи файлов, и он не является интерактивным (т. Е. Все должно быть указано в командной строке). SFTP более сложный и позволяет интерактивным командам выполнять такие действия, как создание каталогов, удаление каталогов и файлов (конечно, с учетом системных разрешений) и т. Д.
ForceCommand internal-sftp
. Я думаю, что PermitTTY no
также запрещает доступ по scp, но разрешает доступ по sftp, хотя я мог просто набирать пароль каждый раз, когда пытался. Но эти две вещи не должны мешать sftp. Источник: личный опыт.
Из Википедии :
По сравнению с более ранним протоколом SCP, который допускает только передачу файлов, протокол SFTP позволяет выполнять ряд операций с удаленными файлами - он больше похож на протокол удаленной файловой системы. Дополнительные возможности клиента SFTP по сравнению с клиентом SCP включают возобновление прерванных передач, списки каталогов и удаленное удаление файлов. [1] По этим причинам относительно просто реализовать клиент SFTP с графическим интерфейсом по сравнению с клиентом SCP с графическим интерфейсом.
а также
Хотя и SCP, и SFTP используют одинаковое шифрование SSH во время передачи файлов с одинаковым общим уровнем служебных данных, SCP обычно намного быстрее, чем SFTP при передаче файлов, особенно в сетях с высокой задержкой. Это происходит потому, что SCP реализует более эффективный алгоритм передачи, который не требует ожидания подтверждения пакета. Это приводит к более высокой скорости, но происходит за счет невозможности прервать передачу, поэтому, в отличие от SFTP, передача SCP не может быть отменена без завершения сеанса.
С точки зрения командной строки:
Другое важное различие между этими 2 командами заключается в том, что sftp не может поместить локальный файл в удаленное местоположение с помощью одной командной строки , хотя он может получить удаленный файл, в то время как scp может сделать и то, и другое .
sftp user@host:/path/to/remote.file [/path/to/local.file]
scp user@host:/path/to/remote.file [/path/to/local.file]
scp /path/to/local.file user@host:[/path/to/remote.file]
sftp {user}@{host}:{remote_dir} <<< $'put {local_file_path}'
SSH ( S ecure SH ell) - это криптографический сетевой протокол, позволяющий удаленному входу в систему и другим сетевым службам безопасно работать в незащищенной сети.
Отличия: SFTP работает в интерактивном режиме (сеанс), а SCP работает в неинтерактивном. Используя SFTP, мы можем получить доступ к удаленной файловой системе, т. Е. Создавать, удалять и просматривать файлы.
Сходства: Оба SCP ( S ecure С опировать Р rotocol) и SFTP ( S SH F Ile Т ransfer Р rotocol) являются сетевыми протоколами, которые поддерживают управление файлами между узлами в сети. Оба используют SSH.
Большинство различий между этими двумя протоколами уже было сказано в других ответах, и более подробно в https://unix.stackexchange.com/q/8707/19088
Другое отличие, согласно документации curl , заключается в том, что протокол SCP не очень переносим и обычно работает только между системами Unix.
Кстати, curl реализует оба протокола и, в отличие от реализации SFTP-клиента OpenSSH по умолчанию, не является интерактивным как для SFTP, так и для SCP.
И обратите внимание, что существует также протокол FISH , который позволяет передавать файлы через SSH без необходимости использования SCP или SFTP. Насколько я знаю, FISH не очень популярен, в настоящее время он реализован всего в нескольких файловых менеджерах ( Midnight Commander и некоторые на основе KDE) и Lftp .