Table des matières
Utilisation de base de la commande scp" >Utilisation de base de la commande scp
Utilisez -v paramètres pour afficher les détails du processus scp" >Utilisez -v paramètres pour afficher les détails du processus scp
Sortie" >Sortie
Fournir l'heure de modification, l'heure d'accès et le mode du fichier d'origine" >Fournir l'heure de modification, l'heure d'accès et le mode du fichier d'origine
Utilisez le paramètre -C pour accélérer le transfert de fichiers" >Utilisez le paramètre -C pour accélérer le transfert de fichiers
更改 scp 密码以加密文件" >更改 scp 密码以加密文件
使用 scp 命令限制带宽使用" >使用 scp 命令限制带宽使用
指定要与 scp 一起使用的特定端口" >指定要与 scp 一起使用的特定端口
递归复制目录中的文件" >递归复制目录中的文件
禁用进度表和警告 / 诊断消息" >禁用进度表和警告 / 诊断消息
通过代理使用 scp 复制文件" >通过代理使用 scp 复制文件
选择不同的ssh_config 文件" >选择不同的ssh_config 文件
场景示例" >场景示例
Maison Tutoriel système Linux 10 commandes scp pour transférer des dossiers de fichiers sous Linux

10 commandes scp pour transférer des dossiers de fichiers sous Linux

Feb 10, 2024 pm 08:30 PM
linux Tutoriel Linux Système Linux Commande Linux script shell Linux embarqué Débuter avec Linux apprentissage Linux

Utilisation de base de la commande scp

Les commandes suivantes signifient 把 source_file_name复制到destination_hostusername account下的destination_folderri.

在 Linux 中传输文件文件夹的 10个 scp 命令

> scp source_file_name username@destination_host:destination_folder

Copie

De nombreux paramètres peuvent être utilisés dans la commande scp. Voici quelques paramètres qui peuvent être utilisés dans les opérations quotidiennes.

Utilisez -v paramètres pour afficher les détails du processus scp

La commande par défaut scp ne prend aucun paramètre et copiera les fichiers silencieusement en arrière-plan. Les utilisateurs ne peuvent voir les résultats que lorsque le processus se termine ou qu'une erreur se produit.

Vous pouvez utiliser le paramètre -v pour afficher les informations de débogage à l'écran. Cela peut vous aider à résoudre les problèmes de connectivité, d’authentification et de configuration.

rumenz@local $ scp -v Label.pdf rumenz@192.168.1.110:.
Sortie

Scp affiche la progression lors de la copie de fichiers

Executing: program /usr/bin/ssh host 202.x.x.x, user mrarianto, command scp -v -t .
OpenSSH_6.0p1 Debian-3, OpenSSL 1.0.1c 10 May 2012
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to 202.x.x.x [202.x.x.x] port 22.
debug1: Connection established.
debug1: Host '202.x.x.x' is known and matches the RSA host key.
debug1: Found key in /home/pungki/.ssh/known_hosts:1
debug1: ssh_rsa_verify: signature correct
debug1: Next authentication method: password
rumenz@202.x.x.x's password:
debug1: Authentication succeeded (password).
Authenticated to 202.x.x.x ([202.x.x.x]:22).
Sending file modes: C0770 3760348 Label.pdf
Sink: C0770 3760348 Label.pdf
Label.pdf 100% 3672KB 136.0KB/s 00:27
Transferred: sent 3766304, received 3000 bytes, in 65.2 seconds
Bytes per second: sent 57766.4, received 46.0
debug1: Exit status 0

Fournir l'heure de modification, l'heure d'accès et le mode du fichier d'origine

-p Les paramètres vous aideront à résoudre ce problème. Une durée estimée et une vitesse de connexion apparaîtront à l'écran.

rumenz@local $ scp -p Label.pdf rumenz@192.168.1.110:.
Sortie

scp estime le temps nécessaire pour copier des fichiers volumineux

> rumenz@202.x.x.x's password:
Label.pdf 100% 3672KB 126.6KB/s 00:29

Utilisez le paramètre -C pour accélérer le transfert de fichiers

L'un des paramètres qui peuvent accélérer le transfert de fichiers est -C 范围。这 -C Le paramètre compressera vos fichiers à tout moment et n'importe où, la particularité est que la compression ne se produit que sur le réseau. Lorsque le fichier atteint le serveur de destination, il est restauré à sa taille d'origine avant compression.

> rumenz@local $ scp -pv messages.log rumenz@192.168.1.110:.
Sortie

scp transférer des fichiers sans compression

Executing: program /usr/bin/ssh host 202.x.x.x, user mrarianto, command scp -v -p -t .
OpenSSH_6.0p1 Debian-3, OpenSSL 1.0.1c 10 May 2012
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to 202.x.x.x [202.x.x.x] port 22.
debug1: Connection established.
debug1: identity file /home/pungki/.ssh/id_rsa type -1
debug1: Found key in /home/pungki/.ssh/known_hosts:1
debug1: ssh_rsa_verify: signature correct
debug1: Trying private key: /home/pungki/.ssh/id_rsa
debug1: Next authentication method: password
rumenz@202.x.x.x's password:
debug1: Authentication succeeded (password).
Authenticated to 202.x.x.x ([202.x.x.x]:22).
debug1: Sending command: scp -v -p -t .
File mtime 1323853868 atime 1380425711
Sending file timestamps: T1323853868 0 1380425711 0
messages.log 100% 93MB 58.6KB/s 27:05
Transferred: sent 97614832, received 25976 bytes, in 1661.3 seconds
Bytes per second: sent 58758.4, received 15.6
debug1: Exit status 0

-C Autoriser la compression

rumenz@local $ scp -Cpv messages.log rumenz@192.168.1.110:.
Sortie

scp transfère les fichiers plus rapidement grâce à la compression

Executing: program /usr/bin/ssh host 202.x.x.x, user mrarianto, command scp -v -p -t .
OpenSSH_6.0p1 Debian-3, OpenSSL 1.0.1c 10 May 2012
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to 202.x.x.x [202.x.x.x] port 22.
debug1: Connection established.
debug1: identity file /home/pungki/.ssh/id_rsa type -1
debug1: Host '202.x.x.x' is known and matches the RSA host key.
debug1: Found key in /home/pungki/.ssh/known_hosts:1
debug1: ssh_rsa_verify: signature correct
debug1: Next authentication method: publickey
debug1: Trying private key: /home/pungki/.ssh/id_rsa
debug1: Next authentication method: password
rumenz@202.x.x.x's password:
debug1: Enabling compression at level 6.
debug1: Authentication succeeded (password).
Authenticated to 202.x.x.x ([202.x.x.x]:22).
debug1: channel 0: new [client-session]
debug1: Sending command: scp -v -p -t .
File mtime 1323853868 atime 1380428748
Sending file timestamps: T1323853868 0 1380428748 0
Sink: T1323853868 0 1380428748 0
Sending file modes: C0600 97517300 messages.log
messages.log 100% 93MB 602.7KB/s 02:38
Transferred: sent 8905840, received 15768 bytes, in 162.5 seconds
Bytes per second: sent 54813.9, received 97.0
debug1: Exit status 0
debug1: compress outgoing: raw data 97571111, compressed 8806191, factor 0.09
debug1: compress incoming: raw data 7885, compressed 3821, factor 0.48

Si vous copiez un grand nombre de fichiers sur le réseau, le paramètre -C vous aidera à réduire le temps total requis.

压缩方法不适用于所有文件。当源文件已经被压缩时,就没有什么效果了。文件如.zip,.rar,pictures, 和.iso

更改 scp 密码以加密文件

默认情况下scp使用 AES-128 来加密文件。如果你想更改为其他密码对其进行加密,你可以使用 -c 范围。看看这个命令。

rumenz@local $ scp -c 3des Label.pdf rumenz@192.168.1.110:.

rumenz@202.x.x.x's password:
Label.pdf 100% 3672KB 282.5KB/s 00:13

上面的命令告诉scp使用3des algorithm来加密文件。请注意此参数使用 -c不是-C

使用 scp 命令限制带宽使用

另一个可能有用的参数是 -l 范围。这 -l 参数将限制使用的带宽制 。如果你执行自动化脚本来复制大量文件,这将很有用

rumenz@local $ scp -l 400 Label.pdf rumenz@192.168.1.110:.

rumenz@202.x.x.x's password:
Label.pdf 100% 3672KB 50.3KB/s 01:13

scp 默认带宽的单位是Kilobyte/sec(KB/s)。所以如果你想限制你的带宽scp最多只有50 KB/s,你需要将其设置为50 x 8=400.

指定要与 scp 一起使用的特定端口

scp正在使用端口22作为默认端口。但出于安全原因,你可以将端口更改为另一个端口. 例如,我们使用端口2249.

rumenz@local $ scp -P 2249 Label.pdf rumenz@192.168.1.110:.

rumenz@202.x.x.x's password:
Label.pdf 100% 3672KB 262.3KB/s 00:14

递归复制目录中的文件

有时我们需要复制目录和其中的所有文件,目录

rumenz@local $ scp -r documents rumenz@192.168.1.110:.

rumenz@202.x.x.x's password:
Label.pdf 100% 3672KB 282.5KB/s 00:13
scp.txt 100% 10KB 9.8KB/s 00:00

复> 制过程完成后,你将在目标服务器上找到一个名为documents及其所有文件。文件夹documents是自动创建的。

禁用进度表和警告 / 诊断消息

rumenz@local $ scp -q Label.pdf rumenz@192.168.1.110:.

rumenz@202.x.x.x's password:
rumenz@local $

可以看到,输入密码后,没有关于 scp 进程的信息。该过程完成后,你将再次看到提示。

通过代理使用 scp 复制文件

代理服务器通常用于办公环境。scp 本身没有配置代理。当你的环境使用代理时,你必须告诉scp 与代理进行通信。

例如代理地址是10.0.96.6代理端口是8080.代理还实现了用户身份验证。首先,你需要创建 ~/.ssh/config文件

ProxyCommand /usr/bin/corkscrew 10.0.96.6 8080 %h %p ~/.ssh/proxyauth

然后你需要创建文件 ~/.ssh/proxyauth 里面输入。

myusername:mypassword

前提是需要安装corkscrew

$ apt-get install corkscrew

Centos系统可以用yum安装corkscrew

# yum install corkscrew

由于 ~/.ssh/proxyauth 文件包含你的 usernamepassword 以明文格式,请确保该文件只能自己访问。

选择不同的ssh_config 文件

对于经常在公司网络和公共网络之间切换的移动用户来说,总是在scp中更改设置会很痛苦。

场景示例

代理在公司网络中使用,但不在公共网络中使用,并且你定期切换网络。

rumenz@local $ scp -F /home/pungki/proxy_ssh_config Label.pdf

rumenz@192.168.1.110:.
rumenz@202.x.x.x's password:
Label.pdf 100% 3672KB 282.5KB/s 00:13

默认情况下 ssh_config 每个用户的文件将被放置在 ~/.ssh/config。创建一个特定的 ssh_config 具有代理兼容性的文件将更容易在网络之间切换。

当你在公司网络,你可以使用 -F 范围。当你在公共网络上时,你可以不用-F参数。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Stock Market GPT

Stock Market GPT

Recherche d'investissement basée sur l'IA pour des décisions plus intelligentes

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment traiter dans la politique de planification FIFO Linux Linux Comment traiter dans la politique de planification FIFO Linux Linux Sep 03, 2025 pm 12:39 PM

Pour effectuer des processus Linux exécutés dans la planification FIFO en temps réel, vous devez utiliser l'appel système CHRT ou Sched_Setscheduler pour définir la stratégie et la priorité de la planification, telles que Sudochrt-F99./App ou configurer sched_fifo et paramètres prioritaires dans le programme C, et assurez-vous que le processus a CAP_SYS_NICE CONDITIONS ou PRÉMITION ROAD PERMITIONS, et Configurer RTPio et MEMLOC Assurez-vous une réalité et évitez l'inversion prioritaire. Vous devez utiliser un mutex qui prend en charge l'héritage prioritaire.

Lien d'installation d'iPhone de l'assistant d'assistant d'assistant authentique de l'assistant AISI Lien d'installation d'iPhone de l'assistant d'assistant d'assistant authentique de l'assistant AISI Sep 16, 2025 am 11:30 AM

Le portail de téléchargement officiel de l'assistant AISI est situé sur le site officiel https://www.i4.cn/, et fournit des téléchargements informatiques et mobiles, prise en charge de la gestion des périphériques, de l'installation d'applications, de la commutation de mode, de la projection d'écran et de la gestion des fichiers.

Comment installer des packages logiciels de format Deb pour Linux Comment installer des packages logiciels de format Deb pour Linux Sep 03, 2025 pm 12:36 PM

Les méthodes courantes d'installation des packages .Deb comprennent: l'utilisation de la commande dpkg pour installer et utiliser les dépendances APT pour réparer; 2. Il est recommandé d'utiliser apttinstall./package_name.deb pour gérer automatiquement les dépendances; 3. Vous pouvez double-cliquer sur le fichier pour installer via le centre logiciel de manière graphique; 4. Après l'installation, vous pouvez utiliser DPKG-L ou DPKG-S pour vérifier l'état du package.

Comment exécuter les programmes Windows sur Linux Comment exécuter les programmes Windows sur Linux Sep 18, 2025 am 03:25 AM

TorunwindowsProgramSonLinux, TryTheseMethods: 1.Usewinetodirectlyrun.exefiles.2.installplayonLinuxforeasierwinemanagement.3.SetUpawindowsVirtualMachinewithVirtualBox.4USELULUTRISTOINSTALLANDRUNWINDOWSGAMINEWORD.

Comment gérer les utilisateurs et les groupes sur un système Linux Comment gérer les utilisateurs et les groupes sur un système Linux Sep 05, 2025 am 08:01 AM

Créer un utilisateur avec AddUser ou UserAdd, 2. Modifier l'utilisateur avec UserMod, 3. Supprimer l'utilisateur avec DeLuerger ou UserDel, 4. Créer un groupe avec GroupAdd, 5. Ajouter un utilisateur à Group avec UserMod-Ag, 6. Supprimer les informations avec GPASSWD-D à partir du groupe, 7. Comptes, définition des politiques de mot de passe et allouant raisonnablement les autorisations de groupe. En maîtrisant ces commandes principales et en sélectionnant des outils appropriés en fonction de la distribution, la gestion des utilisateurs et groupes Linux peut être réalisé efficacement.

Le système Huawei Harmonyos 6 annule le 'prochain' suffixe: ce sera Hongmeng natif à l'avenir Le système Huawei Harmonyos 6 annule le 'prochain' suffixe: ce sera Hongmeng natif à l'avenir Sep 24, 2025 pm 04:12 PM

Les dernières nouvelles du 18 septembre, Huawei HarmonyOS6 a lancé plusieurs cycles de version prévisibles pour les développeurs, et a récemment ouvert la qualification d'expérience à certains utilisateurs qui l'ont essayé pour la première fois. Selon les commentaires de l'utilisateur, le nom du système actuel n'affiche plus le suffixe "suivant", et il est officiellement renommé HarmonyOS6.0. Huawei a initialement proposé le nom HarmonyOsnext pour la première fois lors de la conférence des développeurs en août 2023, visant à marquer le système Hongmeng entrant dans une nouvelle étape de développement et réalisant le véritable développement auto-autonome indigène. La percée la plus principale de HarmonyOsNext est d'adopter complètement l'architecture du système sous-jacente développée indépendamment, de supprimer complètement le noyau Linux et le code AOSP Android, et d'exécuter uniquement des applications basées sur le noyau Harmonyos.

Comment prendre une capture d'écran sur Linux Comment prendre une capture d'écran sur Linux Sep 15, 2025 am 03:35 AM

TotakesCreenshotSonLinux: 1.USEPRTSCNKEYFORFULLSREEN, ALT PRTSCNFORACTIALWINDOW.2.UsegnomesReenshottoolFormoreOptions.3.Usegnome-ScreenshotCommandInterminal.4.InstalLanduscrotForlightWeARDCommand-linecapturing.

Comment trouver le chemin d'un programme dans Linux Comment trouver le chemin d'un programme dans Linux Sep 16, 2025 am 08:56 AM

TolocateAprogram'sinstallationPathonLinux, Utilisation: 1.Whichprogram_NameforquickPath-basés-basés sur la base.2.Harons de l'Isprogramme

See all articles