热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:Jenkins节点管理

本文由编程笔记#小编为大家整理,主要介绍了Jenkins节点管理相关的知识,希望对你有一定的参考价值。
本文由编程笔记#小编为大家整理,主要介绍了Jenkins节点管理相关的知识,希望对你有一定的参考价值。









点击关注,我们共同每天进步一点点!









我们在使用jenkins的时候,一般来说肯定是有slave节点的。任务一般是在slave上面运行的。当然不是讲master节点不能跑任务,master节点主要是处理调度构建作业,把构建分发到slave节点进行实际执行,监视slave节点的状态(必要时让它们进行上线或者离线),记录和发布构建产物。


主要常用的的连接slave节点的方式就是通过ssh和jnlp



  • ssh来说,我们一般用的服务器都是linux系统,当然最方便的就是通过ssh启动jenkins节点,但是这个有个前提的要求就是master和slave之前能进行ssh连接


  • jnlp连接方式有个好处就是不用master和slave之间能够ssh连接,只需要能够ping即可。并且如果slave的机器是windows的话,也是可以的这个其实是非常实用的,因为有时候,可能一些权限或者防火墙的原因,这master和slave真的不能够ssh连接,还有一些未知的原因无法ssh到slave节点(我下面说的公司这个例子就是这样),都可以通过jnlp的方式进行连接。



Ssh方式连接slave


必须有slave机器的账号才行,但不要求必须是root账号。
这种方式的前提是需要安装SSH Slaves plugin插件。
这种方式的步骤如下:


1、输入slave节点的IP。


2、Add Credentials:


有如下两种方式:


  1)通过Username with password方式


  需要知道slave机器的用户名和密码


  2)通过SSH Username with private key方式


  需要先在master机器上生成ssh key pair。生成的 public key放到slave机器的 ~/.ssh/authorized_keys里面。然后chmod 600 ~/.ssh/authorized_keys。
  然后,添加连接slave的credential,


这两种方式的Scope选项,我选择的是System,表示这个Credentials仅仅是用来master和node进行连接用的。还有另外一种是“Global(Jenkins、nodes、items、child items)”,这种scope的Credential可以用来连接git等其他机器。具体选择哪种scope,根据自己的需要。就连接slave这个需求来说,哪种scope的credential都可以。
Username填写在master上生成key pair时使用的用户名。
Private key选择From the jenkins master ~/.ssh


Jenkins的SSH Credentials Plugin插件,可以集中管理这些ssh 的key。安装完这个插件,可以在Jenkins上看到这样的页面


这个页面可以对credentials进行添加、删除、修改等操作。在这里设置的credentials在jenkins的其他需要credentials的地方,可以通过下拉菜单选择使用,比如添加slave时,可以直接在Credentials下拉菜单里选择对应的credential就行


Jenkins节点管理


还有git clone代码时:


此时一定要把在master上生成的 public key添加到github账号的的Profile setting页面里的SSH Keys Settings中。




用户密码方式


Jenkins节点管理


Jenkins节点管理


Jenkins节点管理


Jenkins节点管理


Jenkins节点管理


ssh bug


下线重连就好了


<===[JENKINS REMOTING CAPACITY]===>ERROR: Unexpected error in launching a agent. This is probably a bug in Jenkins.
java.lang.IllegalStateException: Already connected
        at hudson.slaves.SlaveComputer.setChannel(SlaveComputer.java:594)
        at hudson.slaves.SlaveComputer.setChannel(SlaveComputer.java:432)
        at hudson.plugins.sshslaves.SSHLauncher.startAgent(SSHLauncher.java:607)
        at hudson.plugins.sshslaves.SSHLauncher.access$400(SSHLauncher.java:113)
        at hudson.plugins.sshslaves.SSHLauncher$1.call(SSHLauncher.java:441)
        at hudson.plugins.sshslaves.SSHLauncher$1.call(SSHLauncher.java:406)
        at java.util.concurrent.FutureTask.run(FutureTask.java:266)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
        at java.lang.Thread.run(Thread.java:745)
[06/26/19 16:36:45] Launch failed - cleaning up connection
[06/26/19 16:36:45] [SSH] 连接关闭。

私钥方式


记住是私钥,不是公钥,cat .ssh/id_rsa


Jenkins节点管理


-----BEGIN RSA PRIVATE KEY-----
MIIEpAIBAAKCAQEAzOx9ORYwSAKdyRBRsfD85MmXv3PurJoST1nJE4QqumygHcsU
HnkQp6NfDjCiJKJjXRpxDijvoQGa+xMpJySbiL5LzFlEWk17RX+fs3ztEk7ot8l9
jWKoTDWUsD7zMKXTTllKO6bOivvyUPPWqhgZ4Cuu29Fsxq2chU4Wg63eq2b7wKbg
rFgDkL9XMqVMtxxTbhyXjBRFkHtIWIFOSeDBlfuvfW3odDZh3sfUqTjdPAPGlQUA
K9eIplaQkVyN33FZ3eXwr5ylLBca1aCM7WKRVVOuZKFrv4Uqb6WB454ln7jlmz2r
MYaD4nk1IXcBjXGAshpAVd/IBC5nEJgpPeZFVwIDAQABAoIBAEkzCKAFrwVp+dbC
f4wiWxOWdyAqV01MU9IIbm0MPv8Moj1CN1OTR0G6d8/ny2NupjOxqES4lrBalHOv
KnoS94PnBche8q2XE7uFlRRWQZDSowpTbQe+AAQI963lLpVoBozsFDouoYS/7pTA
JSPpLAUJVZKrwkFN7qUneZ9b0jhDEsri5rSSI5xzMIYKMcNm2ZMpVzVCTQhRgPo2
LzGz76boTzFBXZ3y5QM1LPG3rbpRWE1vXSpvx6Q2onG7VdWGz6fwlEQC6KjksrKP
UymevpzD+RBuWC5JAlZ1Q6XBRVJdqE+p6pTobkdHGDGy/WeI5JUTYBC9oGnyvIi4
PFeQu9ECgYEA+p717KJtWfmXlbCYlSC7C5AFwQc7vkKPVeCdKNLXW13VB7Ke8yuo
u5Vl1Z4vvBZNqmCn0kK07vJMnIjSbQ/BTPefQ0NikZWQ8/eBZ8THNgti2aEpaH9R
r1juqScahgWbS8ARrFuGBHo/rkz/jOML66jhkYBtSW6ZgPWJuL7ExsUCgYEA0VJx
7O+6U1i/o6mbQKhJH92ITPc28UM4jAywUY7it3Bhulf1Ldlr05SSvruMtiHwFVmz
kC3jIUKA5wQfwJz70glVLPfLchg/eCBj+ejJztxLiDBTxAlmt74ptkGtNdZ9oQ8i
hcr3x7GnCmAT/wmkSPgTNJhz0OO20MP6xAvFfWsCgYEA+lh5ffROWVdKBVwPPsAg
N4+ZP9Vy5z3jojwpoRLjzr+vQe46etu8xAybWcSXGEILOMsuOIkr5Zgh0SeXUxwu
0ix0aaNRPe3yitFM8ZQODr1W89/Z1imANjEWzd9izkehdgyZWttdxvE61WjSyTAv
wyrCkC6CfJy/N6ON+/6L36UCgYEAhsWifH9NZGR73xBQ2ayAiHfGTmfNhEFXozR4
QcrRxnIhOi1vuvmGJ1A9u3hd/NaVEeoTZv1khAGhpRxOpWFt8an4oV9aKjfaham1
NS7g4MOODj2vcUTsUdmqWaKnt0ZG1PA9tg8cwgJsHo4F0euPTzwKgY624wP6rSfB
yYAaw8kCgYAJ4NKVWy3Zy4iPeUE+h1paQQEgJpqwpeMPnEXn5RJ/FN1bwseTIa3n
ZqN9toDLdNH8w0qnhUiAqqa5qrkREbvYPb9QSYt7pi3iV7nOsw2o0BDqT+AusdLz
A37TQC2jih/YyMJ1eepmTtJN9T4LmtsuZLa43817MAkgu9geRqzdJg==
-----END RSA PRIVATE KEY-----

复制节点


在节点环境配置好之后,我们再添加节点就可以复制了,修改IP和其他自定义配置即可。


Jenkins节点管理


JNLP方式连接salve (回头补上)


不需要master必须能够ssh连接到slave,只需要两者能够ping通即可。


job调用节点



  • 限制项目运行的节点

    Jenkins节点管理


  • 参数选择node或label



并发构建


需要安装Node and Label parameter plugin插件


需要配置node类型参数



  • 如果两个都配置,node参数优先生效



label方式


Jenkins节点管理


Jenkins节点管理


Jenkins节点管理


node方式


可能是我配置的问题,看起来像是并发构建了


Jenkins节点管理


Jenkins节点管理



Jenkins节点管理





原文地址:


https://www.cnblogs.com/wangxu01/articles/11103423.html








Jenkins节点管理




喜欢请关注,有用请转发~












升职、加薪、无漏测-点“在看”












推荐阅读
  • Docker安全策略与管理
    本文探讨了Docker的安全挑战、核心安全特性及其管理策略,旨在帮助读者深入理解Docker安全机制,并提供实用的安全管理建议。 ... [详细]
  • 调试利器SSH隧道
    在开发微信公众号或小程序的时候,由于微信平台规则的限制,部分接口需要通过线上域名才能正常访问。但我们一般都会在本地开发,因为这能快速的看到 ... [详细]
  • 本文详细介绍了如何搭建一个高可用的MongoDB集群,包括环境准备、用户配置、目录创建、MongoDB安装、配置文件设置、集群组件部署等步骤。特别关注分片、读写分离及负载均衡的实现。 ... [详细]
  • 本文通过分析一个具体的案例,探讨了64位Linux系统对32位应用程序的兼容性问题。案例涉及OpenVPN客户端在64位系统上的异常行为,通过逐步排查和代码测试,最终定位到了与TUN/TAP设备相关的系统调用兼容性问题。 ... [详细]
  • 本文详细介绍了如何在ARM架构的目标设备上部署SSH服务端,包括必要的软件包下载、交叉编译过程以及最终的服务配置与测试。适合嵌入式开发人员和系统集成工程师参考。 ... [详细]
  • 在 Ubuntu 22.04 LTS 上部署 Jira 敏捷项目管理工具
    Jira 敏捷项目管理工具专为软件开发团队设计,旨在以高效、有序的方式管理项目、问题和任务。该工具提供了灵活且可定制的工作流程,能够根据项目需求进行调整。本文将详细介绍如何在 Ubuntu 22.04 LTS 上安装和配置 Jira。 ... [详细]
  • Vulnhub DC3 实战记录与分析
    本文记录了在 Vulnhub DC3 靶机上的渗透测试过程,包括漏洞利用、内核提权等关键步骤,并总结了实战经验和教训。 ... [详细]
  • Node.js在服务器上的多种部署策略
    本文探讨了Node.js应用程序在服务器上部署的几种有效方法,包括使用Screen、PM2以及通过宝塔面板进行简易管理。 ... [详细]
  • 对于初学者而言,搭建一个高效稳定的 Python 开发环境是入门的关键一步。本文将详细介绍如何利用 Anaconda 和 Jupyter Notebook 来构建一个既易于管理又功能强大的开发环境。 ... [详细]
  • CentOS下ProFTPD的安装与配置指南
    本文详细介绍在CentOS操作系统上安装和配置ProFTPD服务的方法,包括基本配置、安全设置及高级功能的启用。 ... [详细]
  • 本文详细介绍了在Linux操作系统上安装和部署MySQL数据库的过程,包括必要的环境准备、安装步骤、配置优化及安全设置等内容。 ... [详细]
  • 网络安全实验:Telnet与SSH服务对比及抓包分析
    本实验旨在对比Telnet和SSH两种安全通信协议的服务差异,并通过搭建服务器和使用Wireshark抓包工具进行详细分析。 ... [详细]
  • 本文详细介绍了在 Ubuntu 系统上安装和配置 MySQL、Tomcat 和 JDK 的步骤。通过本文,您将了解如何顺利安装这些组件,并确保它们能够正常协同工作。 ... [详细]
  • 本文详细介绍了如何在 CentOS 7 及其衍生发行版(如 Red Hat, Oracle, Scientific Linux 7)上安装和完全卸载 GitLab。包括安装必要的依赖关系、配置防火墙、安装 GitLab 软件包以及常见问题的解决方法。 ... [详细]
  • 本文节选自《NLTK基础教程——用NLTK和Python库构建机器学习应用》一书的第1章第1.2节,作者Nitin Hardeniya。本文将带领读者快速了解Python的基础知识,为后续的机器学习应用打下坚实的基础。 ... [详细]
author-avatar
hjp1993
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有