scp命令

本文介绍了如何使用SCP命令在本地与远程服务器间进行文件传输。包括从本地复制文件到远程服务器、从远程服务器获取文件到本地的方法,并解释了如何保持源主机文件属性不变。此外,还详细说明了通过SSH密钥实现免密码登录的过程。

scp

使用 scp 在远程机器上 copy 档案
例如:
copy 本地的档案到远程的机器上

scp -r /ITC/www-root/10.10.129.**:/ITC/

回车后输入 10.10.129.**的登录密码并回车

开始复制.

实现了

从本机复制 /ITC/www-root/目录下所有内容到 10.10.129.**/ITC/ 目录下的功能.

辅助资料:

scp
使用 scp 在远程机器上 copy 档案
例如:
copy 本地的档案到远程的机器上
scp /etc/lilo.conf k@net67.ee.oit.edu.tw:/home/k
会将本地的 /etc/lilo.conf 这个档案 copy 到 net67.ee.oit.edu.tw,使用者 k 的家目录下。
copy远程机器上的档案到本地来
scp k@net67.ee.oit.edu.tw:/etc/lilo.conf /etc
会将 net67.ee.oitdu.tw 中 /etc/lilo.conf 档案 copy 到本地的 /etc 目录下。
保持从来源 host 档案的属性
scp –p k@net67.ee.tw:/etc/lilo.conf /etc
在此必须注意使用者的权限是否可读取远程上的档案,若想知道更多关于 scp 的使用方法,可去看看 scp 的使用手册。
ssh-keygen
产生公开钥 (pulib key) 和私人钥 (private key),以保障 ssh 联机的安性, 当 ssh 连 shd 服务器,会交换公开钥上,系统会检查 /etc/ssh_know_hosts 内储存的 key,如果找到客户端就用这个 key 产生一个随机产生的session key 传给服务器,两端都用这个 key 来继续完成 ssh 剩下来的阶段。

它会产生 identity.pub、identity 两个档案,私人钥存放于identity,公开钥 存放于 identity.pub 中,接下来使用 scp 将 identity.pub copy 到远程机器的家目录下.ssh下的authorized_keys。 .ssh/authorized_keys(这个 authorized_keys 档案相当于协议的 rhosts 档案), 之后使用者能够不用密码去登入。RSA的认证绝对是比 rhosts 认证更来的安全可靠。
执行:
scp identity.pub k@linux1.ee.oit.edu.tw:.ssh/authorized_keys

若在使用 ssh-keygen 产生钥匙对时没有输入密码,则如上所示不需输入密码即可从 net67.ee.oit.edu.tw 去登入 linux1.ee.oit.edu.tw。在此,这里输入的密码可以跟帐号的密码不同,也可以不输入密码。
### SCP命令的基本使用方法 SCP(Secure Copy Protocol)是一种基于SSH协议的安全文件传输工具,允许用户在本地与远程主机之间或两个远程主机之间复制文件。其基本语法如下: ``` $ scp [option] /path/to/source/file user@server-ip:/path/to/destination/directory ``` 其中,`/path/to/source/file` 是源文件的路径,`user` 是远程服务器上的目标账户,`server-ip` 是远程服务器的主机名或IP地址,`/path/to/destination/directory` 是远程服务器上的目标目录路径。此命令支持多种选项,如`-P`指定端口号、`-r`递归复制整个目录等[^1]。 ### SCP命令的使用示例 1. **将本地文件复制到远程服务器**: 假设需要将本地当前目录下的`123.txt`文件复制到IP地址为`192.168.0.100`的远程服务器上,目标账户为`user`,目标目录为`/home/user/`,可以使用以下命令: ``` $ scp 123.txt user@192.168.0.100:/home/user/ ``` 执行该命令后,系统会提示输入`user`账户的密码[^3]。 2. **从远程服务器下载文件到本地**: 如果需要从远程服务器`192.168.0.100`上的`/home/user/`目录下载`123.txt`文件到本地的`d:\xxx\`目录,可以使用以下命令: ``` $ scp user@192.168.0.100:/home/user/123.txt d:\xxx\ ``` 同样,执行此命令时也会要求输入`user`账户的密码[^3]。 3. **使用特定端口进行文件传输**: 若远程服务器的SSH服务不在默认端口(22),而是在其他端口(例如2222),则可以使用`-P`选项指定端口号: ``` $ scp -P 2222 123.txt user@192.168.0.100:/home/user/ ``` ### 安全性和加密 SCP命令通过SSH协议进行数据传输,这意味着所有传输的数据都会被加密,从而保证了传输过程的安全性。这种加密特性使得SCP成为跨网络传输敏感数据时的理想选择[^2]。 ### 相关问题 1. 如何使用SCP命令在两台远程服务器之间复制文件? 2. SCP命令支持哪些常用的选项,它们的作用分别是什么? 3. 在使用SCP命令时遇到连接超时的问题,应该如何解决? 4. 如何通过SCP命令同时复制多个文件或整个目录? 5. 使用SCP命令时,如何避免每次都需要手动输入密码?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值