图说jenkins pipeline处理前端项目--(3)将打包结果上传远程主机

上一篇

图说jenkins pipeline处理前端项目--(2)安装依赖与打包 - 掘金 (juejin.cn)

前置条件:让jenkins所在主机能免密登录远程主机

  1. jenkins所在主机生成ssh密钥对(生成时设置密码对文件加密),再将公钥上传到远程主机
  2. jenkins所在主机生成的ssh私钥,加入ssh-agent(目的是自动化处理时,不会被要求再次输入密码)

在jenkins所在主机执行如下命令

生成ssh密钥对

输入如下命令后,会要求你:

  1. 确认密钥对文件生成的目录(默认在~/.ssh/文件夹)

  2. 输入密钥对文件的保护密码(建议设置)

    ssh-keygen -t ed25519

此时会在~/.ssh/文件夹,生成: id_ed25519 和 id_ed25519.pub 两个文件

id_ed25519是私钥

id_ed25519.pub是公钥

将ssh私钥加入ssh-agent

启动ssh-agent

bash 复制代码
eval "$(ssh-agent -s)"

如果是新启动的ssh-agent服务(或者每次重启ssh-agent服务),里面都是没有ssh私钥的

将ssh私钥加入ssh-agent

javascript 复制代码
ssh-add ~/.ssh/id_ed25519

查看ssh-agent中所有私钥

csharp 复制代码
ssh-add -l

要删除已加载到ssh-agent中的特定私钥,可以使用ssh-add -d命令,并提供私钥的文件路径。

javascript 复制代码
ssh-add -d ~/.ssh/id_ed25519

如果你没有明确指定私钥文件路径,ssh-agent不会知道要移除哪个密钥。通常情况下,当你重启ssh-agent时,之前加载的所有密钥都会失效。

若想完全清除ssh-agent缓存并重新启动它,可以先杀掉现有的ssh-agent进程,然后重新启动 此时会让你输入一次密钥对创建时的那个密码

验证是否能免密登录远程主机

将打包结果上传远程主机

scp -r $WORKSPACE/dist root@myalpine2:/root/workspace/ 说明

$WORKSPACEjenkins内部的环境变量,表示当前job的工作目录

$WORKSPACE/dist是我要拷贝的目录

myalpine2是我远程服务器的ip,因为我用的是docker,并创建了network,所以用的是这个

root是我远程服务器的一个账号

/root/workspace/是我要拷贝到目标目录

查看远程主机是否有该文件夹

相关推荐
豆瓣鸡1 分钟前
Docker快速入门
运维·docker·容器
狗凯之家源码网4 分钟前
电商代付系统从零搭建与实战指南
前端·后端·开源
小雨下雨的雨8 分钟前
通过鸿蒙PC Electron框架技术完成-井字棋游戏 - 实现详解
前端·javascript·游戏·华为·electron·鸿蒙
meilindehuzi_a9 分钟前
掌握 ES6 核心语法与大模型(NLP)项目工程化搭建指南
前端·自然语言处理·es6
IT_陈寒17 分钟前
Vue组件通信这个坑我跳了两次才知道怎么爬出来
前端·人工智能·后端
smallswan23 分钟前
第十四 算数运算
linux·服务器·前端
AI_零食24 分钟前
甄嬛人物日志-朗读升级 - 鸿蒙PC Electron框架完整技术实现指南
前端·学习·华为·electron·鸿蒙·鸿蒙系统
HackTwoHub24 分钟前
WEB扫描器Invicti-Professional-V26.50.0(自动化爬虫扫描)更新
前端·人工智能·chrome·爬虫·web安全·网络安全·自动化
VX_1825 分钟前
Docker镜像直接部署JumpServer
运维·docker·容器
copyer_xyf26 分钟前
Python 文件基本操作
前端·后端·python