主要的报错信息:
java.lang.RuntimeException: [source error] getPropertyValue (Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object; in org.apache.dubbo.common.bytecode.Wrapper41: inconsistent stack height -1
at org.apache.dubbo.common.bytecode.ClassGenerator.toClass(ClassGenerator.java:348) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.common.bytecode.ClassGenerator.toClass(ClassGenerator.java:287) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.common.bytecode.Wrapper.makeWrapper(Wrapper.java:261) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.common.bytecode.Wrapper.getWrapper(Wrapper.java:118) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.config.ServiceConfig.doExportUrlsFor1Protocol(ServiceConfig.java:544) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.config.ServiceConfig.doExportUrls(ServiceConfig.java:457) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.config.ServiceConfig.doExport(ServiceConfig.java:415) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.config.ServiceConfig.export(ServiceConfig.java:378) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.config.spring.ServiceBean.export(ServiceBean.java:336) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.config.spring.ServiceBean.onApplicationEvent(ServiceBean.java:114) ~[dubbo-2.7.3.jar:2.7.3]
at org.apache.dubbo.config.spring.ServiceBean.onApplicationEvent(ServiceBean.java:60) ~[dubbo-2.7.3.jar:2.7.3]
解决办法:
dubbo暴露的服务方法错误的命名:getXXX,修改方法名:不要以get开头即可,queryXXX、findXXX等都可。
原因:
不同的协议之间反序列化的方式也不尽相同,常见的有两种方式:
一:通过 getter 和 setter 来获取属性值,例如:有一个对象类,里边有一个属性命名为了 getUrl ,你在通过编辑器自动生成 getter 和 setter 时会发现它生成的是 getUrl 和 setUrl ,如果反序列化的方式是通过 getter 和 setter的方式来获取的话,找到的就是 url 而不是 getUrl 所以在涉及到序列化和反序列化的时候不要命名 get 或 set 开头的
二:通过反射的方式直接获取属性值,这种按照上边的那个例子会获取到 getUrl ,而不是 url ,但是为了防止后期修改序列化协议,或者客户端和服务端的序列化方式不同造成问题,还是规范命名的好