【Shell 命令集合 文件管理】Linux ssh 远程主机之间复制文件 scp 命令使用教程

简介: 【Shell 命令集合 文件管理】Linux ssh 远程主机之间复制文件 scp 命令使用教程


描述

scp命令是Linux中用于在远程主机之间复制文件的命令。它的全称是"secure copy",可以通过SSH协议进行安全的文件传输。

scp命令的基本语法如下:

scp [选项] [源文件] [目标地址]

常用的选项有:

  • -r:递归复制目录及其内容。
  • -P:指定远程主机的端口号。
  • -i:指定用于身份验证的私钥文件。
  • -v:显示详细的调试信息。

源文件可以是本地文件或远程主机上的文件。目标地址可以是本地目录或远程主机上的目录。

下面是一些常见的用法示例:

  1. 从本地复制文件到远程主机:
scp localfile.txt user@remotehost:/path/to/destination

这个命令将localfile.txt文件复制到远程主机remotehost上的/path/to/destination目录。

  1. 从远程主机复制文件到本地:
scp user@remotehost:/path/to/file.txt .

这个命令将远程主机remotehost上的/path/to/file.txt文件复制到当前目录。

  1. 递归复制整个目录:
scp -r user@remotehost:/path/to/directory .

这个命令将远程主机remotehost上的/path/to/directory目录及其内容递归地复制到当前目录。

scp命令使用SSH协议进行传输,因此需要远程主机支持SSH服务。它提供了安全的文件传输功能,可以在不同的主机之间方便地复制文件。


语法格式

scp [参数] [源文件] [目标地址]

参数说明

  • -r:递归复制整个目录。
  • -P:指定端口号。
  • -i:指定私钥文件进行身份验证。
  • -v:显示详细的调试信息。

错误情况

  • 如果源文件不存在,则会显示No such file or directory错误。
  • 如果目标地址不存在,则会显示No such file or directory错误。
  • 如果没有足够的权限访问源文件或目标地址,则会显示Permission denied错误。

注意事项

使用Linux Shell的scp命令时,有一些注意事项需要注意:

  1. 确保目标地址的正确性:在使用scp命令时,目标地址可以是本地文件系统的路径,也可以是远程主机的地址。如果是远程主机的地址,需要确保目标主机的IP地址或域名正确,并且具有正确的访问权限。
  2. 确保源文件的存在:在使用scp命令时,需要确保源文件存在于指定的路径中。如果源文件不存在,scp命令将会报错并退出。
  3. 使用递归复制目录:如果要复制整个目录,需要使用-r参数进行递归复制。否则,scp命令将只复制单个文件。
  4. 指定端口号:如果目标主机的SSH服务监听在非默认的端口上,需要使用-P参数指定端口号。例如,scp -P 2222 file.txt user@remote:/path/to/destination
  5. 使用私钥进行身份验证:如果目标主机需要使用私钥进行身份验证,可以使用-i参数指定私钥文件的路径。例如,scp -i ~/.ssh/id_rsa file.txt user@remote:/path/to/destination
  6. 显示调试信息:如果需要查看详细的调试信息,可以使用-v参数。例如,scp -v file.txt user@remote:/path/to/destination
  7. 注意文件权限:在复制文件时,需要确保目标主机上的目录和文件具有正确的权限。如果没有足够的权限,可能会导致复制失败。
  8. 注意文件名中的特殊字符:如果源文件或目标地址中包含特殊字符,如空格、引号等,需要使用引号或转义字符来正确处理。例如,scp "file name.txt" user@remote:"/path/with\ spaces"
  9. 注意网络连接稳定性:在进行文件传输时,需要确保网络连接的稳定性,以避免传输中断或出现错误。
  10. 注意文件大小:在复制大文件时,需要确保目标主机的磁盘空间足够,以避免复制失败或导致目标主机磁盘空间不足的情况。

总之,在使用scp命令时,需要仔细检查命令的参数和路径,并确保网络连接稳定,以确保文件能够安全、准确地传输到目标地址。


底层实现

Linux Shell的scp命令底层是通过SSH协议进行文件传输的。具体来说,scp命令使用了ssh命令进行身份验证和加密通信,并使用SSH的SFTP子系统进行文件传输。

在执行scp命令时,首先会通过SSH协议建立与目标主机的安全连接。这个过程涉及到身份验证和密钥交换,确保通信的安全性。

一旦建立了安全连接,scp命令会在本地和远程主机之间创建SFTP会话。SFTP(SSH File Transfer Protocol)是SSH协议的一个子系统,用于进行文件传输和管理。

在SFTP会话中,scp命令使用SFTP的put和get命令来实现文件的上传和下载。具体来说,当使用scp命令将本地文件复制到远程主机时,它会调用SFTP的put命令将文件从本地发送到远程主机。而当使用scp命令从远程主机复制文件到本地时,它会调用SFTP的get命令从远程主机获取文件并保存到本地。

在文件传输过程中,scp命令使用SSH协议提供的加密和数据完整性保护功能,确保传输的安全性。它还可以利用SSH的压缩功能来加快文件传输速度。

总之,scp命令通过SSH协议和SFTP子系统实现了安全的文件传输功能。它提供了简单而有效的方式来在本地主机和远程主机之间复制文件。


示例

示例一

从本地复制文件到远程主机的指定目录:

scp localfile.txt user@remotehost:/path/to/destination

这个命令将本地的localfile.txt文件复制到远程主机remotehost上的/path/to/destination目录。

示例二

从远程主机复制文件到本地:

scp user@remotehost:/path/to/file.txt .

这个命令将远程主机remotehost上的/path/to/file.txt文件复制到当前目录。

示例三

复制整个目录到远程主机:

scp -r /path/to/directory user@remotehost:/path/to/destination

这个命令将本地的/path/to/directory目录及其内容递归地复制到远程主机remotehost上的/path/to/destination目录。

示例四

从远程主机复制文件到指定本地目录:

scp user@remotehost:/path/to/file.txt /path/to/local/destination

这个命令将远程主机remotehost上的/path/to/file.txt文件复制到本地的/path/to/local/destination目录。

示例五

指定端口号进行文件复制:

scp -P 2222 user@remotehost:/path/to/file.txt .

这个命令将远程主机remotehost上的/path/to/file.txt文件复制到当前目录,同时使用端口号2222进行连接。

示例六

使用私钥文件进行身份验证:

scp -i private_key.pem user@remotehost:/path/to/file.txt .

这个命令将远程主机remotehost上的/path/to/file.txt文件复制到当前目录,同时使用private_key.pem私钥文件进行身份验证。

示例七

显示详细的调试信息:

scp -v user@remotehost:/path/to/file.txt .
• 1

这个命令将远程主机remotehost上的/path/to/file.txt文件复制到当前目录,并显示详细的调试信息。



结语

在我们的探索过程中,我们已经深入了解了Shell命令的强大功能和广泛应用。然而,学习这些技术只是开始。真正的力量来自于你如何将它们融入到你的日常工作中,以提高效率和生产力。

心理学告诉我们,学习是一个持续且积极参与的过程。所以,我鼓励你不仅要阅读和理解这些命令,还要动手实践它们。尝试创建自己的命令,逐步掌握Shell编程,使其成为你日常工作的一部分。

同时,请记住分享是学习过程中非常重要的一环。如果你发现本博客对你有帮助,请不吝点赞并留下评论。分享你自己在使用Shell命令时遇到的问题或者有趣的经验,可以帮助更多人从中学习。

此外,我也欢迎你收藏本博客,并随时回来查阅。因为复习和反复实践也是巩固知识、提高技能的关键。

最后,请记住:每个人都可以通过持续学习和实践成为Shell编程专家。我期待看到你在这个旅途中取得更大进步!

目录
相关文章
|
5月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
535 9
|
5月前
|
算法 Linux Shell
Linux实用技能:打包压缩、热键、Shell与权限管理
本文详解Linux打包压缩技巧、常用命令与原理,涵盖.zip与.tgz格式操作、跨系统传文件方法、Shell运行机制及权限管理,助你高效使用Linux系统。
Linux实用技能:打包压缩、热键、Shell与权限管理
|
5月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
522 2
|
7月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
890 1
|
9月前
|
Linux Shell
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
275 4
|
9月前
|
Linux Shell 数据安全/隐私保护
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
521 3
|
10月前
|
Linux Shell
shell_42:Linux参数移动
总的来说,参数移动是Linux shell脚本中的一个重要概念,掌握它可以帮助我们更好地处理和管理脚本中的参数。希望这个解释能帮助你理解和使用参数移动。
230 18
|
8月前
|
Shell
Shell脚本循环控制:shift、continue、break、exit指令
使用这些命令可以让你的Shell脚本像有生命一样动起来。正确使用它们,你的脚本就能像一场精心编排的舞蹈剧目,既有旋律的起伏,也有节奏的跳跃,最终以一场惊艳的表演结束。每一个动作、每一个转折点,都准确、优雅地完成所需要表达的逻辑。如此,你的脚本不只是冰冷的代码,它透过终端的界面,跳着有节奏的舞蹈,走进观众——使用者的心中。
321 60
|
11月前
|
关系型数据库 MySQL Shell
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
|
5月前
|
数据采集 监控 Shell
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
Shell脚本利用curl/wget发起请求,结合文本处理工具构建轻量级爬虫,支持并行加速、定时任务、增量抓取及分布式部署。通过随机UA、异常重试等优化提升稳定性,适用于日志监控、价格追踪等场景。相比Python,具备启动快、资源占用低的优势,适合嵌入式或老旧服务器环境,复杂任务可结合Python实现混合编程。