CentOS服务器之间免密登录和传输文件

使用过 Jenkins 的同学都知道,Jenkins 会在远程服务器上执行一些命令,如:cd /home/wwwroot/ && git pull,这时候就需要在 Jenkins 服务器上配置免密登录,以及在远程服务器上配置免密登录,这样才能实现 Jenkins 服务器和远程服务器之间的静默文件传输、执行脚本发版等操作。

一、场景需要

  • 服务器A:CentOS_168,假如IP为:1.1.1.1
  • 服务器B:CentOS_192,假如IP为:2.2.2.2

要求实现: CentOS_168 向 CentOS_192 通过ssh免密登陆、scp传输文件

二、操作步骤

2.1、登陆服务器A,执行命令生成密钥对

1). 生成秘钥

shell 复制代码
ssh-keygen

该命令一直按回车(Enter)即可,默认生成位置一般是:~/.ssh/

如果用户是非 root 一般位置是:/home/你的当前用户名/.ssh/

shell 复制代码
# 进入当前用户的根目录
cd ~
# 查看隐藏文件
ll -a
# or
ls -a

2). 进入该路径

shell 复制代码
cd ~/.ssh/

2.2、下载生成的公钥文件:id_rsa.pub

找到 id_rsa.pub 这个文件,现将这个文件下载到本地

shell 复制代码
sz id_rsa.pub

2.3、登陆服务器B

1). 登陆服务器B,进入 /root/.ssh 目录,如果没有该目录,就创建一个

shell 复制代码
cd /root/.ssh

# or
mkdir /root/.ssh

2). 上传步骤2.2下载到本地的 id_rsa.pub 文件到服务器B的 /root/.ssh 目录下

shell 复制代码
rz

3). 在服务器B的 /root/.ssh 目录下创建一个 authorized_keys 文件

shell 复制代码
touch authorized_keys

此时该目录下应该有 id_rsa.pubauthorized_keys 两个文件

4). 将公钥文件 id_rsa.pub 追加到 authorized_keys 文件中

shell 复制代码
cat id_rsa.pub >> authorized_keys

注意: 尽量不要复制粘贴 id_rsa.pub 的内容,因为有可能会出现乱码,导致免密登录失败。建议使用 cat 命令追加到 authorized_keys 文件中。

三、测试

登录服务器A,以下命令都是在服务器A中执行。

  1. 免密登录,如果能够免密登录服务器B,则表示配置成功。
shell 复制代码
ssh root@2.2.2.2
  1. 免密传输文件
shell 复制代码
# 新建一个测试文件
touch /root/test.txt

# 传输文件
scp /root/test.txt root@2.2.2.2:/root/test.txt
# 可以修改文件名
scp /root/test.txt root@2.2.2.2:/root/01.txt
  1. 免密执行命令
shell 复制代码
ssh root@2.2.2.2 "nginx -t"
# 执行脚本
ssh root@2.2.2.2 "sh /root/01.sh"

欢迎访问:天问博客

相关推荐
chlk12319 小时前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑20 小时前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件20 小时前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
xy1230621 小时前
OpenStack Train 部署实战(三)控制节点--keystone服务
centos·openstack
深紫色的三北六号1 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash1 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI2 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行3 天前
Linux和window共享文件夹
linux
木心月转码ing3 天前
WSL+Cpp开发环境配置
linux
埃博拉酱4 天前
VS Code Remote SSH 连接 Windows 服务器卡在"下载 VS Code 服务器":prcdn DNS 解析失败的诊断与 BITS 断点续传
windows·ssh·visual studio code