首页 » 排名链接 » 使用Jenkins+Docker+Gitlab+Maven搭建持续集成环境(搭建持续集成环境构建)

使用Jenkins+Docker+Gitlab+Maven搭建持续集成环境(搭建持续集成环境构建)

少女玫瑰心 2024-11-30 17:57:59 0

扫一扫用手机浏览

文章目录 [+]

大致的步骤如下:

开发人员通过IDE工具(IntelliJ IDEA)将代码推送到gitlab。
jenkins从gitlab中获取到源码,并使用maven编译、打包、(下一章节介绍)自动构建镜像。
jenkins在构建脚本中调用docker命令将构建好的镜像push到本地Docker Registry.并启动相应的容器。
(下一章节介绍)

一、使用IntelliJ IDEA 将项目发布(提交)到GitLab

(1)本地下载并安装配置Git客户端,并在idea配置本地git。

使用Jenkins+Docker+Gitlab+Maven搭建持续集成环境(搭建持续集成环境构建) 排名链接
(图片来自网络侵删)

官方下载地址为:https://git-scm.com/download/win,下载完之后,双击安装,全部选择默认。

(2)Git初始化及仓库创建和操作

Git安装之后需要进行一些基本信息设置(需要先注册Github)

a、设置用户名:git config -- global user.name '你再github上注册的用户名';

b、设置用户邮箱:git config -- global user.email 'github注册时候的邮箱';

注意:该配置会在github主页上显示谁提交了该文件

c、配置ok之后,我们用如下命令来看看是否配置成功:git config --list

注意:git config --global 参数,有了这个参数表示你这台机器上所有的git仓库都会使用这 个配置,当然你也可以对某个仓库指定不同的用户名和邮箱。

(3)在idea 配置Git客户端

file->settings->version control->git

(4)idea本地将本地现有的项目和gitlab进行管理并提交到线上

在idea的菜单项选择 VCS->Import into Version Control->Create Git Repository

出现一个弹出框,选择你要提交的项目的文件夹

如果出现弹出框 ,点击确定。
默认是直接定位到当前项目文件所在的磁盘目录,一般git初始化就在当前项目的根目录,不需要修改路径,直接点击OK确定即可。

init完成之后,可以看到原本的项目文件名变成了红色了,红色在idea的git版本表示未add的文件,同时在系统资源管理中打开项目的磁盘文件目录,会发现一个.git的隐藏文件,这个文件就git的配置和仓库文件。

在回到idea项目中,点击VCS》Git》Add添加当前项目下的文件,添加完成之后,之前的红色文件名变成了绿色了,表示已经Add成功,但还没有commit。

注意:如果有的文件还是红色,按以下处理把你需要提交的内容添加vcs

继续操作,VCS》Git》Commit File,然后在提交创建填写提交注释说明

提交完成之后,只是提交到本地仓库,这个时候还没有同步到远程的gitlab服务上,需要push操作,VCS》Git》Push

然后通过网页的方式登录gitlab服务,创建一个空的project,然后在如图所示的位置复制仓库地址

在本地通过git shell (可以安装git for window) 进入到项目目录 执行 以下命令:

# 给项目设置远程远程仓库 #

git remote add origin http://gitlab.ipzao.com/root/test.git

# 抓取远程仓库数据,并自动合并远程分支 #

git pull origin master

# 更新本地数据到gitlab #

git push origin master

选中项目,先git->commitFile,然后操作git->repository->push 可以push代码到远程gitlab上了,push完成之后会提示push successful

二、安装jenkins

1. 拉取jenkins镜像

docker pull jenkinsci/jenkins

2. 新建jenkins工作目录

cd apps

mkdir jenkins

cd jenkins

3. 生成启动文件 jenkins-start.sh

cat <<EOF > jenkins-start.sh#!/bin/bashHOST_NAME=jenkins.ipzao.comGITLAB_DIR=`pwd`docker stop jenkinsdocker rm jenkinsdocker run -d \ -p 38080:8080 \ -p 50000:50000 \ --name jenkins \ --link gitlab:gitlab.ipzao.com \ -u root \ -v /apps/ipzao/jenkins:/var/jenkins_home \ jenkinsci/jenkins:latestEOF

使用docker命令运行容器,然后开启38080端口,并启动jenkins容器。

其中8080端口是jenkins的端口,38080是映射宿主机的端口,50000端口是master和slave通信端口.以root用户来启动容器,同时通过配置--link连接gitlab,因为要与gitlab容器通讯下载代码。

4. 运行 jenkins-start.sh 启动jenkins

sh jenkins-start.sh

jenkins 启动后,可通过 docker logs -f 容器实例Id 查看日志。

容器实例Id 查询 docker ps

打开浏览器http://ip:38080/访问跳转到解锁jenkins页面。

在服务器上以下执行命令查看密码

由于之前启动jenkins容器时我们做了目录映射

-v /apps/ipzao/jenkins:/var/jenkins_home,所以要将执行命令改为:

cat /apps/ipzao/jenkins/secrets/initialAdminPassword

在解锁页面上输入上述密码,继续进入以下页面:

建议选择安装推荐的插件,基本上一些常用的插件都会被安装,安装过程如图:

安装完后进入以下页面:

单击开始使用Jenkins按钮进入jenkins系统,点击左侧菜单中的\"系统管理\"进入Jenkins管理模块,查看系统设置:

主目录:是存放Jenkins所有的文件的,工作空间根目录和构建记录目录默认都是在Jenkins主目录下,这个设置一般不用进行变更。

执行者数量:可以并发构建的数量。

标记:用来记录这个机器的名称。

用法:设置这个节点的执行策略(包括尽可能使用这个节点和只允许绑定到这台机器的job。

生成前等待时间:这个时间为构建开始前的等待时间。

scm签出重试次数:使用svn或者git拉取代码失败重试的次数。

工程命名限制:限制项目命名,勾选后可以看到具体设置,可以设置为默认或者使用正则表达式进行限制。

全局属性

工具位置:设置全局工具,可以把需要的工具都在这里进行配置,比如maven,ant,jdk等。

环境变量:设置全局变量,在这里定义的全局变量可以在构建或者发送邮件时引用。

设置时间格式

管理监控默认选中所有

jenkins location

jenkins url:设置jenkins的url(发送邮件引用jenkins的地址会取这个值,如果设错了,邮件的连接就会打不开)。

系统管理员邮件地址:管理员的邮件地址(在构建需要发送邮件时,会用到这个邮件地址)。

插件管理:进入全局工具配置 选择可选插件板块,安装并配置maven插件,如果缺少Maven Integration Plugin插件,在创建job时,不会有新建一个maven项目选项。

5. 创建一个构建任务

输入项目名称test,选中构建一个多配置项目点击确定按钮进入项目配置页面:

在源码管理板块中选择git并在repository url填写git仓库名称,但此时会报错:

通过错误提示可知:我们所填入的URL是需要身份认证的,可单击Credentials下拉框右侧的Add按钮,并选择Jenkins选项,弹出身份认证信息对话框:

上面填写的是gitlab的用户名密码验证,添加完后需要选中它,这个时候可以看到已经不报错了。

在构建板块中配置maven:

添加构建后操作:

点击增加构建后操作步骤,选择归档成品,在文本框中输入需要存档的文件路径:/target/.jar。

单击保存回到主界面

单击左侧菜单的立即构建并在控制台输出中查看构建日志:

小球图标表示构建状态:蓝色表示构建成功,但目的是搭建一个持续集成的环境,在开发阶段我们会不断的推送代码到gitlab,所以我们需要利用jenkins来帮我们实现自动构建发布(下一章节介绍)。

标签:

相关文章