你的團隊須要一個正確的程序集(dll)管理姿式

不少團隊經歷時間的積澱以後,都會有不少的可重用的公共技術組件。大部分的團隊都會把這些公共組件生成程序集(dll)後,放到GIT或SVN的一個公共目錄裏面,以供各個項目中使用。起初在項目不多又或者是公共組件很少的時候,這樣看起來也沒有多大問題。可是隨着團隊愈來愈大,項目的組件增多,所封裝的可重用組件愈來愈多,一些問題就會慢慢暴露出來。這個時候若是仍是使用這種方式去管理程序集,顯然就不太合適了。git

咱們知道,在Java中比較經常使用的包管理工具,如Maven。實際上在不少大公司裏面都會搭建本身公司的Maven私服,以管理公司的一些公共技術組件。github

實際上在.net中也有,你們也絕對不陌生,就是Nuget, 相信每一個人都從官方的nuget服務器上下載過一些第三方組件,如:log4net、quartz.net等等。web

Nuget是一個.NET平臺下的開源的項目,它是Visual Studio的擴展。在使用Visual Studio開發基於.NET Framework的應用時,Nuget能把在項目中添加、移除和更新引用的工做變得更加快捷方便。這是維基百科中的定義,實際上Nuget就是一個包管理器,相似於Java的Maven,能夠幫助咱們更方便的管理dll,這也是微軟提供給.net平臺的一個正確的包管理工具。api

而如Maven同樣,Nuget也能夠搭建本身的私服。這篇文章就來簡單介紹一下如何搭建屬於大家團隊本身的Nuget服務器。緩存

1、下載Nuget.Server

    從官方Nuget服務器上搜索nuget.server,點擊項目url中的github路徑。從github中下載nuget.server的源碼。

下載並解壓後的文件路徑以下圖所示:
服務器

2、搭建Nuget.Server

  1. 打開項目文件NuGet.Server.sln,找到NuGet.Server,右鍵發佈,選擇文件系統(跟發佈web程序同樣,發佈到IIS中)。
  2. IIS新建站點MyNuGet

    啓動程序出現如下頁面表明搭建成功
  3. 注意:若點擊here出現404頁面以下圖所示:

    能夠經過VS運行起來Nuget.Server項目,而後將bin目錄替換IIS下的bin目錄,便可解決。出現下圖表明搭建成功

    打開VS的Nuget管理器,點擊圖中設置圖標,新建咱們本身的nuget服務器

    以後就能夠連上咱們本身搭建的服務器了

3、自建NuGet基本使用

  1. 下載NuGet命令行打包工具nuget.exe
    下載地址:https://www.nuget.org/downloads併發

  2. 打包咱們程序框架

  • 方式1:經過類庫文件csproj的方式打包
    首先打開咱們程序的AssemblyInfo.cs文件修改程序集信息

使用nuget.exe打包程序集

在.csproj文件目錄下執行命令spec工具

nuget.exe spec //spec 在.csproj文件目錄下執行命令


此時會生成一個.nuspec文件,打開這個文件
修改其中的xml屬性便可(注意此處一些信息最好和AssemblyInfo.cs中的程序集信息一致)

修改完成後繼續執行pack命令

這時將生成的.nupkg文件直接copy到nuget服務器IIS目錄下的packages文件夾內便可
也可經過命令push推送至nuget服務器url

nuget push *.nupkg -s http://127.0.0.1:8005 123456 //push 程序包路徑 選項 地址 apikey
//apikey 能夠在服務器webconfig中配置

完成後便可查看或使用咱們發佈的程序集

4、問題

若是你認爲以上就結束了,那你就太天真了,實際上,咱們團隊在搭建與使用過程當中仍是遇到了不少問題的,若是搭建使用中踩到了一樣的坑能夠參考下面幾點。

  1. 在剛開始使用的時候常常由於失誤或者程序有問題從而致使須要從新發布nuget包,可是發現覆蓋掉原來的以後,項目裏更新下來的始終仍是原來的程序。
    解決:慎重慎重再慎重打包,須要從新發布包的時候能夠升級,不能覆蓋。(當時認爲這個東西只能升級不能覆蓋)
  2. 用了一段時間後,因爲當時至提供了nuget管理包的技術方案,卻沒有相應的使用規範與制度,致使團隊nuget包混亂,開發人員胡亂升級,胡亂引用nuget包,終於有一天形成大問題。所以須要制定一個完善的使用規範與制度,包括如何打包,如何發佈,誰來打包,誰來發布,慎重打包、升級、專人管理等
  3. 因爲問題2引發的問題,所以決定從新整理nuget包(不破不立),因而從新搭建了一個nuget服務器,從新規整雖有的程序集、組件、從新打包發佈等,可是發現遷移到新的後,項目中下載下來的程序集仍是原來的。(又遇到了問題1)。此次靈感一來發現問題解決方案。VS2017經過工具->選項->清除全部NuGet緩存 再從新下載包問題便可解決

    若沒有VS2017或找不到清楚NuGet緩存選項,也可找到本身機器上nuget的緩存文件夾刪除掉裏面對應的內容也能夠,通常是在C:\Users\Administrator.nuget

小結

今天簡單介紹瞭如何搭建本身團隊的Nuget服務器,以及如何打包併發布程序集到Nuget。實際上,大多數的.net團隊仍然是在用SVN或GIT的方式去管理dll,包括我所在的某大廠,雖而後來框架研發部,提供了一個自主研發的管理工具,但我我的感受仍是不如Nuget更好用一些。

若是你的團隊不知足如今的程序集管理方式,那麼不妨換個姿式,搭建一個屬於大家團隊本身的Nuget服務器吧!固然,若是你有更好的方式,歡迎與我留言分享!

相關文章
相關標籤/搜索