系列目录:

本系列分为项目集成、项目部署、架构演进三个方向,后续会根据情况调整文章目录。

本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单。

Taurus.MVC 微服务框架 入门开发教程:项目集成:1、服务端:注册中心、网关。

Taurus.MVC 微服务框架 入门开发教程:项目集成:2、客户端:ASP.NET(C#)编程语言项目集成:应用中心。

Taurus.MVC 微服务框架 入门开发教程:项目集成:3、客户端:其它编程语言项目集成:应用中心。

Taurus.MVC 微服务框架 入门开发教程:项目集成:4、默认安全认证与自定义安全认证。

Taurus.MVC 微服务框架 入门开发教程:项目集成:5、统一的日志管理。

Taurus.MVC 微服务框架 入门开发教程:项目集成:6、微服务的二次开发。

Taurus.MVC 微服务框架 入门开发教程:项目部署:1、微服务应用程序常规部署实现多开,节点扩容。

Taurus.MVC 微服务框架 入门开发教程:项目部署:2、让Kestrel支持绑定多个域名转发,替代Ngnix使用。

Taurus.MVC 微服务框架 入门开发教程:项目部署:3、微服务应用程序版本升级:全站升级和局部模块升级。

Taurus.MVC 微服务框架 入门开发教程:项目部署:4、微服务应用程序发布到Docker部署(上)。

Taurus.MVC 微服务框架 入门开发教程:项目部署:5、微服务应用程序发布到Docker部署(下)。

Taurus.MVC 微服务框架 入门开发教程:项目部署:6、微服务应用程序Docker部署实现多开。

Taurus.MVC 微服务框架 入门开发教程:架构演进:1、从单应用程序简单过渡到负载均衡。

Taurus.MVC 微服务框架 入门开发教程:架构演进:2、负载均到模块拆分负载。

Taurus.MVC 微服务框架 入门开发教程:架构演进:3、模块拆分负载到多级负载均衡。

前言:

本篇教程讲述:用Taurus.MVC 微服务架构的方式,如何来进行系统版本的升级。

下面看具体教程:

1、全功能版本升级:

比如,开发了个站点,通过引入Taurus.MVC 微服务后,初步部署成负载均衡模式,并且开了N个Web应用程序节点。

Web应用中心站点:当前V1版本:appsettings.json 微服务配置内容大体如下:

{
"AppSettings": { "MicroService.Client.Name": "www.a.com",//绑定域名
"MicroService.Client.RegUrl": "http://localhost:80",//注册中心地址
"MicroService.Client.Version": 1,//这里可以指定版本号,没默认配置号时,默认版本号为0 "MicroService.App.RunUrl": "http://localhost:0",
}
}

Web应用中心站点:如今,要发布V2版本,具体操作如下:

1、修改微服务配置文件,提升版本号。
2、发布新版本到服务器任意目录。 

3、启动项目(N次)产生节点。

Web应用中心站点:新版本V2:appsettings.json 微服务配置内容大体如下:

{
"AppSettings": { "MicroService.Client.Name": "www.a.com",//绑定域名
"MicroService.Client.RegUrl": "http://localhost:80",//注册中心地址
"MicroService.Client.Version": 2,//这里可以指定版本号,没配置号时,默认版本号为0 "MicroService.App.RunUrl": "http://localhost:0",
}
}

和旧版本相比,仅是修改了版本号。

升级机制与过程说明:

1、如果版本号>原有版本号(无配置即默认0),那么将启动滑动升级。

2、滑动升级过程:

A:每启动一个新版本节点,会注销一个旧节点;
B:每个节点每次注册【5-10】秒,也会注销一个旧节点。 简而言之:如果原有10个节点,那么 1、连续开启10个新版本节点,即可逐个替换掉旧的10个节点。 2、若仅开启1个节点,每5-10秒注销一个旧节点,注销掉10个节点需要50-100秒。

补充说明:

升级后,原有程序仅是不再收到请求,并未退出程序。

如果仅是测试新版本是否可用:

可保持和原有的版本号一致:

1、直接运行即可加入负载均衡中,获得流量测试。

2、绑定其它域名,引导独立测试域名的流量进行测试。

2、指定模块版本升级:

还是原来的架构图,这里补上了节点的请求网址:

当前,系统仅对会员模块进行修改升级,并需要发布该版本。

传统方式:
按照全站升级模式,一个模块的修改,需要进行全站测试,谁也不清楚会不会影响到其它模块。

Taurus.MVC 微服务框架,提供了模块版本升级的方式:

如今,要发布仅针对会员模块升级的V2版本,具体操作如下:

1、修改微服务配置文件,仅提升会员模块版本号

2、发布新版本到服务器任意目录。
3、启动项目(N次)产生节点。

新版本V2:appsettings.json 配置如下:

{
"AppSettings": { "MicroService.Client.Name": "www.a.com,member|2",//绑定域名,绑定会员模块(指定版本号为2)
"MicroService.Client.RegUrl": "http://localhost:80",
   "MicroService.Client.Version": 1,

   "MicroService.App.RunUrl": "http://localhost:0",
}
}

流程和全量升级几乎一样,唯一不同的是配置,指定了模块拦截。

然后启动程序(节点)N次即可。

特别说明:

1、V1版本:仅配置了域名,版本号是1,没有模块存在时,框架会默认追回模块通配符"*",因此所有模块版本号也是:1。

2、V2版本:仍配置域名为1,避免之前的失效,再通过优先级“|”符号指定:member版本号为2。

因此,仅将请求路径为member的会员模块,拦截转发到新版本V2版本,其它模块请求,依旧回到原有版本上。

总结:

对于Taurus.MVC 微服务框架而言,部署和升级都相当简单:

部署就是把程序往上一扔,然后就启动N次的问题。

升级也是把程序往上一扔,然后就启动N次的问题。

特别是局域模块的升级方式,使得全站向模块化部署的过渡,是那么的丝滑与自然,史无前例,细思极恐啊!

Taurus.MVC 微服务框架 入门开发教程:项目部署:3、微服务应用程序版本升级:全站升级和局部模块升级。的更多相关文章

  1. Taurus.MVC 微服务框架 入门开发教程:项目部署:1、微服务应用程序常规部署实现多开,节点扩容。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单 ...

  2. Taurus.MVC 微服务框架 入门开发教程:项目部署:2、让Kestrel支持绑定多个域名转发,替代Ngnix使用。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单 ...

  3. Taurus.MVC 微服务框架 入门开发教程:项目集成:1、服务端:注册中心、网关(提供可运行程序下载)。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单 ...

  4. Taurus.MVC 微服务框架 入门开发教程:项目集成:2、客户端:ASP.NET Core(C#)项目集成:应用中心。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单 ...

  5. Taurus.MVC 微服务框架 入门开发教程:项目集成:5、统一的日志管理。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单 ...

  6. Taurus.MVC 微服务框架 入门开发教程:项目集成:4、默认安全认证与自定义安全认证。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 本系列第一篇:Taurus.MVC V3.0.3 微服务开源框架发布:让.NET 架构在大并发的演进过程更简单 ...

  7. Taurus.MVC 微服务框架 入门开发教程:项目部署:4、微服务应用程序发布到Docker部署(上)。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 开源地址:https://github.com/cyq1162/Taurus.MVC 本系列第一篇:Tauru ...

  8. Taurus.MVC 微服务框架 入门开发教程:项目部署:5、微服务应用程序发布到Docker部署(下)。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 开源地址:https://github.com/cyq1162/Taurus.MVC 本系列第一篇:Tauru ...

  9. Taurus.MVC 微服务框架 入门开发教程:项目部署:6、微服务应用程序Docker部署实现多开。

    系列目录: 本系列分为项目集成.项目部署.架构演进三个方向,后续会根据情况调整文章目录. 开源地址:https://github.com/cyq1162/Taurus.MVC 本系列第一篇:Tauru ...

随机推荐

  1. React BrowserHistory 踩坑实录 布置到服务器Nginx上各种静态文件、二级地址404

    由于BrowserHistory访问的是文件真实地址不仅需要前端配置package.json还需要运维端配置一下网站Nginx设置环境: "react": "^17.0. ...

  2. React history.push()无法跳转 url改变页面不渲染

    一.history.push()无法跳转参考了很多文章 研究一下生命周期 render是要有state变化才会执行 BrowserHistory只有props变化 无法触发render 如下改造环境 ...

  3. 计算机网络 - HTTP和HTTPS的区别

    计算机网络 - HTTP和HTTPS的区别 http所有传输的内容都是明文,并且客户端和服务器端都无法验证对方的身份. https具有安全性的ssl加密传输协议,加密采用对称加密. https协议需要 ...

  4. Elasticsearch学习系列一(部署和配置IK分词器)

    Elasticsearch简介 Elasticsearch是什么? Elaticsearch简称为ES,是一个开源的可扩展的分布式的全文检索引擎,它可以近乎实时的存储.检索数据.本身扩展性很好,可扩展 ...

  5. 使用HBuilder X编辑器安装终端窗口插件未响应的解决方案

    一.打开HBuilder X根目录 依次找到main.js HBuilderX \ plugins \ builtincef3terminal \ script \ main.js 二.编辑main. ...

  6. python线程池 ThreadPoolExecutor 的用法及实战

    写在前面的话 (https://jq.qq.com/?_wv=1027&k=rX9CWKg4) 文章来源于互联网从Python3.2开始,标准库为我们提供了 concurrent.future ...

  7. VScode中配置Java环境

    vscode 中配置Java环境 转载说明:本篇文档原作者[@火星动力猿],文档出处来自哔哩哔哩-[教程]VScode中配置Java运行环境 转载请在开头或显眼位置标注转载信息. 1.下载VScode ...

  8. 从解析HTML开始,破解页面渲染时间长难题

    摘要:在本文中,将重点关注网页的初始渲染,即它从解析 HTML 开始. 我将探索可能导致高渲染时间的问题,以及如何解决它们. 本文分享自华为云社区<页面首屏渲染性能指南>,作者:Ocean ...

  9. 蒸腾量与蒸散量(ET)数据、潜在蒸散量、实际蒸散量数据、气温数据、降雨量数据

    ​   数据下载链接:数据下载链接 引言 多种卫星遥感数据反演地表蒸腾与蒸散率(ET)产品是地理遥感生态网推出的生态环境类数据产品之一,产品包括2000-2009年三个波段RGB数据,值域0-252之 ...

  10. Vue模板解析

    mustcache 什么是模板引擎 模板引擎是将数据变为视图的最优雅的解决方案 数据 [ {"name":"小明","age":12,&qu ...