前言:做爲一名C#開發人員,避免不了常和windows服務以及winform項目打交道,本人公司對服務的管理也是用到了這2個項目的組合方式進行:由於服務項目是沒法直接安裝到計算器中,須要使用命令藉助微軟的一個程序使用,所以作服務安裝工做的活就交給winform去作了。html
關於window服務+winform項目的建立過程,可參考個人另外一篇文章:使用C#開發windows服務定時發消息到釘釘羣_羣組簡單消息程序員
這邊文章只探討:組合項目在發佈及部署過程當中遇到的不少問題。 如今建設你已經順序建立了這2個項目,並完成了功能的開發:windows
開發工具:VS2017,操做系統:windows安全
問題彙總以下:服務器
發佈錯誤1-未能在ClickOnce Bootstrapper中找到setup.bin?app
解釋:首先你要確保你的VS安裝了ClickOnce功能,沒有開啓的話,開啓一下,使用VS安裝程序便可開啓。工具
處理方案一:網上扒了一大堆資料,整體意思就是說:缺乏SDK,須要從新安裝一下: Microsoft Windows SDK for Windows 7 and .NET Framework 4post
參考這邊文章:https://stackoverflow.com/questions/11139538/could-not-find-required-file-setup-bin開發工具
處理方案二:若是上面解決不了你的問題,你能夠經過VS2017安裝程序中的組件安裝,安裝一下組件:Visual Studio SDK,以下圖:測試
發佈錯誤2-清單中的引用與下載的程序集標識不匹配?
解釋:這個問題固然也google了,意思就是你須要改下項目的屬性-->安全性-> 勾選:啓用ClickOnce安全設置,和,這是徹底可信任的應用程序。 參考文章:https://blog.csdn.net/soft_123456/article/details/38080667
也有人解釋的更深一步,說是項目的引用程序集版本號與實際程序集版本號不一致致使的,參考文章:https://blog.csdn.net/linybo/article/details/44699315
我本身走的是第一個方案,大家能夠本身去研究去嘗試,時間有限,事情繁多,沒有仔細去試。
小結:其實上面2個錯誤,雖然都嘗試過,可是最好仍是並無真正解決個人問題,我發佈後仍是出現相似莫名其妙的錯誤,這可能也與個人一個操做過程有關(我本來用的VS2015,又安裝了VS2017,裝好17後就把15給卸載了),
個人終極解決方案是:使用VS2017自帶的安裝程序,從新又修復了一下VS的整個程序,而後上面2個問題就都迎刃而解了。不明覺厲! 可能真的我操做過程致使的,而後若是你修復VS程序後還不行,能夠參考上面的解決方案,逐個去試吧,咱們程序員就愛幹這個。
這篇文章的主要內容是下面:
發佈錯誤3-正常狀況下,winform項目和服務項目沒有直接關聯關係,winform能夠將服務EXE路徑寫死,進行服務的安裝和卸載便可。 可是本人就是想搞一個測試的按鈕,在winform中引用服務項目,調用服務中的類進行方法測試,而服務在自動運行的過程當中就又跟winform程序無關了。 項目是能夠經過VS直接使用發佈功能了。
我這裏只發布了winform項目,因爲項目存在引用關係,winform發佈的文件中自動包含了一個服務的EXE程序集,過高興了,就不用再單獨發佈服務項目了,可是發佈後,在安裝服務後遇到了一個關鍵問題:服務的程序集EXE,是deploy類型,沒法直接使用,太奇怪了,後來發現這塊是能夠設置的:項目屬性->發佈->安裝模式和設置選項->部署-> 取消勾選:使用".deploy文件擴展名",我是這麼解決的,大家自由發揮哈!!
下一步:服務是能夠正常安裝了,沒毛病,可是服務運行過程當中,讀配置文件app.config時(我加了日誌發現的,你不加日誌是發現不了的,除非報異常),找不到數據了?缺乏服務的配置文件?
其實想一想也是,即便已經有了EXE程序集,可是我只發佈了一個winform項目,那發佈文件中,確定只有一個winform的配置文件了,怎麼可能會有服務的配置文件呢,服務的EXE也只是一個程序集供winform使用,就好像一個DLL同樣,在你winfrom只用調用服務類中方法時,走的也是winform的配置文件。 可是關鍵是脫離winform的管理後,服務會獨立運行,若是服務本身有配置文件,那服務執行過程當中確定會出現問題,怎麼去保證:2個配置文件同時存在,且又不用發佈2個項目呢?
(若是你的服務項目不須要配置文件除外;若是你2個項目分開發布也沒有問題,分開發布須要在winform中指定服務EXE程序集的位置,不能使用引用的EXE程序集,由於它默認沒有配置文件,除非你不要配置文件;)
最簡單的解決方案:咱們不使用發佈功能不就完了,編譯後的項目,bin/debug目錄下的文件是能夠直接使用的,直接Copy到服務器就能夠了。這種方案,我們研發人員固然OK了,咱們公司就是這麼作的,不須要發佈,就再調整一下服務的路徑就能夠在測試服務器用了。
固然個人項目是,經過安裝程序,發佈功能,走一個包裝過程,而後小白也能直接安裝的,那麼接着往下看:
解決方案一:像上面分析同樣,把服務的配置文件數據寫死到服務中。 太粗暴了,不便於維護。
解決方案二:2個項目分開發布,各個走各自的配置,互不干擾,可是須要在winform中指定服務程序集EXE的具體路徑。 稍微麻煩
推薦解決方案三:其實本身看,winform的發佈文件能夠看出,發佈的文件其實也就是一個安裝程序,發佈選項中,能夠查看程序集文件,設置必須的系統組件,清單,說明等,那麼能夠總結爲:如何在安裝程序中,添加2個配置文件進去?
後來在發佈裏面始終找不到答案,太TM煩人了,不事後來想到了一個解決方案,就是VS是有自定義安裝程序的項目,叫:Setup Project,VS2010,2015自帶這個項目的,可是VS2017給砍掉了,作成了一個插件,須要本身去安裝,妹的!
大家能夠搜索:Microsoft Visual Studio 2017 Installer Projects,在VS的插件擴展中,或者VS官網均可以。我是經過官網裝的:https://marketplace.visualstudio.com/items?itemName=visualstudioclient.MicrosoftVisualStudio2017InstallerProjects
裝好後就有了,經過這個自定義的安裝項目,咱們能夠把須要文件都扔進去,固然還須要把服務的配置文件一併扔進去。
詳情介紹請看個人另外一篇博文:http://www.javashuo.com/article/p-zxneayrq-bx.html
總結:因爲沒有太多的時間整理,先這樣寫吧,基本上把我本身使用這個winform+window服務這種組合項目,在發佈過程當中以及,怎麼建立自定義安裝包來快速,部署到測試中,遇到的問題說全了,但願能夠幫助到遇到相似問題的道友。。。
之後再整理文章的結構。。。