APP 多版本发布之dubbox服务端配置

发布时间:2020-07-15 06:18:44 作者:xinsir999
来源:网络 阅读:572

场景:近期小L发布app的时候遇到个头疼的事情,由于苹果app store需要审核原因,项目需要部署最新版本,但又不能影响来版本的正常使用;

    分析问题:如果是app业务相关的程序bug、或者是预发布版本

    解决方案:配置dubbo多版本

	
	<dubbo:protocol id="customerRest" name="rest" port="xxxxx" />
	<!-- ref:要注入的Service实现 -->
	<dubbo:service interface="com.jlj.erp.app.dubbo.service.customer.CustomerApi" 
					ref="customerApi" version="1.0" group="group-customer"
					protocol="customerRest"  timeout="60000" />
	<!-- ref:要注入的Service实现 -->
	<dubbo:service interface="com.jlj.erp.app.dubbo.service.customer.CustomerApi" 
					ref="customerVApi2" version="1.1" group="group-customer"
					protocol="customerRest" timeout="60000" />		

实现相同的接口,只是接口对应的版本不一样从1.0到1.1,按照需求对1.1版本的接口进行实现,这样发布时,新老接口就会并存,如果需要强制更新审核通过之后会将老版本(1.0版本代码去掉)停掉运行新版本,如果不需强制更新,那么就可以新老版本并存

客户端调用,小L用的是dubbox 所以不同的版本配置不同的路径即可

        http://127.0.0.1:80/a//xxx/v1(老)
	@GET
	@Path("/xxx/v1")
	public ApiResult xxx(@QueryParam("code") String resourceCode)
	
	 http://127.0.0.1:80/a//xxx/v2(新)
	@GET
	@Path("/xxx/v2")
	public ApiResult xxx(@QueryParam("code") String resourceCode)

如果是数据结构发生变化的话小L不建议使用该方式

这样的情况需要具体问题具体定解决方案,可以分开部署,可以做预发布环境,部署1个具有新表结构和对象的测试数据库(预发布环境)。

对于改动较大的,产品新增了重量级新功能的,业务层面或者底层表结构上都不兼容的,建议是要做强制升级的。

APP 多版本发布之dubbox服务端配置

注:接口的实现方法 按照接口版本定;接口新加的方法写在V1版本中,如果V1版本中的某个方法参数条件变化了,那么把新的实现写在V2版本里面,V1版本的实现保留

推荐阅读:
  1. iOS APP真机测试及上架App Store流程记录
  2. windows server 2012 r2 App-V 5.1 安装部署

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

dubbo pp ubb

上一篇:面相对象的三大基本特性五大基本原则

下一篇:网络配置动态路由

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》