前言:作為一名C#開發人員,避免不了常和windows服務以及winform項目打交道,本人公司對服務的管理也是用到了這2個項目的組合方式進行:因為服務項目是無法直接安裝到計算器中,需要使用命令借助微軟的一個程序使用,因此做服務安裝工作的活就交給winform去做了。
關於window服務+winform項目的創建過程,可參考我的另一篇文章:使用C#開發windows服務定時發消息到釘釘群_群組簡單消息
這邊文章只探討:組合項目在發布及部署過程中遇到的很多問題。 現在建設你已經順序創建了這2個項目,並完成了功能的開發:
開發工具:VS2017,操作系統:windows
問題匯總如下:
發布錯誤1-未能在ClickOnce Bootstrapper中找到setup.bin?
解釋:首先你要確保你的VS安裝了ClickOnce功能,沒有開啟的話,開啟一下,使用VS安裝程序即可開啟。
處理方案一:網上扒了一大堆資料,總體意思就是說:缺少SDK,需要重新安裝一下: Microsoft Windows SDK for Windows 7 and .NET Framework 4
參考這邊文章: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
裝好后就有了,通過這個自定義的安裝項目,我們可以把需要文件都扔進去,當然還需要把服務的配置文件一並扔進去。
詳情介紹請看我的另一篇博文:https://www.cnblogs.com/lxhbky/p/10695527.html
總結:由於沒有太多的時間整理,先這樣寫吧,基本上把我自己使用這個winform+window服務這種組合項目,在發布過程中以及,怎么創建自定義安裝包來快速,部署到測試中,遇到的問題說全了,希望可以幫助到遇到類似問題的道友。。。
以后再整理文章的結構。。。