`

关于多版本支持的疑问

    博客分类:
  • java
 
阅读更多

需要解决的问题


1、支持灰度发布:改bug或新功能上线时,让某一指定地区用户的请求全部打到某一个前店(已实现tengine+lua),然后将该前店的请求打到某一指定后场(注:所有后场注册到同一个zk),目前这个还未实现。
2、支持在不停掉原有服务的情况下,起新的服务,避免不涉及修改的接口调用方服务会中断。
3、同一服务存在不同调用方,由于业务发展其中一个调用方需要调整原有的逻辑,而另一个调用方则不需要调整。具体举例说明:同一签名的接口method1(String),存在多个调用方invoker1,invoker2,调用方invoker2需求变更,需要method1(String)调整逻辑。

 

解决方案一:


给接口引入版本,版本粒度控制到每个具体的方法,同一个类的不同方法直接可以配置不同的版本号,每个具体方法的版本都是独立的,相同签名的方法,通过部署的时候使用不同的版本,一方面可以达到支持灰度上线的目的,另一方面对于不同的业务调用方,可以支撑不同的使用逻辑。

问题:
1.每个类的每个方法都有自己的版本号,总共有200多个类,上万个方法,版本号的管理将面临比较大的挑战。
2.新部署服务的时候,如果原有服务不能停,新起一个jvm来部署,由于只有部分服务更改了版本号,所以有的服务在2个jvm中都存在,有的服务则在2个jvm中都存在。如果按照这种做法多换几次包,那么每个jvm中提供的服务可能都是不一样的,这样当jvm资源都用满了,要再次换包的时候,就要把一部分jvm下掉,要下掉哪个jvm,这个jvm上提供了哪些服务,这些服务是否还有客户端在调用,或者某个特定的服务,在该jvm下掉之后,还有几个jvm在提供服务,剩下的jvm负载是不是会承受不了,每个版本的服务跟jvm之间构成的多对多网状关系将会变得很复杂。
3、由于对于某个具体的方法而言,最新的代码上只保留了最后一版的逻辑,如果某个历史版本的代码发现了bug,只能找到这个版本对应的tag,将该tag代码检出,修复bug然后发布。如果bug涉及多个版本,那就要检出多个tag,修改多个tag,然后重新发布这多个tag。

 

解决方案二:
在方案一的基础上,对部署作出调整,开发出一个容器,能够动态加载多个不同版本的jar包,每个jar包只封装一个服务,200多个服务就打成200多个jar包。由于换版本不需要起停容器,而且可以精确地控制到每个服务的起停,不存在方案一中jvm资源耗尽时,要停掉某个jvm换包,导致的某些还在使用中的服务也不得不下掉的问题。
此外,基于容器的方案,版本可以只控制到类,即一个类就共用一个版本,如果有一个类中的方法调整了,那么就升级整个类的版本。版本号的管理相较于方案一,复杂度要降低一些。

问题:
1、由于代码中也是只保留了最后一次的调整的逻辑,所以方案一中的问题3依然存在。
2、需要研发容器,如果研发出来的容器性能和稳定性上存在问题,对项目来说风险较大。
3、虽然每个jar包中只封装了一个服务,但是其背后依赖的一整套sv,dao都是全量的,也就是说一个jar包中大部分是无效代码,有效代码只占到了1/200.每个服务中只封装跟该服务相关的sv,dao,这个也会对jar包打包机制和管理构成一个挑战。

 

解决方案三:
不引入dubbo多版本,接口逻辑变动了,如果对应的调用方只有一个,那么直接在原来接口上修改,如果存在多个调用方,其中一个调用方要增加新的逻辑,那么就通过新增接口的方式来支撑,也就是说统一业务的多种逻辑,全部都体现在一份代码中。如果出现了一个公共的bug,那么多种逻辑的代码都需要调整。

问题:
1、同一个业务的多种相似逻辑存在于同一份代码中,代码会变得臃肿。
2、由于不能依赖于多版本,所以在所有服务(不管新的还是旧的)都注册到同一个zk的前提下,得通过其它方式来实现灰度上线,比如基于dubbo路由扩展。这个其它方式还没有进行相关的探索,不知道最终是否可行,也存在风险。

 

不知道业界关于这个都是怎么处理和解决的。

分享到:
评论

相关推荐

    iOS版微信抢红包Tweak.zip小程序

    iOS版微信抢红包Tweak.zip小程序

    毕业设计&课设_篮球爱好者网站,含前后台管理功能及多种篮球相关内容展示.zip

    该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过严格测试运行成功才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

    基于springboot社区停车信息管理系统.zip

    基于springboot社区停车信息管理系统.zip

    基于springboot南皮站化验室管理系统源码数据库文档.zip

    基于springboot南皮站化验室管理系统源码数据库文档.zip

    重磅,更新!!!上市公司全要素生产率TFP数据及测算方法(OL、FE、LP、OP、GMM)(2000-2023年)

    ## 数据指标说明 全要素生产率(TFP)也可以称之为系统生产率。指生产单位(主要为企业)作为系统中的各个要素的综合生产率,以区别于要素生产率(如技术生产率)。测算公式为:全要素生产率=产出总量/全部资源投入量。 数据测算:包含OL、FE、LP、OP、GMM共五种TFP测算方法!数据结果包括excel和dta格式,其中重要指标包括证券代码,固定资产净额,营业总收入,营业收入,营业成本,销售费用,管理费用,财务费用,购建固定资产无形资产和其他长期资产支付的现金,支付给职工以及为职工支付的现金,员工人数,折旧摊销,行业代码,上市日期,AB股交叉码,退市日期,年末是否ST或PT等变量指标分析。文件包括计算方法说明及原始数据和代码。 数据名称:上市公司全要素生产率TFP数据及测算方法(OL、FE、LP、OP、GMM) 数据年份:2000-2023年 数据指标:证券代码、year、TFP_OLS、TFP_FE、TFP_LP1、TFP_OP、TFP_OPacf、TFP_GMM

    多种编程语言下算法实现资源汇总

    内容概要:本文详细总结了多种编程语言下常用的算法实现资源,涵盖Python、C++、Java等流行编程语言及其相关的开源平台、在线课程和权威书籍。对于每种语言而言,均提供了具体资源列表,包括开源项目、标准库支持、在线课程及专业书籍推荐。 适合人群:适用于所有希望深入研究并提高特定编程语言算法能力的学习者,无论是编程新手还是有一定经验的技术人员。 使用场景及目标:帮助开发者快速定位到合适的算法学习资料,无论是出于个人兴趣自学、面试准备或是实际工作中遇到的具体算法问题,都能找到合适的解决方案。 其他说明:文中提及多个在线学习平台和社区网站,不仅限于某一特定语言,对于跨学科或多元化技能培养也具有很高的参考价值。

    基于springboot的交通旅游订票系统源码数据库文档.zip

    基于springboot的交通旅游订票系统源码数据库文档.zip

    GO语言教程:基础知识与并发编程

    内容概要:本文档是一份详细的GO语言教程,涵盖了Go语言的基础语法、数据类型、控制结构、函数、结构体、接口以及并发编程等多个方面。主要内容包括Go语言的基本概念和历史背景、环境配置、基本语法(如变量、数据类型、控制结构)、函数定义与调用、高级特性(如闭包、可变参数)、自定义数据类型(如结构体、接口)以及并发编程(如goroutine、channel、select)等内容。每部分内容都附有具体的代码示例,帮助读者理解和掌握相关知识点。 适合人群:具备一定编程基础的开发者,尤其是希望深入学习和应用Go语言的技术人员。 使用场景及目标:①初学者通过本教程快速入门Go语言;②有一定经验的开发者系统复习和完善Go语言知识;③实际项目开发中利用Go语言解决高性能、高并发的编程问题。 阅读建议:本文档全面介绍了Go语言的各项基础知识和技术细节,建议按章节顺序逐步学习,通过动手实践代码示例加深理解。对于复杂的概念和技术点,可以通过查阅更多资料或进行深入研究来巩固知识。

    time_series_at_a_point.ipynb

    GEE训练教程

    memcached笔记资料

    memcached笔记资料,配套视频:https://www.bilibili.com/list/474327672?sid=4486766&spm_id_from=333.999.0.0&desc=1

    基于springboot校内跑腿业务系统源码数据库文档.zip

    基于springboot校内跑腿业务系统源码数据库文档.zip

    计算机控制光感自动窗帘控制系统设计.doc

    计算机控制光感自动窗帘控制系统设计.doc

    基于SpringBoot的校园服务系统源码数据库文档.zip

    基于SpringBoot的校园服务系统源码数据库文档.zip

    基于SpringBoot+Vue的美容店信息管理系统源码数据库文档.zip

    基于SpringBoot+Vue的美容店信息管理系统源码数据库文档.zip

    基于springboot程序设计基础课程辅助教学系统源码数据库文档.zip

    基于springboot程序设计基础课程辅助教学系统源码数据库文档.zip

    原生JS实现斗地主小游戏源码.zip

    这是一个原生的JS网页版斗地主小游戏,代码注释全。带有斗地主游戏基本的地主、选牌、提示、出牌、倒计时等功能。简单好玩,欢迎下载

    基于springboot亚运会志愿者管理系统源码数据库文档.zip

    基于springboot亚运会志愿者管理系统源码数据库文档.zip

    毕业设计&课设_含多功能的远程控制工具集(已停维护),含命令行、文件管理、桌面功能.zip

    该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过严格测试运行成功才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

    Sen2_NDVI_Max.txt

    GEE训练教程——Landsat5、8和Sentinel-2、DEM和各2哦想指数下载

    基于springboot家校合作平台源码数据库文档.zip

    基于springboot家校合作平台源码数据库文档.zip

Global site tag (gtag.js) - Google Analytics