scp 指令详细介绍

目录

[1. 基本语法](#1. 基本语法)

[2. 例子](#2. 例子)

从本地到远程

从远程到本地

从远程到远程

使用端口和指定私钥

递归复制目录

[3. 注意事项](#3. 注意事项)

如何拷贝文件的软链接


SCP(Secure Copy Protocol)是一种用于在计算机之间安全地传输文件的协议。它通过加密的方式在网络上安全地复制文件。SCP基于SSH(Secure Shell)协议,因此它提供了加密的连接和身份验证,确保数据在传输过程中的安全性。

下面是SCP指令的详细介绍:

1. 基本语法

复制代码
scp [选项] 源文件/目录 目标路径
  • 选项:
    • -r:递归复制,用于复制目录。
    • -P:指定SSH端口号。
    • -i:指定身份文件(私钥文件)。
    • -v:详细模式,显示详细的调试信息。

2. 例子

从本地到远程
复制代码
scp localfile.txt user@remote:/path/to/destination/
从远程到本地
复制代码
scp user@remote:/path/to/file.txt /local/destination/
从远程到远程
复制代码
scp user1@remote1:/path/to/sourcefile.txt user2@remote2:/path/to/destination/
使用端口和指定私钥
复制代码
scp -P 2222 -i /path/to/private_key.pem localfile.txt user@remote:/path/to/destination/
递归复制目录
复制代码
scp -r sourcedir user@remote:/path/to/destination/

3. 注意事项

  • 如果目标路径是目录,文件将会被复制到该目录中。
  • 如果目标路径包含文件名,文件将被复制并重命名为指定的文件名。
  • 使用递归选项 -r 可以复制整个目录及其内容。
  • 如果目标路径中包含空格,应该使用引号将其括起来。
  • 要连接到非标准SSH端口,可以使用 -P 选项。
  • 使用 -i 选项可以指定用于身份验证的私钥文件。

以上是基本的SCP指令用法,具体使用时,请根据你的实际情况调整参数。

如何拷贝文件的软链接

在SCP命令中,主要用于控制文件复制行为的参数是有限的,通常用来控制连接的选项、递归复制等。对于软链接(Symbolic Link)的处理,SCP默认会将软链接解析为实际文件进行传输,而不是复制软链接本身。

在传输软链接时,实际上会将链接指向的文件复制到目标位置,而不会在目标位置创建一个新的软链接。这是SCP默认的行为,因此目标位置会包含原始文件的内容而不是软链接。

如果你想要保留软链接的形式,可以使用rsync命令,它具有更多的灵活性,并且可以通过一些参数来控制软链接的处理。以下是一个例子:

复制代码
rsync -avl source/ user@remote:/path/to/destination/

这里的参数含义是:

  • -a:递归复制并保持文件属性。
  • -v:详细模式,显示详细的调试信息。
  • -L:保留软链接的形式,而不是复制链接指向的文件。

请注意,rsync可能需要在系统中安装,你可以使用系统包管理器安装它,例如在Ubuntu上使用sudo apt-get install rsync

相关推荐
KoiHeng2 小时前
操作系统简要知识
linux·笔记
Johny_Zhao5 小时前
Docker + CentOS 部署 Zookeeper 集群 + Kubernetes Operator 自动化运维方案
linux·网络安全·docker·信息安全·zookeeper·kubernetes·云计算·系统运维
小毛驴8506 小时前
Linux 后台启动java jar 程序 nohup java -jar
java·linux·jar
好好学习啊天天向上7 小时前
世上最全:ubuntu 上及天河超算上源码编译llvm遇到的坑,cmake,ninja完整过程
linux·运维·ubuntu·自动性能优化
tan180°8 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
典学长编程8 小时前
Linux操作系统从入门到精通!第二天(命令行)
linux·运维·chrome
wuk9988 小时前
基于MATLAB编制的锂离子电池伪二维模型
linux·windows·github
snoopyfly~11 小时前
Ubuntu 24.04 LTS 服务器配置:安装 JDK、Nginx、Redis。
java·服务器·ubuntu
独行soc11 小时前
#渗透测试#批量漏洞挖掘#HSC Mailinspector 任意文件读取漏洞(CVE-2024-34470)
linux·科技·安全·网络安全·面试·渗透测试
BD_Marathon11 小时前
Ubuntu下Tomcat的配置
linux·ubuntu·tomcat