使用Jenkins部署.Net Core遇到的几个坑

搞过CI/CD的同窗必定吃过很多苦头,或者说遇到很多坑,可是对自动化的执着住挡不了前进的步伐,若是你缺乏了运维这一块知识,那么你的流水线老是不那么完美,本文记录的是本身躺过的坑,但愿对你有所帮助。html

1、相关环境和版本

  • 服务器:windows2008【历史遗留服务器,建议升级到2012以上,2016支持Windows的容器化技术】
  • 源代码管理:git
  • .net core版本:net core 2.2

  这里最应该注意的是操做系统版本和Jenkins的版本,不一样的版本,特别是操做系统操做的shell可能千差万别,你会在网上看到各类命令,因此选择好本身的环境。前端

安装Jenkins比较简单,这里略过……python

2、Jenkins相关配置

Step1.建立一个自由风格的Jenkins项目,这一步比较简单略过(pipeline项目是一项更加挑战,也许运维高手更须要熟悉,这里跳过)linux

Step2.在 配置git 源码路径的时候报错:

解决方法git

1.安装git client插件,并重启jenkinsgithub

2.确保安装jenkins的服务器同时也安装了git,并在jenkins上配置git的路径,以下图:shell

3.成功配置git源码路径json

 

Step3.构建时候报错:windows

从中能够判断,个人邮件尚未配置,因此发送报错……api

Step4.进行 邮件的配置
  • Jenkins内置邮箱功能:

1.首先配置Jenkins Location

所在路径:Manage Jenkins=》Configure System=>Jenkins Location

2.配置E-mail Notification以下图所示

3.测试发送成功

  • Email插件:Email Extension

插件安装后以下图所示:

step5.构建的坑[该坑最耗时间,最后发现倒是最简单]

1.请指定项目或解决方案文件。当前工做目录中未包含项目或解决方案文件。

排查:切换到服务器cmd下进行restore后发现,原来是nuget做怪,由于服务器没法找到部署在本地服务器的nuget包

2.发布Nuget包到官网

试着解决:试着把nuget包发布到官网。具体如何发布请跳转

新版本的发布须要增长License.txt,不然没法经过,配置以下:其中Licese是从github上拷贝过来的。若是你发布后发现代码没有生效,请确认你是否在release下进行编译,而且build过?

 解决方法:以下图所示,极其简单,折腾的半天,晕!你甚至dotnet restore和dotnet build都不用写,由于dotnet publish自己包含restore和build

Step6. 卡住在using GIT_ASKPASS to set credentials的坑

Unable to delete 'D:\Program Files (x86)\Jenkins\workspace\Stone.Base.API'. Tried 3 times (of a maximum of 3) waiting 0.1 秒 between attempts.

解决方法:关闭配置里的删除功能

6.构建的时候卡住在using GIT_ASKPASS to set credentials 

解决方法

Step 1:開始 -> 命令提示字元 -> 滑鼠右鍵 -> 以系統管理員身分執行

Step 2: 找出Jenkins Server 的Git 布置位置,能够從本身的Jenkins 錯誤中知道位置在哪裡,如下是第一張圖顯示的Git 

Step3: 將命令提示字元(管理者權限) 移動到該位置,輸入cd C:\Program Files\Git\bin 移動到該目錄

Step 4: 輸入 git config --system --unset credential.helper ,按下Enter

Step 5: 再从新建置Jenkins Job 就能够正常運行了

Step7. 没法复制的坑

现象:没法将“obj\Debug\netcoreapp2.2\Stone.Base.API.dll”复制到“E:\Jacky\WebAPI\Base.API\Stone.Base.API.dll”

缘由:该站点正在运行,dll被占用,没法进行替换覆盖

解决方法

  目前暂时尚未找到方法,后面再作补充……

Step8.没法删除的坑

缘由:该站点正在运行,没法进行替换覆盖

解决方法:把Delete workspace before build starts选项勾去掉,以下图:

3、全自动发布自家类库到Nuget官网或自家服务器

  这里的发布改进了以往的手工发布。从代码上传那一刻开始,jenkins自动到git抓取代码,自动编译打包,而后上传到nuget服务器。

jenkins配置以下:这里有不少坑,特别是linux和windows很不同,同窗们要留意。配置其实不麻烦,全部的jenkins编译均可以在系统内部自行跑一遍,若是系统能跑通,jenkins绝对没有问题。具体配置以下图所示:

dotnet build "D:\Program Files (x86)\Jenkins\workspace\Stone.Util\UtilLib\Stone.Util"  -c Release


md publish\nuget
md publish\archives


dotnet pack "D:\Program Files (x86)\Jenkins\workspace\Stone.Util\UtilLib\Stone.Util" -c Release -o publish\nuget


dotnet nuget push "D:\Program Files (x86)\Jenkins\workspace\Stone.Util\UtilLib\Stone.Util\publish\nuget\*.nupkg" -k {本身key} -s https://api.nuget.org/v3/index.json


move "D:\Program Files (x86)\Jenkins\workspace\Stone.Util\UtilLib\Stone.Util\publish\nuget\*" "D:\Program Files (x86)\Jenkins\workspace\Stone.Util\UtilLib\Stone.Util\publish\archiv

 

参考文献:

4、Jenkins经常使用插件

  • Green Balls

该插件让你的感官有了更好的提高,客官请看:

  • Build Monitor View

很是棒的构建看板,把团队信息透明度提高一个档次,不再用听到前端开发在问:“有人在构建吗?”,客官请看:

5、总结

  jenkins是如此强大,以致于今年来基本上一统CI、CD的江山,他的内容又是如此之多,足够写一本书,感叹所学只不过它的冰山一角。在pipeline项目中,它也支持python等其余脚本语言的流水化做业,功能很是之强大,期待后面的挖掘和丰富……

相关文章
相关标签/搜索