背景
MQCPConsumeCarMsg implements MQCPMessageListener {
}
MQCPConsumeCarMsg类实现了MQCPMessageListener这个接口,在自动注入
@AutoWired
MQCPConsumeCarMsg mQCPConsumeCarMsg 的时候,会出现如下错误 :
the bean ‘MQCPConsumeCarMsg’ could not be injected as a ‘com.pa.market.mqcp.MQCPConsumeCarMsg’ because it is a JDK dynamic proxy that implements:
com.paic.mqcp.client.common.MQCPMessageListener
Action:
Consider injecting the bean as one of its interfaces or forcing the use of CGLib-based proxies by setting proxyTargetClass=true on @EnableAsync and/or @EnableCaching.
解决办法: 在application.properties 属性文件中配上如下:
使用cglib动态代理
spring.aop.proxy-target-class=true
因为是实现接口,所以在实现的时候,会使用jdk的动态代理方式。现在需要强制改成,CGLIB的动态代理方式。
两个疑问:
为什么会抛出这个异常,自动注入Bean跟动态代理有什么关系?
为什么jdk的方式改成cglib的方式就可以解决问题?
jdk和cglib的底层有什么区别?
项目MQCP需要重构的地方:
1、因为存在多个topic,为了减少负载,创建了两个customer。并且给这两个不同的cutsomer分配不同的topic。其实没有必要,因为逻辑代码一样。貌似也不影响性能。
2、去掉对MessageListener 实现类中设置topic 和 tagList , 其实这两样属性是不需要的。因为逻辑代码中并没有使用到他们。
3、使用过动态代理,最终是追溯到ConsumeMessageConcurrentlyService这个类中的start() 方法是空的,那么按照常理是使用了一个动态代理类来实现这个start方法。
但是遗憾没有找到那个动态代理类? 所以还是没有解决,为什么跟动态代理相关。
4、RabbitMQ有两种消费模式,一种是pull(拉), 一种是push (推)。 这两种模式都可以存在,项目中使用的push 模式,也就是直接主动推送给消费者,供消费者使用。