当前位置: 首页 > news >正文

运维技术教程之Jenkins的秘钥设置

在Jenkins中使用SSH密钥时,不需要直接将私钥文件传递到Jenkins服务器,而是通过Jenkins的凭证管理功能安全地存储和使用私钥。以下是关键步骤和注意事项:


1. 生成SSH密钥对

  • 在Jenkins服务器(或任意客户端)上生成密钥对
    ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
    
    • 私钥默认保存在 ~/.ssh/id_rsa,公钥在 ~/.ssh/id_rsa.pub
    • 无需以Jenkins用户身份生成密钥,但需确保Jenkins运行用户(如jenkins)有权限读取私钥文件(如果选择文件存储方式)。

2. 部署公钥到目标服务器

  • 将公钥内容添加到目标服务器的 ~/.ssh/authorized_keys 文件中:
    echo "ssh-rsa AAA... your_public_key" >> ~/.ssh/authorized_keys
    chmod 600 ~/.ssh/authorized_keys
    

3. 在Jenkins中配置私钥

  • 通过“Credentials”插件管理私钥
    1. 安装插件:确保Jenkins已安装 CredentialsSSH Agent 插件。
    2. 添加凭证:
      • 进入 Manage JenkinsManage CredentialsSystemGlobal credentials
      • 点击 Add Credentials,选择类型 SSH Username with private key
      • 输入:
        • Username:目标服务器的用户名(如rootdeploy)。
        • Private Key:直接粘贴私钥内容(非文件路径),若私钥有密码则填写Passphrase
      • 保存后,凭证将安全存储在Jenkins中。

4. 在Job中使用SSH凭证

  • 配置构建任务
    • 在Job的构建步骤中,选择 Execute shellSSH Agent
    • 若使用 SSH Agent,需指定之前添加的凭证ID(如 ssh-deploy-key),并在脚本中通过 ssh 命令执行远程操作。

为什么不需要直接传递私钥文件?

  1. 安全性风险
    • 直接传递私钥文件可能导致权限泄露(如Jenkins运行用户无关权限)。
    • 私钥可能被其他系统用户或进程访问。
  2. Jenkins设计理念
    • Jenkins通过 Credentials插件 统一管理敏感信息(如私钥、密码),避免明文存储。
    • 私钥以加密形式存储在Jenkins内部,仅在任务执行时临时加载到内存。

常见问题与解决方案

  • 问题1:Jenkins提示输入私钥密码

    • 原因:私钥被加密(有Passphrase),但未在凭证配置中填写密码。
    • 解决:在凭证配置的 Passphrase 字段中输入密码。
  • 问题2:无法连接目标服务器

    • 检查
      • 公钥是否正确部署到目标服务器的 authorized_keys
      • 目标服务器的SSH端口、用户名是否正确。
      • Jenkins凭证是否选择正确的ID。

总结

  • 正确流程:生成密钥对 → 部署公钥到目标服务器 → 在Jenkins凭证中添加私钥 → 在Job中使用凭证。
  • 核心原则:私钥应通过Jenkins的凭证管理功能配置,而非直接传递文件,以确保安全性和可维护性。

参考文档:Jenkins Official SSH Plugin Documentation


文章转载自:
http://balladize.kjawz.cn
http://bisulphite.kjawz.cn
http://blinkered.kjawz.cn
http://cecum.kjawz.cn
http://adrenocortical.kjawz.cn
http://arsenism.kjawz.cn
http://byplot.kjawz.cn
http://barbuda.kjawz.cn
http://ashram.kjawz.cn
http://albany.kjawz.cn
http://bellwaver.kjawz.cn
http://canaanite.kjawz.cn
http://adonize.kjawz.cn
http://airfreighter.kjawz.cn
http://adcraft.kjawz.cn
http://cesspipe.kjawz.cn
http://brachiopoda.kjawz.cn
http://broomie.kjawz.cn
http://attu.kjawz.cn
http://chivalrous.kjawz.cn
http://chicory.kjawz.cn
http://behaviorism.kjawz.cn
http://augustly.kjawz.cn
http://breathless.kjawz.cn
http://angelical.kjawz.cn
http://affreightment.kjawz.cn
http://chordamesoderm.kjawz.cn
http://archaeornis.kjawz.cn
http://caramba.kjawz.cn
http://capeskin.kjawz.cn
http://www.dtcms.com/a/280584.html

相关文章:

  • TP商城登录系统测试报告
  • Python Fabric库详解:从入门到自动化运维实战
  • C++ Boost Aiso TCP 网络聊天(服务端客户端一体化)
  • 【论文阅读 | PR 2024 |ITFuse:一种用于红外与可见光图像融合的交互式 Transformer】
  • 第三章 OB SQL 引擎高级技术
  • 【网络安全】大型语言模型(LLMs)及其应用的红队演练指南
  • 【Git】详解git commit --amend用法以及使用遇到的问题
  • Vue 2 和 Vue 3 中,组件的封装、二次开发和优化
  • Sersync和Rsync部署
  • Keil 5下载的时候提示“No J-Link found”
  • 《恋与深空》中龙和蛇分别是谁的代表
  • 25、企业能源管理(Energy):锚定双碳目标,从分类管控到智能优化的数字化转型之路
  • flutter弹窗:fluttertoast
  • HTTP 性能优化实战:突破高并发瓶颈的工业级方案
  • elasticsearch 下载/安装
  • 飞睿UWB超宽带定位测距技术,数字钥匙重塑智能生活,高精度厘米级定位无感解锁
  • ffmpeg音视频处理大纲
  • HR数字化转型:3大痛点解决方案与效率突破指南
  • QT 中各种坑
  • 基于Scikit-learn的机器学习建模与SHAP解释分析
  • 如何解决 Spring Boot 使用 Maven 打包后运行失败的问题(附详细排查步骤)
  • [雨云教程]端口冲突该如何解决
  • 前端报错:“Uncaught SyntaxError: missing ) after argument list
  • 【学习笔记】条件变量+互斥锁解决问题
  • 快速排序:原理、示例与 C 语言实现详解
  • 区块链的三种共识机制——PoW、PoS和DPoS原理
  • [面试] js 数组面试题
  • LangChain智能体开发实战:从零构建企业级AI助手
  • Ubuntu18.04 系统重装记录
  • Flutter 入门指南:从基础到实战