开发.NET Core NuGet包并实现CI/CD

实际开发中我们需要对一些公共类库进行开发,并基于Jenkins进行CI/CD(CI:持续集成,CD:持续部署),其他项目通过NuGet引用。上文讲述了如何搭建本地NuGet服务器并发布NuGet包,这里不再赘述。

CI/CD流程如下图:

首先公共类库代码通过Git管理,编辑完代码后上传到Git服务器。

配置Jenkins Job,按设定的触发条件进行构建任务。

构建开始,删除Workspace中旧文件,从Git服务器下载最新代码,执行编译,生成NuGet包,上传到NuGet服务器。

这样,别人就可以引用或者更新最新的公共类库的NuGet包进行业务开发了。

在Visual Studio中操作

  • 自定义打包类库

新建一个.net core 的类库,在工程文件处右键,选择属性,在“打包”中勾选“在版本中生成NuGet包”,然后设置基本信息。如下图:

编译生成,就会在Debug/Release目录生成一个nupkg文件:

  • 自动更新编译版本

关于版本号:
这里指Net Framework风格的版本号,
即,主版本号.子版本号[.编译版本号[.修订版本号]]
英文对照:
Major_Version_Number.Minor_Version_Number[.Build_Number[.Revision_Number]]
主版本号和次版本号是必选的;
编译版本号和修订号是可选的,但是如果定义了修订号部分,则编译版本号就是必选的。
所有定义的部分都必须是大于或等于 0 的整数。
应根据下面的约定使用这些部分:
Major :具有相同名称但不同主版本号的程序集不可互换。例如,这适用于对产品的大量重写,这些重写使得无法实现向后兼容性。
Minor :如果两个程序集的名称和主版本号相同,而次版本号不同,这指示显著增强,但照顾到了向后兼容性。例如,这适用于产品的修正版或完全向后兼容的新版本。
Build :编译版本号(内部版本号)的不同表示对相同源所作的重新编译。这适合于更改处理器、平台或编译器的情况。
Revision :名称、主版本号和次版本号都相同但修订号不同的程序集应是完全可互换的。这适用于修复以前发布的程序集中的安全漏洞。

在Visual Studio中选择NuGet包管理器,搜索“MSBump”,安装,然后在工程文件下新建一个.msbump文件,写入如下代码:

{
  Configurations: {
    "Debug": {
      BumpLabel: "dev",
      LabelDigits: 4
    },

    "Release": {
      BumpRevision: true,
      ResetLabel: "dev"
    }
  }
}

上文表示:当编译配置为“Debug”时,版本号生成一个dev前缀后面跟四位数字的标签,数字从0001开始递增。当编译配置为“Release”时,修订版本号会+1,清除dev标签。当然,也可以直接在.msbump中这样写:

{
    BumpRevision: true
}

意思就是每次编译不管debug还是release,都会使修订版本号+1

在Jenkins中操作

前提操作:
需要下载NuGet.exe,并且把NuGet.exe所在目录和MSBuild所在目录加入到环境变量中,这样方便在Jenkins中直接使用msbuild和nuget命令。

  • 安装Jenkins

这里不再赘述,自行百度,就是安装Java那套环境

  • 新建任务

新建任务,起个名字,选择“构建一个自由风格的软件项目”,点击“OK”:

  • 编辑配置信息

我们用的是Git管理代码,所以源代码管理里选择Git,输入仓库地址和用户名密码,选择需要拉取的分支名称:

触发条件,可以根据自己的需求,比如每日定时调度:

编译环境中选择编译开始前清空Workspace,保证拉取最新代码不冲突:

编译步骤中,选择执行Windows批处理命令,主要执行如下操作:
1.进入工程文件目录
2.还原所有依赖的包
3.执行编译Release版本
4.进入Releas目录
5.将生成的nupkg文件推送到NuGet服务器
6.由于生成操作修改的修订版本号,所以将修改的文件提交

代码:

cd GAIA.GISmsbuild -t:restore
msbuild /p:Configuration=Release
cd bin\Releasenuget push *.nupkg -Source http://192.168.1.209:1024/nuget iwehave2305!
git commit -a -m updateversion

如图 :

创建编译后事件,将修改记录推送到git服务器,也可以加失败邮件通知等等操作:

保存

立即构建测试一下,大功告成~

原文地址:https://www.cnblogs.com/hao-zhang/p/10178641.html

时间: 2024-10-21 06:58:47

开发.NET Core NuGet包并实现CI/CD的相关文章

rancher+gitlab+appveyor 实现 CI/CD 流水线(汇总)

rancher+gitlab+appveyor 实现 CI/CD 流水线 本文主要是做一些汇总,将近期接触并弄好的一些工具整合起来,弄一套流水线,减轻一定工作压力 工具介绍 所有的组件都是使用 docker 跑的,所以一款好用的 docker 的 ui 管理工具很重要,那就是rancher.这里只是用来管理一些工具,有点屈才了 项目代码托管使用 gitlab,其内置了 CI/CD,成套使用,非常方便 appveyor 也是一个 CI/CD 解决方案,基于asp.net core开发.其内置 nu

asp.net core 三 Nuget包管理

参考连接:http://www.cnblogs.com/netcore2/p/7412891.html 这里的说明,基本就是学习了别人的文章,自己做了个备份 asp.net core中,针对项目中的包管理,做了很多的性能优化,如果项目中通过Nuget引用了包,但是在项目目录找不到了package文件,而且生成目录也没有对应的应用的dll生成,那项目是如何运行以及引用nuget包,这些包都在哪里? 1.对于应用程序引用的Framework包,微软提供了运行时包仓(runtime package s

运用.net core配合VS 2015制作nuget包

以往做nuget包我们一般要么用命令行,要么用nuget的图形化界面去做,但是一些操作比较麻烦.比如引入命名空间,引入第三方nuget包.今天,我们来讲解下一种全新的构建方式. 环境: win10 VS2015 企业版 .net 全家桶(.net framework,dnx,.NET core) Why: 运用.net core+官方这种特殊类库项目,一切都可以用代码编辑完成,不需要做一些对我们来讲非常额外的工作,于是乎,构建变得无比简单.本人强烈建议以后做nuget类库的时候都用这样的方法.

一个技术汪的开源梦 —— 基于 .Net Core 的组件 Nuget 包制作 & 发布

微软的 ASP.Net Core 强化了 Nuget 的使用,所有的 .Net Core 组件均有 Nuget 管理,所以有必要探讨一下 .Net Core 组件制作 Nuget 包和发布. 之前 .Net Framework 程序集打包 Nuget 有以下方法: 1. 使用命令  nuget pack  详见博客园的一篇博文 <用命令行工具创建 Nuget 程序包>: 2. 使用 NuGet Package Explorer: 3. vs 插件 NuBuild Project System.

.NET Core 学习笔记2&mdash;&mdash;管理nuget包

.NET Core 基于Nuget包.它是一个.nupkg后缀的zip文件. 工具 dotnet 工具 vs2017 的程序包管理控台 这两个工具都可以用命令行来下载安装,更新,上传包(上传要先在网站注册账号):也可以用vs里面的UI工具管理. 项目文件控制包 项目文件(.csproj后缀)是一个xml文件,描述了引用包的关系,很多时候需要手工编辑这个来达到高级目标. <ItemGroup> <!-- ... --> <PackageReference Include=&qu

.Net core 还原Nuget包失败的解决方法

今天是2018最后一天了,真是神奇的一年啊,写个博客压压惊,来年继续加油吧..... 正文: 当我们打开.net core 项目时候,发现输出提示nuget包还原失败,这个时候首先要考虑.Net Core SDK的版本,可以用命令行去查看,命令行界面输入dotnet --version 就可以知道所安装的SDK是什么版本的了.如图,我安装的是2.1.502 版本 由于.net core 是向下兼容的,所以如果安装的是2.0,项目使用的又是2.1,那么有可能会造成nuget包还原失败. 如果版本和

如何发布同时支持.net core和.net framework的nuget包

原文:https://blog.csdn.net/quxing10086/article/details/80258422 项目支持多版本的改造步骤 过程中其实没有想到,要发布一个同时支持 Net Standard 2.0 和 Net Framework 4.5 版本的 Nuget 包,还是比较繁琐的.需要将原来的两个分支的代码合并到一起,并通过预处理命令来分别编译为不同版本. 下面,简单记录一下一些重要的步骤: 创建并使用新的 Net Standard 项目文件格式来创建. 修改 Rafy.c

.NET Core + EF 报nuget包不兼容

错误信息如下: 严重性 代码 说明 项目 文件 行 禁止显示状态错误 NU1107 Microsoft.EntityFrameworkCore 中检测到版本冲突.直接安装/引用 Microsoft.EntityFrameworkCore 2.2.4 到项目 CoreWeb 可解决此问题. CoreWeb -> CoreWeb.Entities -> Microsoft.EntityFrameworkCore.SqlServer 2.2.4 -> Microsoft.EntityFrame

.Net core 程序Nuget包独立存放 (二)

在上篇博文.Net core 程序Nuget包独立存放(一)中介绍了运行环境中,如何实现将nuget库存放,还有一个问题没有解决:如何将nuget包从publish的程序集中分离.本文就介绍下如何解决这个问题: 首先,利用dotnet store命令,将nuget包导出,同时并生成目标清单. dotnet store -m test.csproj -r win-x64 --skip-optimization --skip-symbols -o r:\packages 这个命令也可以用于解决方案文