首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

让 sdk 包静默升级的 SAO 操作,你见过几种?

业务背景

有时候为业务方提供了基础的 sdk 包,为了保证稳定性,一般都是 release 包。

但是每一次升级都非常痛苦,也不可能写一个一步到位的 jar 包,因为业务一直在变化。

那有什么方式,让 sdk 包静默升级呢?

今天学习到一个骚操作,和大家分享一下。

方式1-snapshot

以 java 的 maven 包管理为例,如果使用 snapshot,那么就可以随时方便地升级包内容。

优点

非常简单,maven 天然支持。

缺点

•包信息不够稳定,一般为了追求生产的稳定性,都会要求去 snapshot。

   •升级失败,不兼容等,没有回滚的余地。

方式2-nexus 等内部仓库直接替换

方式:直接替换指定版本的仓库中的包。这种方式的核心和上面类似。只不过是看起来不是 snapshot,但是依然无法保障安全。

方式3-shell 脚本结合 CI

方式:使用 shell 脚本,在升级的时候,先备份,再替换。

流程:一般结合 ci 流水线使用,部署打包的时候替换包版本到指定版本,相比较而言更加灵活,也有回旋的余地。

缺点:要求比较多,比较麻烦。且要求应用必须通过 ci 流水线部署,否则就会被绕过。

注意点

1)需要保证 jar 版本之间的向前兼容性,避免升级导致问题。

2)应用环境比较复杂,可能会出问题。所以一定要逐步地升级,让用户测试环境经过验证。

3)提前通知用户,让用户知道这个事情。而且允许用户不做升级操作。

小结

这种方式给我的感觉是无可奈何,但是又非常巧妙。

上一次有这种感觉的,还是运维怕磁盘爆,预留 500MB 放一个垃圾文件,磁盘满了直接移除,快速解决问题。

你在日常工作中,见到过哪些类似的骚操作?

  • 发表于:
  • 原文链接https://page.om.qq.com/page/Ofu_wB3vgqcVVnC8QEKw7BPg0
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券