搞过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.进行
邮件的配置
1.首先配置Jenkins Location
所在路径:Manage Jenkins=》Configure System=>Jenkins Location
2.配置E-mail Notification以下图所示
3.测试发送成功
插件安装后以下图所示:
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经常使用插件
该插件让你的感官有了更好的提高,客官请看:
很是棒的构建看板,把团队信息透明度提高一个档次,不再用听到前端开发在问:“有人在构建吗?”,客官请看:

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