我有一个托管的Jenkins服务器,我试图从那里获取使用Jenkins REST API的所有作业的构建详细信息(如结果,时间戳,持续时间等),然后将其保存在数据库中。
现在,我正在从Java代码中调用以下API,以获取所有作业(约200个作业):
https://<JENKINS_HOST>/api/json
然后,我使用以下方法获取作业详细信息和每个作业的所有内部版本:
https://<JENKINS_HOST>/job/MY_JOB/api/json
然后,最后,对于每个构建(我只需要获取最近的50个),我必须调用它来获取构建详细信息:
https://<JENKINS_HOST>/job/MY_JOB/<BUILD_NUMBER>/api/json
因此,总共约有50 * 200 + 201 =超过10000个API调用。
我猜,这么多的API调用会使Jenkins服务器的执行速度变慢吗?
所以,我的问题是,有没有更快/更好的方法来执行此操作,这样我就不必进行太多的API调用了?
类似这样的地方,我可以使用一个URL来获取所有构建详细信息,如下所示: (假设)
https://<JENKINS_HOST>/job/MY_JOB/api/json?fetchAllbuildDetails=True
答案 0 :(得分:3)
以防万一其他人陷入困境,我可以使用树来完成此任务:
https://<JENKINS_HOST>/api/json?tree=jobs[name,url,builds[number,result,duration,url]]
这里,可以对列名进行过滤,以仅获取所需的数据,因为从中返回的数据量很大。
您还可以像这样限制要获取的记录数:
https://<JENKINS_HOST>/api/json?tree=jobs[name,url,builds[number,result,duration,url]{0,50}]
这将仅获取所有工作的最后50个版本,这正是我所需要的。