zoukankan      html  css  js  c++  java
  • gitlab + jenkins 持续集成

    一、概述

    GitLab是一个代码仓库,用来管理代码。Jenkins是一个自动化服务器,可以运行各种自动化构建、测试或部署任务。所以这两者结合起来,就可以实现开发者提交代码到GitLab,Jenkins以一定频率自动运行测试、构建和部署的任务,帮组开发团队更高效的集成和发布代码。

    下面是我最近安装GitLab+Jenkins环境的一个过程,记录下来,以备日后参考。

    另外,这篇文章虽然很长,讲得很琐碎,但是仍有未能描述清楚的地方,如果按照这篇文章未能搭建成功,请耐心分析,也可从官方文档 找找灵感,继续下去总会成功的。

    环境

    操作系统 ip地址 角色 访问地址
    ubuntu-16.04.4-server-amd64 192.168.10.122 Jenkins http://192.168.10.122:8080/
    ubuntu-16.04.4-server-amd64 192.168.10.134 GitLab http://192.168.10.134/

    Jenkins 安装教程,请参考链接:

    https://www.cnblogs.com/xiao987334176/p/11323795.html

    GitLab 安装教程,请参考链接:

    https://www.cnblogs.com/xiao987334176/p/11329018.html

    二、使用GitLab创建一个项目

    点击 Create a project

    创建 test 项目

    添加 README 文件

    输入内容,点击确定

     

    效果如下:

    创建jenkins用户

    点击扳手按钮

    点击 User

    添加 jenkins 用户,点击最下面的Create user按钮。

     点击编辑

    修改密码,这里我定义的是 jenkins@1234

    设置jenkins 用户ssh秘钥

     点击 Impersonate ,表示冒充jenkins 用户

    点击设置

    点击 ssh keys

    登录到jenkins服务器,生成秘钥

    ssh-keygen -t rsa -P "" -f ~/.ssh/id_rsa

    查看公钥

    cat /root/.ssh/id_rsa.pub

    将公钥内容复制到网页,点击添加秘钥

    创建Access Tokens

    点击左侧的Access Tokens,输入用户 jenkins,勾选权限,点击创建

    复制token,待会 jenkins 设置时,会用到。Zzis8ALsiYuytsg2GH-5

    点击退出

    重新登录root用户,点击test

    点击设置-成员

     

    添加jenkins 用户,这样就可以访问项目了

    三、 jenkins 安装和Git,GitLab插件

    由于 jenkins安装时,勾选了推荐安装的插件,因此包含了git插件。

    现在只需要安装gitlab插件即可

    点击 Manage Jenkins --> Manage Plugins -->可选插件,搜索gitlab

    勾选gitlab,点击直接安装

    等待十几分钟

    提示安装完成

    点击 Manage Jenkins --> Configure System -->配置 -->Gitlab

     

    Connection Name ”随便填,“Git Host URL”填GitLab的访问地址,然后点“Add”——“jenkins”,如下所示:

    选择gitlalb api,输入 jenkins 用户创建的token Zzis8ALsiYuytsg2GH-5

    选择 gitlab api token,点击测试连接,出现 Success,表示成功。

     点击最下面的保存

    配置Git插件

    点击 Manage Jenkins --> Configure System -->配置 -->Git plugin

     

    设置Git插件的全局配置,然后点击最下面的保存。

    四、创建一个Jenkins Job

    在jenkins里,一个任务叫做一个job。一般我们的项目会有多个分支,比如开发分支和产品分支,我们可以对每一个分支都新建一个job,比如,我们对开发分支创建一个测试的job,每次有代码提交就自动运行一次测试,对产品分支创建一个打包的job,每次有代码提交就运行打包任务。

    不过在这里,我们只是单纯的创建一个job,来演示jenkins自动运行任务的过程。

    首先,点击 新建Item,item name”可以随便起,然后点击“构建一个自由风格的软件项目”,点击Ok

    至此,创建一个Job成功了

    由于 jenkins 服务器的ssh秘钥,已经添加到gitlab上面了。那么就可以进行下一步了!

    配置Job的源码管理

    选择“源码管理”,选择“Git”,然后去GitLab中复制项目地址,粘贴到“Repository URL”,然后点击“credentials”后面的“Add”按钮

    类型,选择 SSH Username with private key

    Username 填 root

    PrivateKey 选择Enter directly,点击add

    登录到jenkins 服务器,查看私钥

    cat /root/.ssh/id_rsa

    将内容复制到网页上面,点击添加

    在“credentials”里选择我们刚刚创建的认证方式:root

     

    如果没报错,说明成功了,点击页面底部的“apply”。如果出错了,会在“Repository URL”和“Credentials”之间显示红色的错误信息。

    jenkins job默认对master分支进行构建,你也可以自定义分支。这要求你的Gitlab代码仓库中要存在这个分支,一般来说,就是要向代码仓库提交一次更改,请 自行完成(Gitlab项目刚创建时是空的,一个分支也没有,这样的话,自动构建时会出错)

    配置Job的构建触发器

    选择“构建触发器”,勾选“Pull SCM”,这个选项会每隔一段时间检查一下GitLab仓库中代码是否有更新,有的话就执行构建操作。日程表如何设置,在这个输入框下面有说明。

    扩展阅读:

    常见构建触发器、:

    • Build after other projects are built 当另一个构建任务完成之后触发
    • Build periodically 周期性的触发
    • Build when a change is pushed to GitLab. GitLab CI Service URL: http://191.8.2.112:12000/project/test-go-dev 当代码有更新的时候触发,通过GitLab CI
    • GitHub hook trigger for GITScm polling 通过Github钩子触发
    • Poll SCM 定期检查代码有无更新,有更新时触发

    这只是个人理解,具体怎么样大家可以试试,Poll SCM方式我是试过的。

    配置Job的构建脚本

    在build栏目里,选择“jenkins execute shell”,然后输入你项目的构建命令(这依赖于你的项目,如Maven的maven build,gulp的gulp xxx 等等)

    这里我输入一段测试命令,表示将git项目的代码复制到/tmp/test

    cp -r $WORKSPACE /tmp/test

    点击 可用的环境变量列表,就可以看到很多变量

    其中 WORKSPACE 表示,下载git项目后的路径。

    由于git项目为test,因此路径为:/var/lib/jenkins/workspace/test

    点击保存

    点击 Build Now,点击下面的构建过程

    点击控制台输出,就可以看到完整的cp命令

    登录到jenkins服务器,查看/tmp/test目录,是否有文件存在。

    复制代码
    root@ubuntu:~# ll /tmp/test/
    总用量 16
    drwxr-xr-x  3 jenkins jenkins 4096 8月  28 18:27 ./
    drwxrwxrwt 14 root    root    4096 8月  28 18:29 ../
    drwxr-xr-x  8 jenkins jenkins 4096 8月  28 18:27 .git/
    -rw-r--r--  1 jenkins jenkins   16 8月  28 18:27 README.md
  • 相关阅读:
    vue:自定义指令
    vue 声明周期
    组件之间的通信
    vue动态组件keepalive
    vuecli的使用
    数据结构线性表(C#) 天高地厚
    HOOK钩子函数 天高地厚
    OSI模型 天高地厚
    HTTP 天高地厚
    说说JSONP 天高地厚
  • 原文地址:https://www.cnblogs.com/yangxiaochu/p/11981164.html
Copyright © 2011-2022 走看看