配置Jenkins的slave agent并使用它完成构建任务

上一章,使用单机配置并运行了一个简单的maven项目,并发布到了一个服务器上启动。这一章将要配置一个slave agent,并将上一章的job放到agent上执行。我们agent使用的是ssh的方式

前置步骤

准备两台虚拟机:

192.168.233.32(使用用户名+密码方式登录ssh)

192.168.233.34(使用私钥方式登录ssh)

两台虚拟机都安装并配置好Git、Java、Maven

两台虚拟机都创建好一个用户组jenkins、用户jenkins、用户对应的home 目录 /data/jenkins,并赋予home目录权限

sudo chown -R jenkins:jenksins /data/jenkins

1、安装ssh agent插件

2、配置服务器的Credentials(两种方式都可以)

2.1、使用的简单的账号+密码的方式(很简单,不需要额外配置)

 

 2.2、使用私钥的方式
2.2.1、在Master机器登录jenkins账户,并使用ssh-keygen生产秘钥对
sudo su jenkins -s /bin/bash  #切换到jenkins账户
cd ~ #进入jenkins账户的根目录
ssh-keygen -t rsa #生成秘钥对,一路回车即可

Master的jenkins账户是在我们安装Jenkins的时候就自动创建好的,不需要我们自己去创建,这个账号没有设置密码,不能直接使用 su jenkins登录。

2.2.2、将上一步骤中生成的公钥推送到agent服务器
ssh-copy-id jenkins@192.168.233.34 #指定登录agent使用的账户是我们自己创建的jenkins

第一步会生成一个秘钥对保存在 /var/lib/jenkins/.ssh,本步骤是将生成的公钥id_rsa.pub推到agent机器的jenkins账户的home目录下保存起来(/data/jenkins/.ssh/authorized_keys里)。

可以查看authorized_keys里包含了id_rsa.pub的内容。

2.2.3、配置对应的Credentials

在Private key中,将生成的私钥id_rsa的内容全部拷贝过来,包括“BEGIN OPENSSH PRIVATE KEY”、“END OPENSSH PRIVATE KEY” 这两行。保存就可以了。

3、添加agent node

 

Credentials选择2中配置的Credentials

一定要记得指定好java home和maven home,不然后期执行任务的时候会找不到

这里记得要在目标机器上创建对应的用户(jenkins)、用户组 (jenkins),并赋予这个用户工作目录权限(/data/jenkins)。

这里记录下创建完用户的各种问题:

a、没有权限

sudo chown jenkins:jenkins /data/jenkins/

b、登录的时候什么都没有

创建用户的时候指定的登录脚本有问题,指定了 /bin/sh,应该要 /bin/bash

点击保存就可以了。

4、build之前的job

build之前最好将Build-In Node的Executors设置为0,以免job运行到到Build-In Node上

已经导agent上去build了 

好的,这里我给您举个例子。 假设我们的 Jenkins 主节点已经部署在 Kubernetes 集群中,并且已经安装了 Kubernetes 插件。现在我们需要创建一个 Jenkins Slave Pod,使其能够在 Kubernetes 集群中运行构建任务。 1. 创建一个 Jenkins Agent 镜像 首先,我们需要创建一个 Jenkins Slave 镜像。可以使用 Dockerfile 来定义该镜像,例如: ``` FROM jenkins/inbound-agent:4.6-1-jdk11 USER root RUN apt-get update && \ apt-get install -y maven && \ apt-get clean && \ rm -rf /var/lib/apt/lists/* USER jenkins ``` 这个 Dockerfile 基于 `jenkins/inbound-agent:4.6-1-jdk11` 镜像,安装了 Maven,然后切换回 Jenkins 用户。 2. 创建一个 Kubernetes Pod Template 接下来,我们需要创建一个 Kubernetes Pod 模板,该模板将用于创建 Jenkins Slave Pod。 在 Jenkins 界面中,点击 "Manage Jenkins" -> "Configure System",然后在 "Cloud" 部分下找到 "Kubernetes" 并点击 "Add Pod Template"。 在 "Pod Template" 页面中,可以配置 Pod 的基本信息,例如 Pod 名称、标签、容器名称、镜像名称等。 此外,还可以在 "Containers" 部分下添加容器。在这个例子中,我们只需要添加一个容器,名称为 "jnlp",镜像为我们之前创建的 Jenkins Slave 镜像。 ``` Name: jenkins-slave Labels: jenkins-slave Namespace: default Service Account: default Node Selector: <none> Working Dir: /home/jenkins/agent Containers: jnlp: Name: jnlp Docker Image: <your-jenkins-slave-image> Command to run: - /bin/sh - -c - > cat > /root/.kube/config <<EOF apiVersion: v1 kind: Config clusters: - name: cluster-name cluster: server: https://kubernetes.default.svc.cluster.local certificate-authority-data: <your-ca-data> contexts: - name: context-name context: cluster: cluster-name user: <your-user> namespace: <your-namespace> current-context: context-name EOF /usr/local/bin/jenkins-agent TTY Enabled: true Always Pull Image: true Working Dir: /home/jenkins/agent ``` 上述配置中,我们在容器中执行了一个命令,用于配置 Kubernetes API 访问信息,然后启动 Jenkins Agent。 3. 创建 Jenkins Slave Pod 完成 Pod 模板的配置之后,我们可以在 Jenkins 界面中使用该模板来创建 Jenkins Slave Pod。 在 Jenkins 界面中,点击 "New Item" -> "Freestyle project",然后在 "General" 页面中勾选 "Restrict where this project can be run",并在 "Label Expression" 中输入 "jenkins-slave"。 保存配置后,当我们触发构建任务时,Jenkins 将会自动创建一个 Jenkins Slave Pod,并将该任务分配给该 Pod 运行。 以上就是在 Jenkins使用 Kubernetes 动态创建 Jenkins Slave Pod 的具体步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值