Gitlab+Jenkins自动化部署,解放双手

这篇具有很好参考价值的文章主要介绍了Gitlab+Jenkins自动化部署,解放双手。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

项目打包

​ 在部署项目前需要对源码进行打包,一个简单的SpringBoot项目默认是打包为jar包,也就是在pom.xml中的<packaging>jar</packaging>方式,当然也会有一些打包成war包方式,使用外置的Tomcat应用服务器部署war包,那么就是<packaging>war</packaging>

在父子类聚合项目中,父工程的pom.xml文件中的打包方式就需要改为pom,如下:

<packaging>pom</packaging>

那么所有的子工程pom.xml中,就需要改为jar方式,或者war

jar包是默认的打包方式,子工程如果是打包成jar包那么不需要改任何配置,war包时如下配置

<packaging>war</packaging>

并且所有的子工程中需要,导入maven插件配置

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <executable>true</executable>
                <layout>JAR</layout>
            </configuration>
            <executions>
                <execution>
                    <goals>
                        <goal>repackage</goal>
                    </goals>
                    <configuration>
                        <attach>false</attach>
                    </configuration>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

执行打包

在具有maven环境的情况下,到父工程pom.xml文件所在目录下执行

mvn clean package

即可将此父工程下所有子工程进行打包,假如这里得到了三个jar包为consumer.jarprovider1.jarprovider2.jar

那么就可以手动执行部署了。

命令行部署

使用命令行方式去部署3个jar包,可以说非常简单,但还要考虑项目中需要的一些环境:

  • 服务器需要由java的jdk环境,能使用java命令
  • 假如项目中用到了nacos,那么还需要做好nacos环境的配置及服务的启动
nohup java -jar consumer.jar > consumer.logs.log 2 >&1 &
nohup java -jar provider1.jar > provider1.logs.log 2 >&1 &
nohup java -jar provider2.jar > provider2.logs.log 2 >&1 &

nohup:不挂断运行

> xxx.logs.log 2 > &1 &:将程序日志输出到某个位置并且后台运行。

那么这些都是手动运行,目前而言大多都采用了自动化部署。

Jenkins

手动运行需要每次都去上传jar包,然后更新jar重启服务。若服务数量较少还比较好,一旦遇到微服务多jar包情况下,手动就会显得很繁琐而无助。或者说可以采用shell脚本的方式去部署,但这都不是最优秀的解决方案。可以使用Jenkins部署运行服务。

介绍

Jenkins的前身是Hudson。Jenkins是一款较为流行的开源持续集成工具,地位几乎可以说是CI&CD软件领导者,已经超过了Hudson,它拥有超过1000个插件来支持项目的构建和部署。几乎可以适用于所有的项目,没有项目编程语言的限制。

CI&CD:

  • 持续集成(Continuous Integration,CI):指的是团队成员每天一次或多次把代码集成到主干。每次集成会自动构建,尽快尽早发现错误。持续集成是为了让产品快速迭代,同时保证高质量。
  • 持续交付(Continuous Delivery):指的是持续将新的功能部署到类生产环境(可理解为测试环境qa、uat),交给质量团队或用户,交给它们评审
  • 持续部署(Continuous Deployment):指的是通过评审后,自动部署到生产环境中

Jenkins的特性:

  • 系统平台无关性:Jenkins本身是由Java语言编写,理论上只要由java的运行环境,就能使用Jenkins
  • 编程语言无关性:支持多种编程语言的项目持续集成、持续部署,而非只有java一种
  • 安装和配置简单:可以通过yum安装或war包、Docker方式等,由简洁易用的web界面完成配置
  • 插件丰富:拥有超过1000个插件,几乎可以满足任何项目的需要
  • 容易扩展:Jenkins可以通过其插件架构进行扩展,为用户提供无限可能
  • 分布式构建:Jenkins能使多台服务器一起构建
  • 消息通知:构建完成后发送email通知结果

下载和安装

Jenkins的官网地址是https://www.jenkins.io/,下载软件包的地址https://www.jenkins.io/download/。推荐下载LTS(长期支持)版本。笔者这里选择Generic Java package(.war),只需要java环境即可。

当然要注意你选择版本要和你本地的jdk环境的兼容关系:

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

笔者是java8的环境,选择一款适用的jenkins版本即可。笔者选择2.346.3版本。

提供下下载地址:https://get.jenkins.io/war-stable/2.346.3/jenkins.war

运行

  • war包下载完毕后,不需要额外的步骤(前提是有java环境),是可以直接运行的
java -jar jenkins.war --httpPort=8085
  • –httpPort是设置程序端口号,若要使程序不挂断后台运行,可以这样执行
nohup java -jar jenkins.war --httpPort=8085 > jenkins-logs.log 2 >&1 &

服务运行后,成功访问UI页面,记得需要打开防火墙的端口哦

firewall-cmd --permanent --zone=public --add-port=8085/tcp
firewall-cmd --reload
  • 打开jenkins的UI地址(笔者这里是http://192.168.1.41:8085)

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

我们需要去上面的相应文件中去找到密码,然后填写,确定即可。

注意:第一次启动Jenkins会初始化去下载一些元(metadata)数据,打开界面时提示等待大概4分钟,等待期间,使用F12调试时,看到报错503是正常现象。等待日志打印Jenkins is fully up adn running 即可

  • 下一步会让用户安装插件,若是新手可以选择Jenkins推荐的插件,可以减少很多的步骤。笔者这里也选择推荐的插件了,唯一的缺点是下载的东西多,稍微会慢点。

  • 完成后创建一个管理员用户

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

Jenkins配置

Jenkins初始化完成后,还需要配置一些全局工具,如jdk,maven,git。在Jenkins后台页面点击Manage Jenkins,再点击Global Tool Configuration配置全局工具JDK、maven、git

配置maven

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

找好你的settings.xml文件的路径,配置到这里即可。然后再去配置maven的路径

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

注意:如果你的maven的bin目录没有可执行的权限,要记得增加可执行权限,否则执行命令时会报错:Permission denied,可以在maven的根目录下使用命令赋权:chmod +x -R bin

配置jdk

直接输入JAVA_HOME的安装地址即可

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

最后配置git的目录,记得先安装git

yum install -y git

使用yum安装的git,目录是/usr/bin/git

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

GitLab简介&安装

持续集成一般有3个组成的要素:

  • 一个自动构建的过程,代码检出、编译构建等过程都是自动完成,无需人工
  • 一个代码存储库(SVN或git)
  • 一个持续集成服务器(如Jenkins)

现在还缺少一个代码存储库。在企业中为了掌握代码的所有权,一般都会自动搭建代码存储库。可以使用Gitlab。

GitLab使用git作为代码管理工具,并且在此基础上开发了Web管理页面来进行项目管理。

与github最大的不同是,gitlab部署在自己的服务器上,所有权都是掌握在自己手中。

采用yum方式安装GitLab

  • 安装需要的依赖和设置ssh开机自启动,开启ssh及配置防火墙
yum install -y curl policycoreutils-python openssh-server
systemctl enable sshd
systemctl start sshd
firewall-cmd --permanent --add-service=http
firewall-cmd --permanent --add-service=https
systemctl reload firewalld
  • 安装Postfix并设置开机自启动、开启Postfix,便于邮件通知
yum install -y postfix
systemctl enable postfix
systemctl start postfix
  • 添加Gitlab软件包存储库并安装软件包
curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh | bash
  • 配置Gitlab访问地址并安装Gitlab(http://192.168.1.41是gitlab访问地址)
EXTERNAL_URL="http://192.168.1.41" yum install -y gitlab-ee
  • 打开防火墙端口(或关闭防火墙)
firewall-cmd --permanent --zone=public --add-port=80/tcp
firewall-cmd --reload
  • 完成后,打开http://192.168.1.41,第一次进入时需要去/etc/gitlab/initial_root_password找下初始化密码,然后登录即可

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

Docker方式安装Gitlab

使用Docker方式安装Gitlab是比较快捷的方式,如下命令即可:

mkdir -p /data/gitlab # 先创建gitlab存储数据、配置、日志的目录

docker run -d --hostname 192.168.1.41:80 --publish 443:443 --publish 80:80 --publish 23:22 --name gitlab --restart always --volume /data/gitlab/config:/etc/gitlab --volume /data/gitlab/logs:/var/log/gitlab --volume /data/gitlab/data:/var/opt/gitlab gitlab/gitlab-ee:latest

-d : 后台运行

–hostname:gitlab服务地址

–publish或-p:宿主机和容器的端口映射

–name 设置容器名称

–volume或-v:宿主机和容器的目录映射

–restart always: 开机自启

Gitlab常用命令

  • gitlab-ctl start:启动
  • gitlab-ctl stop:停止
  • gitlab-ctl status:查看
  • gitlab-ctl restart:重启

Jenkins+Gitlab部署运行

现在已经有了存储库,然后创建git仓库把项目上传到Gitlab上面。

git init 
git remote add origin http://192.168.1.41/root/jenkins-demo.git
git add .
git commit -m "Initial commit"
git push -u origin main

这些就比较简单了,笔者这里不再赘述了。直接展示下项目的目录

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

需要注意的是:如果普通用户push代码,可能会没有权限,管理员设置下即可。

Jenkins页面创建任务

  • 在Jenkins页面点击新建项目(New Item),输入项目名称(名称随便取,别重复)。选择自由风格项目。

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

  • 在General一栏输入描述,可以任意填写,重要的是源代码管理,仓库地址就填写gitlab的项目地址,然后添加你的gitlab账号的凭证(账号密码)。
  • 完成后,下面有一个分支选择,选择你要部署的分支即可。

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

  • 来到构建这一栏,点击添加构建步骤,选择Invoke toplevel maven targets(调用顶层 Maven 目标)项,maven版本选择配置好的,目标Goals填写clean package

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

这里的maven命令不需要添加mvn,请注意!!

  • 打包完成后,就可以运行jar包了,再增加一个构建步骤,选择Excecute shell,执行shell命令,在Command输入以下命令,考虑到可能出现第二次部署时,需要把上一次的jar停止,那么命令如下
#!/bin/bash
# 先停止进程
ps -ef |grep consumer |grep -v 'grep' | awk '{print $2}' | xargs kill -s 15
ps -ef |grep provider-8001 |grep -v 'grep' | awk '{print $2}' | xargs kill -s 15
ps -ef |grep provider-8002 |grep -v 'grep' | awk '{print $2}' | xargs kill -s 15
sleep 5s	# 5s后再启动
BUILD_ID=dontKillMe	# 表示别干掉启动的程序
cd consumer/target/
nohup java -jar consumer-1.0-SNAPSHOT.jar > consumer.logs.log 2 >&1 &
cd ../../provider-8001/target/
nohup java -jar provider-8001-1.0-SNAPSHOT.jar > provider1.logs.log 2 >&1 &
cd ../../provider-8002/target/
nohup java -jar provider-8002-1.0-SNAPSHOT.jar > provider2.logs.log 2 >&1 &

完事后,保存即可。

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

  • 点击立即构建,即可

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

同时还可以去看日志信息:

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

我们可以到服务器上看下程序有没有启动成功

ps -ef |grep java

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

成功部署了三个jar包。

Webhook网络钩子

当我们需要每次提交合并代码时,自动进行项目部署时,可以使用网络钩子Webhook完成我们的需求。

大致流程就是:Jenkins提供一个地址,当代码有更新时代码存储库(gitlab)主动调用一次这个地址,触发Jenkins构建即可。

需要在Jenkins上面安装Generic Webhook Trigger插件

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

到项目主界面,点击配置,到构建触发器那里,选择Generic Webhook Trigger一项,然后添加一个Token(随便写,但不要重复了)

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

那么,构建的URL格式如下:

http://JENKINS_URL/generic-webhook-trigger/invoke/invoke?token=刚刚自定义的Token

JENKINS_URL:是JENKINS的访问地址。

此项目中就是如下

http://192.168.1.41:8085/generic-webhook-trigger/invoke/invoke?token=nihaowoshichufaqi

回到gitlab

因为Gitlab10.6版本后,为了安全,默认不允许向本地网络发送Webhook请求,这里因为笔者是把gitlab和jenkins安装到一台服务器了,所以这里先允许发送本地网络webhook。

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

到gitlab项目中,设置webhook即可。这里暂时写所有分支push时触发了,实际可以按照项目情况执行。

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化

配置完成

完成后,即可提交任意分支的代码,看到jenkins已经自动触发构建了,并且jar也重新启动了

Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化
Gitlab+Jenkins自动化部署,解放双手,运维,gitlab,gitlab,jenkins,自动化文章来源地址https://www.toymoban.com/news/detail-728143.html

到了这里,关于Gitlab+Jenkins自动化部署,解放双手的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Jenkins+Gitlab自动化部署配置】

    以下为整理当初参照的博客 阿里云云服务器 ECS 手动搭建GitLab避坑教程 博客文中的镜像源地址已换 Gitlab忘记root用户密码的解决办法 Gitlab学习笔记(一):基于Ubuntu的gitlab的私有服务搭建(超详细) Jenkins 构建报错:Couldn‘t find any revision to build. Verify the repository and branch conf

    2024年02月21日
    浏览(40)
  • Jenkins + Gitlab 实现项目自动化构建及部署

      通俗来讲就是本地项目 push 到 gitlab 后, Jenkins 能够识别到项目的更新并自动构建部署;  本文以实际操作的方式来表述详细配置过程及避开配置 Jenkins 时的坑. 默认电脑已经安装了虚拟机, 默认gitlab 上已经有了你想要部署的项目, 部署了 maven 和 jdk 并配置了环境变量!!! 1 执行

    2024年02月16日
    浏览(44)
  • Gitlab + Docker + Jenkins + Harbor实现自动化部署

    目录 文章目录 前言 一、第一台服务器--Jenkins 1、安装前 2、安装Jenkins 3、修改正在跑容器的端口 4、Jenkins内部插件和配置  二、第二台服务器--Harbor 1、安装docker-compose 2.安装及配置 3、卸载Harbor  4、Harbor启动后操作 三、第三台服务器--生产环境  1、配置私服地址 四、Jenkin

    2024年02月14日
    浏览(45)
  • Jenkins+Maven+Gitlab+Tomcat 自动化构建打包,部署

    1、安装服务 Jenkins工具、环境、插件配置 全局变量配置 Manage JenkinstoolsJDK 安装 安装插件 Deploy to container 安装此插件,才能将打好的包部署到tomcat上     配置国内mvn源 创建maven项目 1  2   3    4    5    6    7    8     9 10  

    2024年02月05日
    浏览(47)
  • Jenkins+GitLab+Docker搭建前端自动化构建镜像容器部署

    前言 🚀 需提前安装环境及知识点: 1、Docker搭建及基础操作 2、DockerFile文件描述 3、Jenkins搭建及基础点 🚀 目的: 将我们的前端项目打包成一个镜像容器并自动发布部署,可供随时pull访问 1、在当前项目的根目录创建Dockerfile文件并写入如下代码: 代码片段详细描述: 注意

    2024年02月05日
    浏览(62)
  • Jenkins+GitLab+Docker搭建前端自动化构建镜像容器部署(无本地证书,映射证书)

    前言 🚀 需提前安装环境及知识点: 1、Docker搭建及基础操作 2、DockerFile文件描述 3、Jenkins搭建及基础点 🚀 目的: 将我们的前端项目打包成一个镜像容器并自动发布部署,可供随时pull访问 1、在当前项目的根目录创建Dockerfile文件并写入如下代码: 代码片段详细描述: 注意

    2024年02月15日
    浏览(46)
  • 2023全网最细最全保姆级gitlab+Jenkins+maven自动化部署springboot项目教程

    如果没有Linux基础请仔细看好每一个步骤,避免出错,从0到1带你搭建自动化部署环境,包括服务器安装,自动化部署所需各类软件安装配置,详细贴出每一步,不断步骤,让你一次搭建部署完成,希望这篇文章能给大家带来一定的帮助,话不多说开始整 2.0 CentOs安装 2.0.1 下载VM虚拟机 我直

    2024年02月08日
    浏览(52)
  • Jenkins自动化部署-GitLab拉取代码 配置ssh代码拉去方式的密钥(公私钥)

    Jenkins想要通过ssh方式拉去gitlab代码,则需要在在Jenkins服务器配置私钥,gitlab服务器配置公钥 使用root用户生成公钥和私钥 在/root/.ssh/目录保存了公钥和使用 id_rsa:私钥文件 id_rsa.pub:公钥文件 把生成的公钥放在Gitlab中 以root账户登录-点击头像-Settings-SSH Keys 复制刚才id_rsa.pu

    2024年04月10日
    浏览(44)
  • 解放你的双手,让 ChatGPT 来帮你完成 Jenkins 到极狐GitLab CI 的迁移

    目录 可用的 Jenkinsfile ChatGPT 大发神威 极狐GitLab CI/CD 验证结果 自从 ChatGPT 闪亮登场以来,各种基于它的软件扩展纷至沓来。爱折腾的极狐GitLab 开发者们,也花式玩转起了 ChatGPT + 极狐GitLab,让研发工作更高效。 之前我们分享了 如何利用极狐GitLab CI/CD 完成 Jenkins 的迁移。今

    2024年02月04日
    浏览(41)
  • Gitlab自动触发jenkins完成自动化构建 jenkins

     首先安装gitlab插件,我已经安装过了,首次请在 可选插件 中进行搜索。   进入项目配置--构建触发器: Build when a change is pushed to GitLab. GitLab webhook URL: 请复制此处的URL,后续有用。  然后点击高级   “Allowed branches”触发分支可以用默认的全部分支,也可以选择仅由指定名

    2024年02月16日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包