看到讨论微服务优劣的帖子,我有个疑问,如果微服务中的某个基础服务对外接口发生变化,假设有 10 个服务调用了此接口,那么所有接口都需要重新改动?甚至于有时不知道哪些服务会调用到这个变动的接口,这是个大问题,请问大家都用什么方案来解决以上问题?
举报· 1036 次点击
登录 注册 站外分享
9 条回复  
littlewing 初学 2025-2-23 23:44:53
变化当然是要考虑兼容性啊
ipwx 小成 2025-2-23 23:46:36
把旧的接口留着,调一下新的接口相关代码呗。微软 20 年老 API 都留着呢
cvbnt 小成 2025-2-23 23:52:38
那要看什么级别的改动,如果是接口名称,参数修改那没辙,但是可以单独将请求对外接口封装到单独的一个服务里供其他服务使用,这样外部接口发生变化,仅需要改动这一个服务就行了
quan7u 小成 2025-2-23 23:58:35
1 、版本号 or 参数控制接口版本,比如保留 v1 、新开 f ,通知上游接口切换 2 、完善监控,统计接口流量、分渠道的调用量
lnbiuc 小成 2025-2-23 23:58:40
旧的接口不变,新的改成 f 版本,其他的服务如果有需要就改,没需要就维持现状
xuanbg 小成 2025-2-24 06:55:50
首先,出现 10 个服务调用情况基本就是设计的问题。代码写错地方真的比写错了代码还糟糕。 然后,问题已经出现了,那该怎么办呢?简单,给一个 V2 版本就行了。需要新的改用 V2 版本,不需要的继续用 V1 ,就不需要动他了。
conn4575 初学 2025-2-24 08:13:38
如果你有更上层的 api 网关的话,可以在上面做参数重写,这就是 api 网关的意义。否则就只能用 v1 f 做好兼容了
wogogoing 小成 2025-2-24 09:00:23
/api/v1 /api/f 让需要的服务显式变更。
lasuar 小成 2025-2-24 10:01:35
1. 内部逻辑变化不影响其他服务,仅接口出入参变化需要关联更新 2. 接口出入参变化属于较大结构调整,可能是因为之前设计不完善或业务/功能原因需要调整,频率较低 3. 微服务中的服务调用一般是基于生成式代码的 RPC 调用,不存在说 [不知道影响了哪些服务] 4. 楼主的问题在微服务中属于基础,最好是先尝试本地使用熟悉语言实践一下微服务架构,这样方能避免一知半解的状态。
返回顶部