使用ssh打通服务器之间免密登录以及两个服务器之间文件cp脚本上加密码

使用ssh打通服务器之间免密登录以及文件cp

环境:腾讯云服务器 A:服务器是使用ssh命令的服务器 ,B:服务器是有文件的服务器想要跳转到的服务器

1、免密跳转验证

跳转B服务器命令

ssh root@172.21.16.2

输入完上面的命令之后,会提示你输入密码,此时输入密码即可正常进入。(默认端口是22)

第一步:在 A 的./root/.ssh/目录下,有两个文件:id_rsa.pub和id_rsa。前者是当前服务器当前用户的公钥,后者是当前服务器当前用户的私钥。如果没有,则使用如下命令生成密钥对:

ssh-keygen -t rsa

运行上面的命令以后,系统会出现一系列提示,可以一路回车。

第二步:密钥传到远程服务器的命令
ssh-copy-id -i ~/.ssh/id_rsa.pub {B服务器账号}@{B服务器内网ip}

ssh-copy-id -i ~/.ssh/id_rsa.pub root@172.21.16.2

第三步:验证是否免密
ssh {B服务器账号}@{B服务器内网ip}

ssh root@172.21.16.2

在这里插入图片描述
验证成功!

2、复制功能

假如A、B都有SSH服务,现在在A的SSH里
(一)从A复制到B (推过去)
scp -rp /{路径}/{文件名称} {B服务器账号}@{B服务器内网ip}: /{路径}

scp -rp /path/test.sh root@172.21.16.2:/path

(二)从B复制到A (拉过来)
scp -rp {B服务器账号}@{B服务器内网ip}: /{路径}/{文件名称} /{路径}

scp -rp root@172.21.16.2:/path/test.sh /path

(三)脚本使用:
cp B服务器的一个jar包 到A服务器 脚本上可以加上B服务器的密码
123456 是密码

yum -y install expect
source /etc/profile
expect -c "
spawn scp -r root@172.21.16.2:/var/lib/jenkins/workspace/k8s-dataapi/target/d-dataApi-1.0-SNAPSHOT.jar /home/harbor/images/dataApi
expect {
    \"*assword\" 
                {
                    set timeout 300; 
                    send \"123456\r\";
                }
    \"yes/no\" 
                {
                    send \"yes\r\"; exp_continue;}
                }
expect eof"
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酸菜鱼(szy)

如果给您提供帮助的话可以打赏哦

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值