CSE/ServiceComb 服务启动的时候报告接口方法不存在,启动失败

本文探讨使用CSEJAVASDK开发微服务时遇到的接口方法不存在问题,特别是在两个接口定义相同schemaId但实现不同方法的情况下,可能导致服务启动失败。分析了问题出现的原因及随机性,帮助开发者理解并避免此类错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用CSE JAVA SDK开发微服务,报告接口方法不存在,启动失败,查看接口实现,这些方法都是存在的。日志信息:

java.lang.Error: swagger method %s not exist in producer

  at org.apache.servicecomb.swagger.engine.SwaggerEnvironment.createProducer

有些版本报错:

java.lang.Error: swagger method %s not exist in producer %s. 

  at org.apache.servicecomb.swagger.engine.SwaggerEnvironment.createProducer

原因分析:

   这个错误在比较swagger的方法是否在定义的接口实现里面存在,对于服务端,swagger的方法是根据接口实现生成的,因此任何时候都是存在的,正常情况下不会出现这个异常。 

   当用户将一个接口定义的schemaId指定为一样的,并且两个实现方法不一样的时候,就会出现这样的问题。 比如:

   @RestSchema(schemaId="xyz")

   public class Hello

   @RestSchema(schemaId="xyz")

   public class World

 

这个问题不一定是必现的。假设用户定义了两个Rest接口类,通过@RestSchema注解指定了相同的schemaId,其中一个接口比另外一个接口的方法少,这种情况下服务启动是否报错取决于两个接口类被扫描和处理的顺序。

如果方法少的REST接口先被扫描出来,那么这个时候契约里的operation方法少于另一个REST接口,启动流程不会报错。

但是如果方法多的REST接口先被扫描出来,则生成的契约里operation方法多余方法少的REST接口,等扫描到这个REST接口并做检查时,就会因为REST接口没有实现契约里的某些方法而报错。

这个问题有可能本地开发时没有出现,而在线上部署时碰到,具有一定的随机性。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值