Jenkins——持续集成概念与部署gitlab

一、持续集成(CI)

1.1 流程


1.提交:流程的第一步,是开发者向代码仓库提交代码。所有后面的步骤都始于本地代码的一次提交(commit)
2.测试(第一轮):代码仓库对commit操作配置了钩子(hook),只要提交代码或者合并进主干,就会跑自动化测试
3.构建:通过第一轮测试,代码就可以合并进主干,就算可以交付了。交付后,就先进行构建(build),再进入第二轮测试。所谓构建,指的是将源码转换为可以运行的实际代码,比如安装依赖,配置各种资源(样式表、JS脚本、图片)等等
4.测试(第二轮):构建完成,就要进行第二轮测试。如果第一轮已经涵盖了所有测试内容,第二轮可以省略,当然,这时构建步骤也要移到第一轮测试前面
5.部署:过了第二轮测试,当前代码就是一个可以直接部署的版本((artifact)。将这个版本的所有文件打包 ( tarfilename.tar * )存档,发到生产服务器
6.回滚:一旦当前版本发生问题,就要回滚到上一个版本的构建结果。最简单的做法就是修改一下符号链接,指向上一个版本的目录

1.2 持续集成的组成要素

1.一个自动构建过程,从检出代码、编译构建、运行测试、结果记录、测试统计等都是自动完成的,无需人工干预
2.一个代码存储库,即需要版本控制软件来保障代码的可维护性,同时作为构建过程的素材库,一般使用SVN或Git
3.一个持续集成服务器,Jenkins 就是一个配置简单和使用方便的持续集成服务器

1.3 持续集成的好处

1.降低风险,由于持续集成不断去构建,编译和测试,可以很早期发现问题,所以修复的代价就少
2.对系统健康持续检查,减少发布风险带来的问题
3.减少重复性工作
4.持续部署,提供可部署单元包
5.持续交付可供使用的版本
6.增强团队信心

二、Jenkins介绍

Jenkins是一款流行的开源持续集成(Continuous Integration)工具,广泛用于项目开发,具有自动化构建.测试和部署等功能。官网:http://jenkins-ci.org/

2.1 Jenkins的特征

1.开源的Java语言开发持续集成工具,支持持续集成,持续部署
2.易于安装部署配置:可通过yum安装,或下载war包以及通过docker容器等快速实现安装部署,可方便web界面配置管理
3.消息通知及测试报告:集成RSS/E-mail通过RSs发布构建结果或当构建完成时通过e-mail通知,生成JUnit/TestNG测试报告
4.分布式构建:支持Jenkins能够让多台计算机一起构建/测试
5.文件识别: Jenkins能够跟踪哪次构建生成哪些jar,哪次构建使用哪个版本的jar等
6.丰富的插件支持:支持扩展插件,你可以开发适合自己团队使用的工具,如git,svn,maven、docker等

2.2 持续集成流程具体说明


1.首先,开发人员每天进行代码提交,提交到Git仓库
2.然后,Jenkins作为持续集成工具,使用Git工具到Git仓库拉取代码到集成服务器,再配合JDK,Maven等软件完成代码编译,代码测试与审查,测试,打包等工作,在这个过程中每一步出错,都重新再执行一次整个流程
3.最后,Jenkins把生成的jar或war包分发到测试服务器或者生产服务器,测试人员或用户就可以访问应用

2.3 搭建简易jenkins服务

2.3.1 服务器准备

名称 ip 软件
代码托管服务器 192.168.80.16 Gitlab-12.4.2
持续集成服务器 192.168.80.15 Jenkins-2.318.1,JDK1.8,Maven3.6.2,Git,SonarQube
应用测试服务器 192.168.80.14 JDK1.8,Tomcat8.5

2.3.2 Gitlab代码托管服务器安装

1.官网: https://about.gitlab.com/
2.GitLab是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务
3.GitLab和GitHub一样属于第三方基于Git开发的作品,免费且开源(基于MIT协议),与Github类似,可以注册用户,任意提交你的代码,添加SSHKey等等。不同的是,GitLab是可以部署到自己的服务器上,数据库等一切信息都掌握在自己手上,适合团队内部协作开发

1)关闭防火墙和安全功能

systemctl stop firewalld
systemctl disable firewalld
setenforce 0

2)安装依赖包

yum install -y policycoreutils openssh-server openssh-clients postfix

3)启动ssh服务并设置为开机启动

systemctl enable --now sshd

4)设置postfix开机自启,让postfix支持gitlab发信功能

systemctl enable --now postfix

5)下载gitlab包并且安装

在线下载安装包:
wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6/gitlab-ce-12.4.2-ce.0.el6.x86_64.rpm

这边我下载好了直接拉进/opt目录中进行安装:
rpm -ivh gitlab-ce-12.4.2-ce.0.el6.x86_64.rpm


6)修改gitlab配置

vi /etc/gitlab/gitlab.rb

#修改23行,修改gitlab访问地址和端口,默认为80,我们改为100
external_url 'http://192.168.80.16:100'
#修改1112行
nginx['listen_port']=100


7)重载配置及启动gitlab

gitlab-ctl reconfigure
gitlab-ctl restart

8)浏览器访问测试

http://192.168.80.16:100

进去后看到以下修改管理员root密码的页面,修改密码后,然后登录即可



2.4 Gitlab添加组、创建用户、创建项目

2.4.1 创建组

使用管理员root创建组,一个组里面可以有多个项目分支,可以将开发添加到组里面进行设置权限,不同的组就是公司不同的开发项目或者服务模块,不同的组添加不同的开发即可实现对开发设置权限的管理




2.4.2 在组内创建项目



2.4.3 创建用户

创建用户的时候,可以选择Regular或Admin类型





2.4.4 将用户添加进组中

选择某个用户组,进行members管理组成员


1.Guest:可以创建issue、发表评论,不能读写版本库
2.Reporter:可以克隆代码,不能提交,QA、PM可以赋予这个权限
3.Developer:可以克隆代码、开发、提交.push,普通开发可以赋予这个权限
4.Maintainer:可以创建项目、添加tag、保护分支、添加项目成员、编辑项目,核心开发可以赋予这个权限
5.Owner:可以设置项目访问权限-visibility Level、删除项目、迁移项目、管理组成员,开发组组长可以赋予这个权限

2.4.5 用新建用户登入gitlab



2.4.6 在新用户组中创建项目

posted @ 2021-10-28 23:20  落寞1111  阅读(223)  评论(0编辑  收藏  举报