获取jenkins中的构建数据

背景

搭建效能看板,需要获取jenkins中一些job的数据作为数据源输入。

使用node配合jenkins库进行数据获取,jenkins库为:https://www.npmjs.com/package/jenkins

安装:npm i jenkins

准备工作

使用Jenkins获取数据需要知道Jenkins的URL,以及用户名和apiToken。

Jenkins中每个用于构建和测试代码的项目被称为Job,它是 Jenkins 的基本执行单元。

想要同时获取多个job中的数据,可以通过View将Job分类。Jenkins View 是一个逻辑分组工具,用于对 Job 进行分类和管理。随着 Jenkins 中 Job 数量的增加,View 可以帮助用户更清晰地组织和查找任务。

这里我们将需要统计的Job都放到View1中。

代码

javascript 复制代码
const jenkinsApi = require('jenkins');
const moment = require('moment');

async function getJobBuildHistory({
    jenkinsUrl,
    viewName,
    username,
    apiToken,
    startTime,
    endTime
}) {

    const jenkins = new jenkinsApi({ baseUrl: `http://${username}:${apiToken}@${jenkinsUrl}`, crumbIssuer: true });

    const end = endTime ? moment(endTime) : moment();
    const start = startTime ? moment(startTime) : end.clone().subtract(1, 'days');
    const startTs = start.valueOf();
    const endTs = end.valueOf();

    try {
        const view = await jenkins.view.get(viewName);
        const jobs = view.jobs.map(job => job.name);

        const buildHistory = [];

        for (const jobName of jobs) {

            try {
                const builds = await jenkins.job.get(jobName, { depth: 1 });

                for (const build of builds.builds) {
                    const buildInfo = await jenkins.build.get(jobName, build.number);
                    const buildTs = moment(buildInfo.timestamp).valueOf();

                    if (buildTs < startTs) {
                        break;
                    }
                    if (buildTs > endTs) continue;

                    buildHistory.push({
                        jobName,
                        buildNumber: build.number,
                        startTime: moment(buildInfo.timestamp).format('YYYY/MM/DD-HH:mm:ss'),
                        duration: Math.round(buildInfo.duration / 1000),
                        status: buildInfo.result || 'RUNNING',
                        triggeredBy: buildInfo.actions.find(a => a?.causes)?.causes[0]?.shortDescription?.replace('Started by ', '') || 'UNKNOWN'
                    });
                }
            } catch (e) {
                console.error(`  Job processing failed: ${e.message}`);
            }
        }
        return buildHistory;
    } catch (e) {
        throw new Error(`View error: ${e.message}`);
    }
}

exports.getCiData = async (req, res) => {
    const { startTime, endTime } = req.body;
    try {
        const history = await getJobBuildHistory({
            jenkinsUrl: 'your jenkins url,
            viewName: 'View1',
            username: 'your username',
            apiToken: 'your token',
            startTime,
            endTime
        });

        return res.success(history, 200, '查询成功');
    } catch (error) {
        return res.server_error(error);
    }
};
相关推荐
Bdygsl5 小时前
Node.js(1)—— Node.js介绍与入门
node.js
Java 码农6 小时前
nodejs koa留言板案例开发
前端·javascript·npm·node.js
胡gh7 小时前
浏览器:我要用缓存!服务器:你缓存过期了!怎么把数据挽留住,这是个问题。
前端·面试·node.js
ccnocare10 小时前
Node.js ZIP 安装
node.js
码上有料15 小时前
Node.js中XLSX库的实践使用指南
node.js
前端老鹰16 小时前
Node.js 网页解析神器:cheerio 模块实战指南,像 jQuery 一样玩转 HTML
后端·node.js
Hilaku16 小时前
前端需要掌握多少Node.js?
前端·javascript·node.js
前端工作日常16 小时前
我的 SSR 测试 入门之旅
前端·node.js
前端双越老师18 小时前
【干货】Nodejs + Deepseek 开发 MCP Server 和 Client 踩坑记录
人工智能·node.js·deepseek
叫我阿柒啊1 天前
Java全栈工程师面试实战:从基础到微服务的深度解析
java·redis·微服务·node.js·vue3·全栈开发·电商平台