生产环境代码与开发分支的代码差别很大如何处理?

2021-11-17 17:55:33 +08:00
 fangcan

由于历史原因,没有做好分支管理,现在的情况是这样的:

最近在上线的时候由于代码不一致的问题,导致了上线很困难。

目前我的操作是上线前先把线上的代码 class 拿下来反编译跟要上线的代码比对下, 差距较大的用线上的 class 反编译直接覆盖,但还是免不了有各种问题,少类,少方法等

请教各位 v 友有没有什么好的解决方法?

4057 次点击
所在节点    程序员
32 条回复
Chad0000
2021-11-17 18:09:29 +08:00
一般不这样使用分支吧,我之前做的平台都是从代码角度让他们功能有所不同。通过适当的设计是可以做到的。
dqzcwxb
2021-11-17 18:19:14 +08:00
一切以生产环境为准,测试环境是为生产环境服务的
wolfie
2021-11-17 18:20:42 +08:00
拉一个功能表格做管理。

公司 B 分支要用 公司 A 某个功能,手动 cherry-pick 特定几个 commit 。
fangcan
2021-11-17 18:38:40 +08:00
@dqzcwxb 是要以生产为准,但是问题就是上线太难了,做不到直接把新修改的 class 直接替换就可以。 有想过把生产的代码全量拿下来做开发分支,但是反编译后的代码又没有注释,编译后可读性也很差。
fangcan
2021-11-17 18:49:03 +08:00
@wolfie 目前我接手后的代码就是切了分支的代码,但其实是基于原来的同一份代码。 期间什么公司修改了什么功能,什么类是没有记录的。 所以最近遇到的就是 我这次开发 b 公司的需求,然后修改了 b 类。增量上线后发现少了其中引用的 c 类。
sprite82
2021-11-17 18:49:11 +08:00
class 增量 无力吐槽,另外你这一份代码服务多个客户方式,你这代码并没有面向对象思想
master 主干分支,dev 开发分支,dev-com-a dev-com-b 各个客户的需求分支,
开发时,dev-com-a ,b 都合并到 dev 分支,
上线时,比如只要上线 a 那就把 a 合并到 master ,在 master 上打包发布就行了

至于你的 m1 等业务方法,应该抽一个公共方法和继承的几个 A,B,C 个性化的类,运行时根据客户 id 执行对应的方法,这样,你哪怕几个客户的需求同时开发,也不会影响其他客户的业务。

class 增量更新 劝你赶紧停止
bk201
2021-11-17 18:54:59 +08:00
重新制定完善的分支方案,不要再接着坑走下去了。
Tink
2021-11-17 19:24:32 +08:00
从生产环境拉最新分支
statement
2021-11-17 19:38:13 +08:00
做开关 分支不是干这个的
chenxytw
2021-11-17 20:38:44 +08:00
建议离职换家公司,折腾这种事情完全没有意义。
sagaxu
2021-11-17 21:57:04 +08:00
有两个大问题要整改,

1. 引入可重现打包机制和可信任发布,每个人每次 checkout 出相同版本的代码,能一键打出二进制上完全一样的包,线上只能发布来源于某个 tag 打出来的包。

2. 废弃一个公司一个分支的乱象。合理安排组件,做好分层,底层模块各个公司只能用同一套,且不能出现跟特定公司相关的逻辑,极少修改。中层模块所有公司共享,但可以加入一些开关和特定公司逻辑,不经常改。上层模块,可以玩命定制,甚至搞不同的包或者不同的实现。最好把不同的层拆到不同的仓库,上层只能复用下层发布的 jar/lib 。

有些公司会搞成不同的服务,划分出相应的平台和中台以及大前端,每个 team 各司其职。不过这不太适合规模较小的业务,jar/lib 级复用比较简单可行,虽然不如服务化那么强大,但是也不必付出服务化的成本。
TypeError
2021-11-17 21:59:12 +08:00
抽时间全 merge 到 master ,然后发布用专门的 release 分支打 tag ,没时间那就没办法了
MarioLuo
2021-11-17 22:01:05 +08:00
问题是生产环境上运行的包,在分支里没有有一个 commit 能完整对应起来。现在只有人肉处理了
1. 当前的分支留存一份
2. 对每个公司或者近期要迭代的找出历史 commit 打包后 class 差异最小的,无论是手工还是找差异文件的源代码补齐
3.如果差异过大或者无法找到的,保持 class 增量部署
最后处理这个问题一定要反馈给上级领导,风险和成果要让上面知道
wingoo
2021-11-17 23:23:24 +08:00
不同公司如果需求不确定, 最好是做开关, 在代码层级区分(或者统一的配置管理), 而不是分支, 特别是对于持续迭代的功能, 没法区分的
momocraft
2021-11-18 00:48:01 +08:00
为什么会有单个 class 更新这种做法的 难道这样风险更小吗
wqhui
2021-11-18 09:43:04 +08:00
最好是不同公司都用同一套代码,功能的差异通过配置来控制
jtacm
2021-11-18 09:44:44 +08:00
class 反编译的方法非常不建议。

如果是我的话,设计开关+配置 config 文件(不同公司 config 不同),同时利用好抽象和继承。

PS:是停下来进行一次重构了,这是一次必须偿还的技术债。否则以后越滚越大,就更麻烦了,除非你也想跑路。
lei2j
2021-11-18 10:01:36 +08:00
怎么感觉跟我现在公司一样啊,不同的分支服务不同公司
clf
2021-11-18 10:47:52 +08:00
按 commit 合并?

另外,建议把定制化功能放在单独的项目 /特定服务里,不要影响通用化的项目代码。如果对通用化的功能有改变,统一以新加页面、新加接口的方式进行,通过权限树管理页面。

比如 AB 两家公司的同一个功能是两个不同的逻辑,那么前端页面就是两个页面,路由是相同的,整套前后端代码是相同的,唯一不同的就是权限树上同个路由指向了不同页面代码文件。
libook
2021-11-18 11:28:17 +08:00
核心思路就是能统一的都统一版本,不能统一的彻底分开。

代码分两个 repo ,核心+应用。
核心提供底层、基础、通用的接口,尽量向前兼容。
应用调用核心接口来实现业务,可以针对不同客户的需求分不同分支。
多个客户在应用方面有交集的话,可以再分出一个中台 repo 出来,只维护通用的应用。
构建的时候是使用核心+中台+客户分支一起编译。

一个新的应用功能先在本客户的分支上开发,当具有通用性之后就分离出来放入中台,同样当中台硬用不再具备通用性之后就从中台拿出来放到客户分支上。
应用开发过程中发现需要某核心不具备的基础能力,则可以向核心提扩展需求,核心维护团队评估合理后进行开发。
每次发版,按照客户和版本号打 tag ,这样可以通过客户信息来定位到当前服务器上部署的代码版本(历史版本也可以定位)。

首先得明确,这是个技术债务,不还的话利息越滚越多,还债的成本可能低于不还债未来导致的不必要成本,所以最好尽快解决。

其次是,要对产品需求进行有效管理,至少每一次的需求内容都要有记录,然后梳理出每个客户的最终需求和产品设计方案,然后根据基础的代码来看缺什么、需要修改什么,最不济的方案就是根据最新需求从一个旧版本重新开发,有时候会比 hack 现有代码要更快。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/816109

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX