美文网首页
使用Jenkins进行Python项目的持续集成

使用Jenkins进行Python项目的持续集成

作者: 樊海鹏 | 来源:发表于2018-08-24 15:43 被阅读0次

    谈到持续集成,最常用的工具无非就是三个:

    一个是TravisCI

    一个是CircleCI

    一个是Jenkins。前两个是网站,可以非常便利地与Github相集成,但都有数量限制,最后一个是开源软件,可以下载安装成供自己使用的工具,想做几个做几个。

    所谓持续集成,听起来似乎很时尚,但其本质无非就是三件事:

    从代码库git中拉取代码、编译、部署。如果你想尝试Jenkins,可以通过Docker安装,然后集成到你自己的git仓库上

    持续集成(CI)对于软件工程来说非常重要,它的意义在于产品快速迭代的同时,还能够让代码保持高质量,所以编写高质量的单元测试代码也显得十分重要。Travis可以免费做开源软件的持续集成,但是对于闭源软件来说,它的费用非常高昂。另外一款持续集成软件叫Jenkins,它是Java实现的一款开源持续集成工具,对于Java程序的持续集成支持特别好,网上也有很多这方面的文章。

    本文主要讲述怎么运用它来做Python 项目的持续集成。

    这里假设大家都比较熟悉Git开发流程了。

    这里所讲的工作流是Git+Jenkins。首先,我们在持续集成服务器上安装JDK1.8、Git和Python3(非Python项目无需安装),并且把Python3设置为默认Python解释器。

    由于篇幅限制,这里就不展开讲了。然后我们通过pip3 install virtualenv安装虚拟环境,安装虚拟环境的目的是,在进行持续集成测试的时候,各个项目构建使用不同的虚拟环境,因为项目不同可能相同依赖的版本会有冲突。

    然后,在Jenkins官网上下载Jenkins并将其安装到持续集成服务器上。可以直接下载.war文件,通过java -jar jenkins.war启动。我用的是CentOS,直接使用它自带的包管理器yum安装。首先,需要添加jenkins源,可以在官网相关页面查看

    > sudo wget -O /etc/yum.repos.d/jenkins.repo [https://pkg.jenkins.io/redhat-stable/jenkins.repo](https://link.jianshu.com?t=https://pkg.jenkins.io/redhat-stable/jenkins.repo)
    
    > sudo rpm --import [https://pkg.jenkins.io/redhat-stable/jenkins.io.key](https://link.jianshu.com?t=https://pkg.jenkins.io/redhat-stable/jenkins.io.key)
    
    

    然后便可以使用yum install jenkins安装了。安装完成后,我们通过

    sudo service jenkins start
    

    这个时候输入http://your_jenkins_ip:8080/便可以进入jenkins初始化页面,如下图

    Image text

    图中提示了密码所在文件,通过

    cat /var/lib/jenkins/secrets/initialAdminPassword
    

    可查询到密码,将其填入密码框即可。

    之后,Jenkins会提示我们安装插件,我们选择自定义安装。除了它默认勾选安装的插件之外,我们还需要安装Cobertura Plugin、JUnit Plugin,前者是和代码覆盖率相关的插件,后者是单元测试相关插件,其他暂时不用安装,然后我们点击install进行安装。在安装进度条走完之后,Jenkins会让我们填入登录用户的用户名和密码,提示如下图

    填入之后,我们便可以使用刚才创建的用户登入系统了。
    除了在这个时候可以创建用户,还可以使用超级管理员账号(账号为admin,密码可以通过cat /var/lib/jenkins/secrets/initialAdminPassword查看)来创建普通用户,操作路径是Jenkins主页=>系统管理=>管理用户=>新建用户。

    还可以通过让用户自行注册的方式来添加用户,不过这个功能默认是关闭的,需要通过Jenkins主页=>系统管理=>Configure Global Security=>勾选允许用户注册来开启该功能,这个时候所有用户都具有读写权限,如果Jenkins暴露在公网,会很不安全。

    我们需要为不同用户设置不同权限,目前Jenkins支持5种访问控制策略,我们通过Jenkins主页=>系统管理=>Configure Global Security=>授权策略选择其中的一种,它们的区别,由于篇幅有限,就不赘述了,

    推荐选择安全矩阵策略,在添加用户/组添加需要进行访问控制的用户和用户组。如下是我的设置:
    !()[https://img.haomeiwen.com/i1514374/46d0a1776c4ad652.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/2210/format/webp]

    如果我们想进行Python程序的持续集成,还可能需要安装Python Plugin(很奇怪的是,我在CentOS服务器上不安装它也可以进行持续集成,而在我的MacBook上不安装却无法进行Python项目持续集成,所以为了保险起见,还是安装吧),

    它的安装路径是Jenkins 主页=>系统管理=>插件管理=>可选插件=>Python Plugin。

    除此之外,这个时候还可以安装Violations plugin,它的作用是分析代码行数。

    该插件依赖sloccount,因此我们这时候可以通过yum install sloccount安装。

    安装完成后,勾选空闲时重启Jenkins。重启之后,我们便可以进行项目构建和持续集成测试了。

    首先讲公开项目的持续集成。

    公开项目的持续集成,操作比较简单。我们首先通过下面的目录结构创建一个Python程序

    py_jenkins/
        readme.md
        .gitignore
        tests/
            __init__.py
            auth_tests.py
        py_jenkins/
            __init__.py
            auth.py
    
    

    该程序放在github上,引用的这篇博客的代码,我改成了Python3的语法。

    进入正题,我们点击新建开始创建项目,这里我命名为py_jenkins,选择“构建一个自由风格的软件项目”,如下图

    https://www.jianshu.com/p/caa136e191cd

    http://mainframer.github.io/articles/Python%E6%8C%81%E7%BB%AD%E9%9B%86%E6%88%90.html

    相关文章

      网友评论

          本文标题:使用Jenkins进行Python项目的持续集成

          本文链接:https://www.haomeiwen.com/subject/hjabiftx.html