欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

【.NetCore】基于jenkins以及gitlab的持续编译及发布

程序员文章站 2022-07-27 09:34:48
前沿 其实本来是想把标题叫做持续集成的,只是后来看看研究出的内容,就只有发布这一个动作,自动化测试等内容也未涉及到,所以改名叫持续编译及发布应该更加贴切吧? 问题背景 其实目前我们传统方式上的发布方式,一般都是开发人员本地打包,然后传给测试,测试完成之后,发包到项目经理或者实施人员,最后进行部署,对 ......

前沿

  其实本来是想把标题叫做持续集成的,只是后来看看研究出的内容,就只有发布这一个动作,自动化测试等内容也未涉及到,所以改名叫持续编译及发布应该更加贴切吧?

问题背景

  其实目前我们传统方式上的发布方式,一般都是开发人员本地打包,然后传给测试,测试完成之后,发包到项目经理或者实施人员,最后进行部署,对于非互联网项目也许通过人力操作,也可以很好的完成,虽然可能会磕磕碰碰,但是对于互联网的产品,这种方式就显得低效了,每次迭代开发打包验证可能都要花掉不少时间,测试部署也要花掉不少时间,在这种情况下,自动化方案也就显得尤其重要

  按照面向对象理解就是将编译发布等操作进行封装抽象,减少重复的过程(果然万物皆对象么)

什么是jenkins

  那标题既然是基于jenkins,那什么是jenkins呢?百度解释我就抄一个过来了:Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。

  那既然是持续集成的工具,那发布功能肯定也是有的,SO我们就采用jenkins来实现我们的诉求,想想啥时候我们公司也可以有真正的持续集成方式出现呢?

安装技能准备:

  rpm安装方法:

rpm -ivh XXXX.rpm

jenkins安装&配置

安装:

  1、要安装jenkins,那就必须得先安装JDK,先从官方找个jdk的地址(rpm安装):jdk-8u161-linux-x64.rpm,找那个jdk-8u161-linux-x64.rpm,rpm安装之。

  2、jenkins的rpm下载,给个地址:jenkins-2.89.4-1.1.noarch.rpm,然后rpm安装之

  3、安装完关闭防火墙(或者开放8080端口也可以)

  4、service jenkins start;开启jenkins

配置:

  浏览器打开ip:8080

【.NetCore】基于jenkins以及gitlab的持续编译及发布

 

  根据红字部分目录,找到密钥信息输入

【.NetCore】基于jenkins以及gitlab的持续编译及发布

  选择第一个推荐安装,等待一段时间,则安装结束,第一步的初始化配置就到这里结束了

 

.NETCore安装

  参照微软官方安装方法

git安装

  既然我们要基于gitlab跟jenkins,那必须还得装一个git才能pull源码到本地啊,安装方式如下:一句一句执行(参照https://www.cnblogs.com/gsliuruigang/p/7899803.html

yum -y groupinstall "Development Tools"//下载编译工具
yum -y install zlib-devel perl-ExtUtils-MakeMaker asciidoc xmlto openssl-devel//下载依赖包
wget https://github.com/git/git/archive/v2.16.2.tar.gz//下载文件
tar -zxf v2.16.2.tar.gz//解压文件
cd git-2.16.2/
autoconf
./configure --prefix=/usr/local/git make && make install//编译安装 export PATH="/usr/local/git/bin:$PATH"//配置全局路径 source /etc/profile//使配置生效

gitlab配置

  登录ip:8080,到管理插件的地方,安装GitLab Plugin插件,如下图所示

【.NetCore】基于jenkins以及gitlab的持续编译及发布

  

  打开gitlab地址——>个人设置——>account——>复制Private token备用

  【.NetCore】基于jenkins以及gitlab的持续编译及发布

  jenkins——>系统管理——>系统设置——>找到gitlab

【.NetCore】基于jenkins以及gitlab的持续编译及发布

  点击add按钮

  【.NetCore】基于jenkins以及gitlab的持续编译及发布

  最后点击test connection,显示success的话那就是连接是成功的了

 

 

任务构建

  回到jenkins首页——>新建任务——>输入名称——>生成

  1、General

  如下图所示,gitlabconnection选择之前配置的信息

  【.NetCore】基于jenkins以及gitlab的持续编译及发布

 

  2、源码管理

  源码管理主要配置源码库的信息,具体配置如下两图所示,如果以上操作没报错,就是说明成功了,如果报错的话会在Repository URL下面有红字提示,jenkins的branch Specifier会对输入的分支进行构建,所以要选择一个当前库中存在的分支填写。Credentials可以选择通过ssh或者通过http进行,如果通过ssh的话 需要通过公私钥的方式进行认证,我们这边选用用户名密码的方式进行,所以选择Username with password这个选项

  【.NetCore】基于jenkins以及gitlab的持续编译及发布

【.NetCore】基于jenkins以及gitlab的持续编译及发布

 

3、构建触发器

  构建触发器我们选择Poll SCM,如下图所示,这个表示每隔5分钟构建一次,当然也可以选择webhook的方式,通过提交来进行构建,这个在以后需要的时候我会去研究(目前我司还没这需求)

【.NetCore】基于jenkins以及gitlab的持续编译及发布

  4、构建

  这些linux的命令应该都是比较简单的,大家应该都能明白,其实就是模仿人工操作到一个目录下 执行dotnet restore 以及dotnet publish动作,最后publish的目录我设置成了bin/release下面

【.NetCore】基于jenkins以及gitlab的持续编译及发布

  5、执行构建

  点击立即构建,如果不抱错的话,/var/lib/jenkins/workspace/test/bin/release下就会有编译好的代码

持续发布

  以上我们只是将代码从gitlab中获取并且执行了编译,那编译之后呢如何发布到指定的服务器呢,总不能直接就拿jenkins的服务器使用吧,所以接下来我们要做的就是将编译好的程序发布到需要的服务器,还好,jenkins也考虑到了这个需求,有一个publish over ssh插件可以很好的帮我们完成这个工作。

  我们回到之前下载插件的地方,下载publish over ssh

【.NetCore】基于jenkins以及gitlab的持续编译及发布

  回到之前配置gitlab的地方,现在多出了Publish over SSH的配置,如下图所示,我们这里也是选择了使用用户名密码的方式进行操作(同样可以使用ssh的方式进行授权登录)

【.NetCore】基于jenkins以及gitlab的持续编译及发布

  这里配置好了后,我们重新进入任务里,发现多出了一个构建环境,如下所示,红字可以不用管(应该是jenkins的bug)

  Source files表示要复制的文件信息(ps:这里的目录是相对于workspace的)

  remove prefix是去除前缀的意思,否则会创建相应的文件夹,这边我只需要文件,所以整个都去除了

  remote directory 这个文件夹如果不存在的话,那么会在服务端进行创建

  Exec command 拷贝成功后要执行的命令,这里一般的话 都是写个脚本放在服务端,直接执行服务端上的脚本,这里由于dotnet test.dll命令运行后,进程是不会结束的,所以,这里的这个文件我实际上是写了个空文件,真实使用的话可以使用Supervisor开启进程守护,每次发布之后杀掉相应进程,然后由进程守护去启动程序

【.NetCore】基于jenkins以及gitlab的持续编译及发布

 

  点击构建,如果没问题的话,你应该在对应的服务器的目录下看到了publish出来的内容,如果构建失败的话,这里的控制台输出也有非常详细的日志记录,通过日志记录应该是比较容易发现问题的

总结

  jenkins是一个很强大的工具,目前也只是因为公司的需要开始研究,很多功能也还未接触到,包括自动化测试等,后续的方向上,应该是朝着docker以及k8s的方向研究,结合自动化的测试方案,完成真正的持续集成。

  docker方案思考,也是给大家一个思路,其实也就是把构建的脚本换成docker build的方式,再pull到镜像库中,最后通知目标服务器重新拉取镜像生成,运行,问题在于历史的版本库的序号如何一步步生成?

  遗留的问题:针对于数据库的持续集成或者发布,到底要如何去实现?

 

作者: Mango

出处: http://www.cnblogs.com/OMango/

关于自己:专注.Net桌面开发以及Web后台开发,开始接触微服务、docker等互联网相关(最近被互联网架构搞的死去活来- -)

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,如有问题, 可站内信告知.