使用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接口没有实现契约里的某些方法而报错。
这个问题有可能本地开发时没有出现,而在线上部署时碰到,具有一定的随机性。