AspNet 应用程序热更新升级工具

1:下载、开源、使用教程下载地址:
https://github.com/cyq1162/AspNetCoreUpdater/tree/main/release
开源地址:
https://github.com/cyq1162/AspNetCoreUpdater
使用教程:
解压AspNetCoreUpdater.rar,得到两个压缩包,分别对应用Window和linux 。

AspNet 应用程序热更新升级工具

文章插图
 
方法一:使用教程之:For Window IIS1、解压
AspNetCoreUpdaterForWindow,得到一个执行文件和一个配置文件 。
AspNet 应用程序热更新升级工具

文章插图
 
2、打开
AspNetCoreUpdaterForWindow.ini,根据提示,修改对应的参数 。
AspNet 应用程序热更新升级工具

文章插图
 
把对应要升级的dll或其它文件都放到YDLCService.zip包里,并移到发布目录下 。
 
AspNet 应用程序热更新升级工具

文章插图
 
 
3、把软件移到发布的工具目录下,直接运行AspNetCoreUpdater.exe即可,运行过程如下图:
 
AspNet 应用程序热更新升级工具

文章插图
 
热更新完成效果
AspNet 应用程序热更新升级工具

文章插图
 
方法二:使用教程之:For Linux Nginx1、解压AspNetCoreUpdaterForLinux,得到一个dll和2个配置文件 。
AspNet 应用程序热更新升级工具

文章插图
 
2、打开
AspNetCoreUpdaterForLinux.ini,根据提示,修改对应的参数 。
AspNet 应用程序热更新升级工具

文章插图
 
把对应要升级的dll或其它文件都放到update.zip包里,并移到发布目录下 。
并将修改后的nginx.conf也放一份到update.zip包里 。
3、把软件移到发布的工具目录下,命令cd到目录后,运行dotnet AspNetCoreUpdater.dll 即可,运行过程如下图:
AspNet 应用程序热更新升级工具

文章插图
 
2、AspNetCore热更新解决方案产出的过程1、热更新定义:当然是指更新dll等新应用程序后,启动新的程序接收新的请求,并保持原有的程序处理旧的请求,直到旧的请求处理完后,结束旧的应用程序的过程 。
任何其它非以上解释的程序升级过程,都明显有点冷 。
2、产出过程:对于热更新,在AspNetCore之前,IIS一直处理的很好,以至于我们根本不需要思考这个问题 。
直到我写了关于AspNetCore的文章开始后,关于Linux下如何进行热更新,开始有过简单的思考,不过不是实际应用,就没进一步 。
直到最新的项目,建的AspNetCore应用程序,并发布到本地IIS,在内网进行API测试时,一个基本的问题出现了:
我需要喊1声,大伙结束请求10秒钟,然后手工快速结束w3wp进程,然后点发布按钮 。
开发过程,内部还能喊一声,但这样的升级明显是不科学,于是乎就上了一顿的搜索关于“NETCore 热更新”,结果,失望啊 。
于是乎,我添加了一个.net framwork的解决方案,代码还是同一份,用不同的解决方案可以发布不同的版本 。
PS:用过我框架的人都知道,开发方式和代码从来都是不需要改的,唯一的操作只要添加解决方案就可以在两种模式中切换 。
部署也拆分成了两部分,只保持一些业务基本不动的,才用了dotnetcore部署 。
这时候就一个念头产生了:DotNetCore如果热更新不解决,这必然会制约NetCore的大规模应用 。不是每个应用都能等到深夜再更新的;
也不是每个应用都允许随意中断用户请求的;
也不是每个程序员都有实力,能找到一种分布式的繁琐部署流程来解决升级的方法的 。
就像我,搜了国内外的网,就以下几种不靠谱的方案:
【AspNet 应用程序热更新升级工具】1、停机维护的:App_ffline.htm文件 。
2、热更新配置文件:IOptionsSnapshot(只是.json文件) 。
3、天真的动态加载dll想法:AppDomain走不通的 。
4、就一句你去看:ApplicationPartManager的。
发现没有好的解决方案之后,就只能分离一些不太重要,又更新不频繁的业务给了dotnetcore机会 。
随着项目开发阶段忙碌加班的阶段过去之后,终于能分出点时间来研究并解决这个问题 。
经过一番研究:AspNetCore源码、AppDomain源码、和Kestrel源码,打算从应用程序本身搞点事件,结果路走不通....


推荐阅读