色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

基于Python的Jenkins的二次開(kāi)發(fā)操作

瀏覽:2日期:2022-07-25 18:03:03

背景

最近我們?cè)谡粋€(gè)云執(zhí)行的平臺(tái),底層用的是Jenkins來(lái)做執(zhí)行引擎,方便的把我們的腳本做一個(gè)統(tǒng)一的調(diào)度。

Jenkins確實(shí)是一個(gè)非常方便的框架,它提供了一整套的RESTful的API,可以非常方便的做二次開(kāi)發(fā),而且提供了一個(gè)python的庫(kù),操作起來(lái)就更加方便了。

常用的Jenkins概念

我們?cè)谑褂肑enkins的時(shí)候,一般看到的都是Jenkins的View。

也就是說(shuō)我們看到的基本上都是一些視圖。

每一個(gè)構(gòu)建的內(nèi)容,無(wú)論是執(zhí)行用例,跑腳本,還是打包編譯發(fā)布,都是一個(gè)job。

每一個(gè)job都有一個(gè)對(duì)應(yīng)的name,如果這個(gè)job被放在某個(gè)文件夾了,那么name就是文件夾名+job名。在查看job信息的時(shí)候,會(huì)返回一個(gè)full_name字段,指的就是這個(gè)了。

PythonSDK

pip install python-jenkins執(zhí)行這條命令就可以安裝SDK了。

官網(wǎng):https://pypi.org/project/python-jenkins/

說(shuō)明文檔:http://python-jenkins.readthedocs.io/en/latest/

說(shuō)明文檔都是英文的,如果有興趣,看這塊當(dāng)然最好,不過(guò)這個(gè)SDK實(shí)際上非常非常的簡(jiǎn)單,如果直接去看源代碼,也是沒(méi)問(wèn)題的,我在開(kāi)發(fā)的過(guò)程中,基本上都是去看源碼來(lái)寫的,SDK里面函數(shù)命名比較直白,不用深刻理解也能夠正常的去使用。

這里列一些比較常用的方法,也是我這次開(kāi)發(fā)的時(shí)候用到的一些,我按照我自己寫的過(guò)程中,一步一步的寫出來(lái)。

開(kāi)發(fā)過(guò)程

job信息查詢

在Jenkins中,每一個(gè)構(gòu)建都是一個(gè)job,所以,我們做開(kāi)發(fā)的時(shí)候,要在頁(yè)面上展示歷史的構(gòu)建信息,因此,要能夠拿到歷史執(zhí)行job的信息。因此我們要使用get_job_info這個(gè)方法。

def get_job_info(self, name, depth=0, fetch_all_builds=False): ’’’Get job information dictionary. :param name: Job name, ``str`` :param depth: JSON depth, ``int`` :param fetch_all_builds: If true, all builds will be retrieved from Jenkins. Otherwise, Jenkins will only return the most recent 100 builds. This comes at the expense of an additional API call which may return significant amounts of data. ``bool`` :returns: dictionary of job information ’’’

這里的name參數(shù)指的是job的名字,比如我新建了一個(gè)叫自動(dòng)化測(cè)試這么個(gè)job,那么這個(gè)name傳的就是自動(dòng)化測(cè)試,如果我把這個(gè)job放到了某個(gè)文件夾中,那么name這個(gè)參數(shù)需要傳文件夾名/自動(dòng)化測(cè)試。

這里有一個(gè)坑,在Python2.7版本中傳遞這個(gè)name,如果以變量的形式傳遞過(guò)去,會(huì)有一個(gè)報(bào)錯(cuò),規(guī)避的方法是name.encode(’utf-8’)做一下編碼的處理。返回的參數(shù)是這些:

在builds字段里面就存有所有的歷史構(gòu)建數(shù)據(jù)。在property這個(gè)字段中放有Jenkins構(gòu)建時(shí)的各種參數(shù)。

構(gòu)建日志

拿到了構(gòu)建數(shù)據(jù),我們需要在頁(yè)面上展示出來(lái),如果能在頁(yè)面上直接看日志就更方便了,因此要把每次的構(gòu)建日志拿出來(lái),需要調(diào)用get_build_console_output這個(gè)方法。

def get_build_console_output(self, name, number): ’’’Get build console text. :param name: Job name, ``str`` :param number: Build number, ``int`` :returns: Build console output, ``str`` ’’’

這里可以拿到Jenkins的構(gòu)建日志,返回的就是一個(gè)字符串了。需要注意的是,如果你想要構(gòu)建的時(shí)候也展示構(gòu)建日志,只需要在構(gòu)建的時(shí)候調(diào)用這個(gè)方法就行,會(huì)返回調(diào)用時(shí)候構(gòu)建的日志,用socket或者輪詢的方式都可以實(shí)現(xiàn)實(shí)時(shí)日志的展示。

執(zhí)行構(gòu)建

執(zhí)行構(gòu)建當(dāng)然是非常關(guān)鍵的一步,我們可以使用build_job這個(gè)方法來(lái)執(zhí)行構(gòu)建。

def build_job(self, name, parameters=None, token=None): ’’’Trigger build job. This method returns a queue item number that you can pass to :meth:`Jenkins.get_queue_item`. Note that this queue number is only valid for about five minutes after the job completes, so you should get/poll the queue information as soon as possible to determine the job’s URL. :param name: name of job :param parameters: parameters for job, or ``None``, ``dict`` :param token: Jenkins API token :returns: ``int`` queue item ’’’

這里的name參數(shù)跟job信息查詢的參數(shù)一樣,也會(huì)有編碼的問(wèn)題。parameters字段傳入的是一個(gè)字典類型,也就是在頁(yè)面上點(diǎn)擊構(gòu)建的時(shí)候,需要填入的參數(shù)。token參數(shù)在Jenkins這個(gè)類初始化的時(shí)候就已經(jīng)有了,所以一般來(lái)說(shuō)無(wú)需傳入。這個(gè)方法會(huì)返回一個(gè)queue_item的編號(hào),這個(gè)就是Jenkins的構(gòu)建編號(hào),這個(gè)編號(hào)可以做一些其他數(shù)據(jù)的查詢,比如構(gòu)建狀態(tài),取消構(gòu)建等操作,在SDK里面都有對(duì)應(yīng)的方法。

注意:絕對(duì)不行用這個(gè)來(lái)查詢是否處于構(gòu)建中,這個(gè)編號(hào)在一定時(shí)間內(nèi)會(huì)出現(xiàn)失效的情況,如果構(gòu)建時(shí)間過(guò)長(zhǎng),會(huì)導(dǎo)致查詢不到結(jié)果而報(bào)錯(cuò),實(shí)際上job依然處于構(gòu)建中

這些方法使用起來(lái)比較方便,但是有一些局限性,我們?nèi)绻跇?gòu)建的時(shí)候用了第三方插件,這些方法是沒(méi)辦法拿到第三方插件的結(jié)果的,比如我們這里用RobotFramework的插件來(lái)處理了結(jié)果,用這些方法是沒(méi)辦法拿到結(jié)果的。

從原理入手

Jenkins對(duì)外提供的是一個(gè)RESTful的接口,那么Python的SDK做的動(dòng)作實(shí)際上就是去請(qǐng)求這個(gè)接口,只不過(guò)做了一些包裝,保證了易用性,很多方法的核心,都會(huì)用到j(luò)enkins_request,比如:

response = self.jenkins_request(requests.Request(’POST’, self.build_job_url(name, parameters, token)))

有興趣的可以自己去讀一讀源碼,整個(gè)SDK實(shí)際上就是基于requests這個(gè)庫(kù)做了一下包裝,然后最終都是通過(guò)jenkins_request去請(qǐng)求RESTful的API。我們進(jìn)入jenkins的頁(yè)面,在右下角能看到一個(gè)這樣的東西。

有這個(gè)標(biāo)記的頁(yè)面,就是有接口的,那么這個(gè)接口是怎么拿的呢?

從源碼里面可以找到答案,很多方法里面都有這么樣一個(gè)東西。

self.jenkins_open(requests.Request(’GET’, self._build_url(INFO),auth=auth), add_crumb=False, resolve_auth=False)response = self.jenkins_open(requests.Request(’GET’, self._build_url(BUILD_INFO,locals())))

在最上方的配置中可以找到:

INFO = ’api/json’

也就是說(shuō),在我們看到頁(yè)面的后方加上/api/json就可以拿到數(shù)據(jù)了。

所有的操作都在這個(gè)數(shù)據(jù)的背后了,也就是說(shuō)只要寫好這個(gè)url的拼接規(guī)則,就能很簡(jiǎn)單的去做二次開(kāi)發(fā)了。

當(dāng)然,在開(kāi)發(fā)的過(guò)程中,也是有很多坑的,比如拿歷史數(shù)據(jù)的時(shí)候,接口竟然不返回歷史構(gòu)建的狀態(tài)。。。。

總結(jié)

整個(gè)開(kāi)發(fā)過(guò)程下來(lái)還算比較順利,由于源碼比較簡(jiǎn)單的原因,基本上遇到問(wèn)題都能通過(guò)看源碼來(lái)解決,但是比較大的問(wèn)題就是返回結(jié)果的枚舉沒(méi)有一個(gè)地方列出來(lái),所以導(dǎo)致開(kāi)發(fā)完成后經(jīng)常有地方需要修修補(bǔ)補(bǔ)。

以上這篇基于Python的Jenkins的二次開(kāi)發(fā)操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 美女网站免费观看视频 | 久久久国产精品福利免费 | 九九精品视频在线观看 | 色怡红院 | 欧美大片a一级毛片视频 | 亚洲高清中文字幕一区二区三区 | 国内自拍小视频 | 欧美成人免费观看国产 | 成人夜色视频网站在线观看 | 国产美女又黄又爽又色视频免费 | 九九精品国产兔费观看久久 | 天天se天天cao综合网蜜芽 | 玖玖精品视频在线观看 | 亚洲深夜视频 | 免费国产高清精品一区在线 | 国产精品二区三区 | 久久亚洲国产高清 | 黄色一级网址 | 欧美 亚洲 丝袜 清纯 中文 | 特级毛片免费观看视频 | 国产三级久久久精品三级 | 日韩欧美成人乱码一在线 | 国产免费人成在线看视频 | 欧美色成人tv在线播放 | 亚洲第一视频在线播放 | 精品一区视频 | 欧美一级毛片免费大片 | 成人国产第一区在线观看 | 深夜做爰性大片中文 | 国产高清视频免费观看 | 日韩一区二区三 | 色偷偷亚洲偷自拍 | 成人美女网 | 一区二区三区中文国产亚洲 | 国产精品成久久久久三级 | 一区二区三区网站在线免费线观看 | 亚洲精品日韩一区二区 | 日本精品视频一视频高清 | 欧美一区二区三区男人的天堂 | 一本色道久久99一综合 | 久久久久久尹人网香蕉 |