Linux命令-安全复制命令:scp

scp是有Security的文件copy,基于ssh登录。操作起来比较方便,比如要把当前一个文件copy到远程另外一台主机上。

命令格式:

scp [可选参数] 源文件 目标文件

scp 本地文件  远程目录或文件
scp [-P 端口] /home/dir/full.tar.gz root@远程机器IP地址:/home/root

端口要在前。

还支持把文件从远程主机copy到当前系统,也很简单。

scp 远程目录或文件  本地文件
scp 远程机器IP地址:/home/root/full.tar.gz home/daisy/full.tar.gz

如果想使用自动登录需要首先创建加密证书文件,如下操作:

cd ~/.ssh  进入ssh目录
ls -la
ssh-keygen -t rsa  生成密钥文件
ls -la

做信任连接远程机器:

ssh-copy-id -i ~/.ssh/id_rsa.pub root@远程机器IP地址   需要输入用户密码

在远程机器上操作下面命令查看是否已经将证书copy到root用户下面了

ls ~/.ssh/authorized_keys   查看文件是否存在
cat /root/.ssh/authorized_keys   查看文件内容

查看远程机器默认证书文件名称

vi /etc/ssh/sshd_config
查找AuthorizedKeysFile字符串:/AuthorizedKeysFile .ssh/authorized_keys

回到本地计算机的.ssh目录

cd ~/.ssh
pwd

vi config 编辑config文件,这个文件名是固定的

编写下面的内容

Host vemysql
Hostname 远程机器IP地址
Port 22
User root
IdentityFile ~/.ssh/id_rsa

等同于windows远程连接计算机后,记住用户名和密码

 修改config文件的权限

chmod 600 config   或 chmod go-r config

cd .. 向上一级目录,即回到.ssh目录
ls -la  查看~/.ssh目录权限是否为700

本机登录远程机器

ssh -v vemysql -v表示登录并显示登陆过程的信息

接下来本地的用户和机器名就已经切换到远程了。例如:ifconfig 就可以看到远程机器的IP地址了。

exit 退出登录远程机器,回到本机

使用后台命令执行scp操作。

nohup scp 本地文件 vemysql:远程目录 >> 本地日志文件 &
tail -f 本地日志文件  查看日志文件

 

posted @   —八戒—  阅读(1889)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示