Jenkins-安装和持续集成环境配置(2)

1.持续集成流程说明

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_服务器


(1)首先,开发人员每天进行代码提交,提交到Git仓库

(2)然后,Jenkins作为持续集成工具,使用Git工具到Git仓库拉取代码到集成服务器,再配合JDK,

Maven等软件完成代码编译,代码测试与审查,测试,打包等工作,在这个过程中每一步出错,都重新再执行一次整个流程。

(3)最后,Jenkins把生成的jar或war包分发到测试服务器或者生产服务器,测试人员或用户就可以访问应用。

服务器列表
本安装教程 虚拟机统一采用CentOS7。

名称

IP地址

安装的软件

代码托管服务器

192.168.66.100

Gitlab-12.4.2

持续集成服务器

192.168.66.101

Jenkins-2.190.3,JDK1.8,Maven3.6.2,Git,SonarQube

应用测试服务器

192.168.66.102

JDK1.8,Tomcat8.5

2.Gitlab代码托管服务器安装

Gitlab简介

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

GitLab 安装

  1. 安装相关依赖
yum -y install policycoreutils openssh-server openssh-clients postfix
  1. 启动ssh服务&设置为开机启动
systemctl enable sshd && sudo systemctl start sshd
  1. 设置postfix开机自启,并启动,postfix支持gitlab发信功能
systemctl enable postfix && systemctl start postfix
  1. 开放ssh以及http服务,然后重新加载防火墙列表
firewall-cmd --add-service=ssh --permanent
firewall-cmd --add-service=http --permanent
firewall-cmd --reload

如果关闭防火墙就不需要做以上配置

  1. 下载gitlab包,并且安装
在线下载安装包:
wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6/gitlab-ce-12.4.2-ce.0.el6.x
86_64.rpm
安装:
rpm -i gitlab-ce-12.4.2-ce.0.el6.x86_64.rpm
  1. 修改gitlab配置
vi /etc/gitlab/gitlab.rb

修改gitlab访问地址和端口,默认为80,我们改为82
external_url ‘http://192.168.66.100:82’

nginx[‘listen_port’] = 82

  1. 重载配置及启动gitlab
gitlab-ctl reconfigure
gitlab-ctl restart
  1. 把端口添加到防火墙
firewall-cmd --zone=public --add-port=82/tcp --permanent
firewall-cmd --reload

启动成功后,看到以下修改管理员root密码的页面,修改密码后,然后登录即可

注意: 可能由于 大家本地 CentOS环境 都不相同 或者 自己环境变量没有配置好,所以在 安装过程中,可能会遇到各种问题,遇到问题不要慌,去网上 各种一顿搜,程序就是一个改bug的过程,祝大家愉快安装!

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_运维_02


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

1)创建组

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

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_jenkins_03


jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_git_04


2)创建用户

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

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_git_05


创建完用户后,立即修改密码

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_git_06


3)将用户添加到组中

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

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_git_07


jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_jenkins在gitlab拉去代码_08


jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_jenkins在gitlab拉去代码_09


Gitlab用户在组里面有5种不同权限:

Guest:可以创建issue、发表评论,不能读写版本库 Reporter:可以克隆代码,不能提交,QA、PM可以赋予这个权限 Developer:可以克隆代码、开发、提交、push,普通开发可以赋予这个权限

Maintainer:可以创建项目、添加tag、保护分支、添加项目成员、编辑项目,核心开发可以赋予这个

权限 Owner:可以设置项目访问权限 - Visibility Level、删除项目、迁移项目、管理组成员,开发组组

长可以赋予这个权限

4)在用户组中创建项目

以刚才创建的新用户身份登录到Gitlab,然后在用户组中创建新的项目

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_git_10


jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_服务器_11

3.源码上传到Gitlab仓库

下面来到IDEA开发工具,我们已经准备好一个简单的Web应用准备到集成部署。
我们要把源码上传到Gitlab的项目仓库中。

这里就是提交代码到远程那一套,比较简单 就不演示了

4.Jenkins安装

1)安装JDK
Jenkins需要依赖JDK,所以先安装JDK1.8

yum install java-1.8.0-openjdk* -y

安装目录为:/usr/lib/jvm

2)获取jenkins安装包
下载页面:https://jenkins.io/zh/download/
安装文件:jenkins-2.190.3-1.1.noarch.rpm

3)把安装包上传到192.168.66.101服务器,进行安装

rpm -ivh jenkins-2.190.3-1.1.noarch.rpm

4)修改Jenkins配置

vi /etc/syscofig/jenkins

修改内容如下:

JENKINS_USER="root"
JENKINS_PORT="8888"

5)启动Jenkins

systemctl start jenkins

6)打开浏览器访问
http://192.168.66.101:8888 注意:本服务器把防火墙关闭了,如果开启防火墙,需要在防火墙添加端口

7)获取并输入admin账户密码

cat /var/lib/jenkins/secrets/initialAdminPassword

8)跳过插件安装

因为Jenkins插件需要连接默认官网下载,速度非常慢,而且经过会失败,所以我们暂时先跳过插件安装

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_jenkins在gitlab拉去代码_12


jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_git_13


9)添加一个管理员账户,并进入Jenkins后台

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_服务器_14


jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_git_15


开始使用Jenkins

jenkins在gitlab拉去代码 jenkins从gitlab上下载的代码在哪_运维_16