我发起了一个 .Net Core 平台上的 开源项目 ShadowDomain 用于 热更新

大家好,  我发起了一个 .Net Core 平台上的 开源项目 ShadowDomain  用于 热更新 。

 

简单的说, 原理就是 类似 Asp.net 那样 让 当前 WebApp 运行在一个 App Domain 中,

当 WebApp 的 Bin 目录 或者 Web.config 被更新时, 就会 创建一个 新的 App Domain,

我们把 这个 新的 App Domain 称之为  “New Domain”,  

把 原来的 正在运行的 App Domain 称之为  “Old Domain” ,

 

然后, 将 更新后的 程序(Bin目录 ,  Web.config)  运行在 New Domain 下,

然后, 等 Old Domain 里把 已经在 处理的 请求 都 处理 完成后,  就 停止 和 销毁 Old Domain 。

 

这样就可以 实现 在线热更新,或者 运行中热更新, 

也不需要考虑 更新文件 后 要 重启 应用程序 等问题 。

 

这个项目里 包含 3 个 部分 :

1  一个 Host 框架 for Kestrel,   这是 Asp.net 的部分

2  一个 Host 框架 for Windows Service,    这是 Windows Service 的部分

3  一个 Host 框架 for Linux AP ,  就相当于是  Linux 上的  Windows Service, 我不知道 Linux 上的 Windows Service 叫什么, 就叫 AP 好了

 

1 的 原理就是 把   Kestrel 作为一个 应用(AP), 通过 Host 创建一个 App Domain , 让 Kestrel 运行在这个 App Domain 里,

有更新的话, 就像上面说的,  创建一个 New Domain , 让 更新后的 程序 运行在 New Domain, 

同时 等 Old Domain 处理完 请求, 则 停止 和 销毁 Old Domain 。

 

2 , 3  的 原理 类似 。

 

至于 Shadow Domain, 也许是指 New Domain, 也许是指 Old Domain, 我记不清了……  反正都讲得通 。哈哈哈

 

Shadow Domain 这个项目 的 意义 在于 为 ServerFul 架构 提供了支持,

有关 ServerFul 架构, 请参考我写的另一篇文章  《我发起了一个支持 ServerFul 架构的 .Net 开源项目 ServerFulManager》

https://www.cnblogs.com/KSongKing/p/9899199.html

 

同时, 像 ServerFul 架构一样, 简化了 服务器集群管理 的 工作, 比如 不需要考虑 重启应用, 只需要 覆盖文件, 省去了 编写脚本 重启应用 等工作, 以及 避免了 使用 容器(比如 Docker)等 复杂技术 。

 

不过 实际 实现起来 问题 也很多 。 比如 Kestrel, 按照上述的原理, Old Domain 要处理完当前已经在处理的请求 才会 停止和销毁 。

而 是否已处理完请求 这只有 Kestrel 自己才知道 , 所以 ShadowDomain 大概要 Kestrel 自己来实现才行 。

而 一台计算机(操作系统)上 端口号 是不能重复的, 所以 我们又不能 在 原来的 Kestrel 还在运行的时候 另外启动一个 Kestrel 进程,

So …… 。

至于 IIS 托管 的 Kestrel, 情况可能更复杂 ……  。

所以, 还是 写个脚本吧  ~!  写个脚本 来 控制 Kestrel 的 启动 停止, 这不算难, 这也是 ServerFul 架构 。

不过这里又引出一个 额外的问题,  就是 如果要 Kestrel 不间断更新(不停机更新) 的话,  怎么办 ?

大概要 增加 一台 备机,  做一个 主备 或者 负载均衡, 

不过这在 云计算 和 虚拟化技术 普及 的 今天,  应该不是 大问题 。

 

 

原文地址:https://www.cnblogs.com/KSongKing/p/10176695.html