C#實現(xiàn)熱更新服務(wù)器程序的具體過程
熱更新有沒有解決一些開發(fā)問題的痛點
其實首先探討的一個問題就是,熱更服務(wù)器程序到底有沒有必要出現(xiàn),或者說有沒有適用場景,我個人覺得吧還是有的。
如果真的可以在不重啟應(yīng)用的情況下實現(xiàn)邏輯的更新,這未嘗對于一些緊急的情況不是一個好消息,尤其是一些小團隊、小創(chuàng)業(yè)公司剛起步的時候,技術(shù)測試流程和人力不會像成規(guī)模的企業(yè)那樣完善,那么帶來的問題就是上線后的應(yīng)用、游戲可能會存在一些Bug,如果不嚴(yán)重還好,可以留到下一個迭代更新統(tǒng)一修復(fù),但是如果嚴(yán)重了,又考慮如果此刻關(guān)服修復(fù)會導(dǎo)致用戶流失,那么這時候不停服熱更新就有了應(yīng)用場景,可以在用戶無感知的情況下進(jìn)行邏輯的修復(fù)工作。這也是熱更功能主要的適用場景,至于增加新功能或者刪除一些功能也可以通過不停服的方式來操作。
那么說完這個需求后,接下就是怎么才能實現(xiàn)這個功能。其實這個功能主要還是利用了C#自帶的反射,在新的Dotnet框架中.net core3.0以后和.net5.0以后,微軟對Assembly加載做了進(jìn)一步整理,雖然以前也有類似功能,但是眾所周知的原因,以前的.net版本混亂,現(xiàn)在微軟既開源也統(tǒng)一化版本,可以說在未來時間里,.Net的潛力不可估量,那么我所講的,也是基于較新的框架版本實現(xiàn)的。
熱更新實現(xiàn)原理
AssemblyLoadContext 這個類就是今天的主角,它的主要功能就是隔離式的程序上下文,什么意思,就是它具備一定保護,可以使動態(tài)加載的程序集不和靜態(tài)加載的程序集混合在一起,而是獨立運行在類似沙盒的空間里,但是又具備相互訪問的權(quán)限。這就很厲害了,這樣一來,我們可以加載自己的程序集,然后供本來應(yīng)用調(diào)用,在需要更新的時候,把新的程序集加載進(jìn)來,并且替換舊的程序,釋放舊的程序集,這樣就可以無縫銜接的執(zhí)行新的邏輯了。
下面我就借用我自己寫的框架來實現(xiàn)這個熱更的過程,如果對熱更原理本身感興趣的,也可以去看看我寫的熱更源碼,我會在文章最下面貼上我的開源項目地址,源碼里面基本上都是有注釋的,所以看起來也不會很難。
具體的實現(xiàn)過程
首先我們創(chuàng)建一個.Net5.0或者.Netcore3.1的項目,取名Abc。
創(chuàng)建成功,我們找到依懶項,右擊管理Nuget程序包,選擇瀏覽標(biāo)簽搜索:EasySharpFrame,然后選中后點擊下載按鈕進(jìn)行安裝。
安裝完成后,框架就算成功安裝好了,接下來,我們再從解決方案右擊新建一個新的項目,這個項目就是用于熱更邏輯實現(xiàn)的動態(tài)庫,名字就叫Hotfix,創(chuàng)建之后,在解決方案資源管理器一欄中就會看到這個項目已經(jīng)成功添加進(jìn)去了,之后我們右擊這個Hotfix項目的依賴項,找到添加項目引用,直接把 Abc 勾選確定,至此項目的添加創(chuàng)建步驟就完成了。
接下來就是開始寫代碼實際應(yīng)用了,首先在Abc主項目中的Program.cs入口中,調(diào)用框架中熱更管理單例。因為我們沒有更改Hotfix項目的默認(rèn)配置,所以生成出來的Dll文件名就是Hotfix,然后我們在Hotfix項目里添加一個Main.cs的入口文件,這里通過熱更管理器就完成了初始化,后面每次重載也只需要重復(fù)這個步驟就可以了。
class Program { static void Main(string[] args) { Console.WriteLine("Hello World!"); // 確保進(jìn)行不會自動結(jié)束 while (true) { // 調(diào)用熱更模塊加載Hotfix HotfixMgr.Instance.Load("Hotfix", "Hotfix.Main"); // 回車?yán)^續(xù),否則阻塞 Console.ReadLine(); } } }
接下來,我們在Hotfix項目里Main.cs中加點測試內(nèi)容。
public class Main { public void Hello() { Console.WriteLine("Hello World"); } }
并且在剛剛主工程代碼里加點東西。
// 調(diào)用熱更模塊加載Hotfix HotfixMgr.Instance.Load("Hotfix", "Hotfix.Main"); // 這里可以通過Agent調(diào)用測試入口的函數(shù) HotfixMgr.Instance.Agent.Hello(); // 回車?yán)^續(xù),否則阻塞 Console.ReadLine();
這樣一個簡單的熱更事例就完成了,接下來生成解決方案。然后找到Hotfix項目生成路徑,把關(guān)于Hotfix.dll和Hotfix.pdb兩個文件復(fù)制粘貼到Abc的生成路徑下。雙擊Abc.exe,啟動事例查看結(jié)果。注:pdb是用于給運行時提供出錯時準(zhǔn)確提示錯誤的解釋文件,實際運行只需要dll,如果不需要查看問題出處,可以只復(fù)制dll即可。
此時不要關(guān)閉控制臺,繼續(xù)回到VS中,修改一下Main.cs的內(nèi)容,并且這次只生成Hotfix項目,把生成好的dll和pdb復(fù)制到Abc中。
public class Main { public void Hello() { // 修改前 // Console.WriteLine("Hello World"); // 修改后 Console.WriteLine("Hello New World"); } }
替換完成后,在控制臺回車一下,結(jié)果顯示,新的邏輯已經(jīng)更新至程序中。
以上就是一個簡單的熱更流程展示,框架提供的熱更功能還有更多功能,這里只是簡單介紹一下熱更的原理與實現(xiàn)。如果對框架感興趣的朋友可以到github上去了解。
項目地址:github.com/suxf/EasySh…
總結(jié)
到此這篇關(guān)于C#實現(xiàn)熱更新服務(wù)器程序的文章就介紹到這了,更多相關(guān)C#熱更新服務(wù)器程序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C# 通過同步和異步實現(xiàn)優(yōu)化做早餐的時間
本文以一個簡單的小例子—如何做一頓早餐及如何優(yōu)化做早餐的時間來讓大家具體了解一下同步和異步方法的區(qū)別,需要的朋友可以參考一下2021-12-12