美文网首页devopt
2使用Jenkins+Gitlab+Maven 构建持续集成环境

2使用Jenkins+Gitlab+Maven 构建持续集成环境

作者: 能取个帅气的昵称 | 来源:发表于2018-07-09 15:21 被阅读317次

本文主要讲述如何使用Jenkins Gitlab等 , 如果你不会安装请访问我之前写的文章

打开Gitlab并登录,没有账号自己注册一个

Create a project 创建一个项目

Project name 输入项目名,其他信息按实际情况填写,这里做演示我就默认了

创建完项目后 在底下会有提示告诉如何上传文件到这个项目

按照提示创建README.md文件并提交

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书

$ git config --global user.name "ludzh"

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书

$ git config --global user.email "ludzh@neusoft.com"

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书

$ git clone http://10.10.167.106:21000/dezhenglu/jenkins-gitlab-demo.git

Cloning into 'jenkins-gitlab-demo'...

warning: You appear to have cloned an empty repository.

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书

$ cd jenkins-gitlab-demo

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书/jenkins-gitlab-demo (master)

$ touch README.md

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书/jenkins-gitlab-demo (master)

$ git commit -m "add README"

On branch master

Initial commit

Untracked files:

        README.md

nothing added to commit but untracked files present

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书/jenkins-gitlab-demo (master)

$ git add README.md

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书/jenkins-gitlab-demo (master)

$ git commit -m "add README"

[master (root-commit) 2b0f013] add README

1 file changed, 0 insertions(+), 0 deletions(-)

create mode 100644 README.md

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书/jenkins-gitlab-demo (master)

$ git push -u origin master

Counting objects: 3, done.

Writing objects: 100% (3/3), 212 bytes | 0 bytes/s, done.

Total 3 (delta 0), reused 0 (delta 0)

To http://10.10.167.106:21000/dezhenglu/jenkins-gitlab-demo.git

* [new branch]      master -> master

Branch master set up to track remote branch master from origin.

ludz@DESKTOP-SQN1UE3 MINGW64 /e/gitlab/简书/jenkins-gitlab-demo (master)

$

刷新刚才的页面,OK提交代码没问题了

稍后在上传代码,先来配置下Gitlab 生成一个API Token ,位置在 User Settings > Access Tokens

Name 随意 Expires at 是到期时间,默认应该是永不过期,Scopes都选上,然后创建Token

Your New Personal Access Token 中就是创建好的Token串 复制出来备用

下面一点是Token的信息 Revoke 是撤销(删除)

打开Jenkins

认证那里追加一个认证,把刚才的Token复制进去,Kind选择Gitlab API Token

输入其他参数并测试显示Success表示成功

现在Jenkins还不能直接拉取Gitlab上的代码需要在Gitlab上设置SSH Key, 在Gitlab项目页面上会出现提示

如果不小心点了忽略在User Settings > SSH Keys 也可以设置不用担心

创建key

ssh-keygen -t rsa -C "ludzh@neusoft.com" -b 4096

把公钥文件打开复制里面的内容复制到key里

SSH key 也是可以删除的

现在回到Jenkins首页,创建一个任务

Repository URL 里写项目Gitlab地址

在Credentials 里追加一个配置

输入用户名并在私有key里选择文件填写刚才创建的私钥文件,ID 和描述应该可以随意

之后输入仓库Url 选择上一步建的认证信息

应用&保存,点击立即构建

构建结束后在工作空间里能看到Pull下来的代码

到此为止Jenkins可以从Gitlab上抓取代码了,现在我们把演示代码上传,这里使用Github Desktop

刷新Gitlab应该能看到刚刚上传的文件

回到Jenkins刚才创建的任务里 构建选项卡-添加构建步骤-调用顶层的Maven目标

Apply&Save&立即构建

出错了,看提示应该是Maven构建失败找不到对应的jar包,我这个机器处于内网要设置代理

设置远程仓库

再次构建

OK 构建成功了

刚才构建的工程jar文件

到此Jenkins拉取代码并构建已经完成了,现在来做自动部署,

创建发布的位置

mkdir /home/cmreadwh/cip/jenkins_demo

cd /home/cmreadwh/cip/jenkins_demo

增加构建步骤选执行Shell

cp $JENKINS_HOME/workspace/jenkins-gitlab-demo/target/dockerdemo-0.0.1-SNAPSHOT.jar /home/cmreadwh/cip/jenkins_demo

$JENKINS_HOME 是Jenkins的内部变量对应我机器位置是/用户/.jenkins

在发布路径下创建停止和启动脚本文件

#!将应用停止

#!stop.sh

#!/bin/bash

echo "Stopping SpringBoot Application"

pid=`ps -ef | grep dockerdemo-0.0.1-SNAPSHOT.jar | grep -v grep | awk '{print $2}'`

if [ -n "$pid" ]

then

#!kill -9 强制终止

  echo "kill -9 的pid:" $pid

  kill -9 $pid

fi

#!startup.sh

java -jar dockerdemo-0.0.1-SNAPSHOT.jar

再创建一个构建步骤依旧是执行Shell

脚本的内容很简单,我就不做介绍了网上都有介绍

最后 apply & save & 立即构建

构建队列里可以点进去控制台输出可以看到详细日志

构建完毕并成功执行了刚才写的启动停止脚本

访问程序的地址,看看程序起来没有

程序启动正常, 紧接着我要配置Webhook 实现push代码自动部署,我会写在我下一篇文章里

相关文章

网友评论

    本文标题:2使用Jenkins+Gitlab+Maven 构建持续集成环境

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