rabbitmq 消费者报错 ListenerExecutionFailedException NullPointerException

报错信息:

org.springframework.amqp.rabbit.support.ListenerExecutionFailedException: Listener method 'private void com.xxx.service.impl.xxxServiceImpl.xxx(com.xxx.dto.XXX)' threw exception
    at org.springframework.amqp.rabbit.listener.adapter.MessagingMessageListenerAdapter.invokeHandler(MessagingMessageListenerAdapter.java:230)
    at org.springframework.amqp.rabbit.listener.adapter.MessagingMessageListenerAdapter.invokeHandlerAndProcessResult(MessagingMessageListenerAdapter.java:150)
    at org.springframework.amqp.rabbit.listener.adapter.MessagingMessageListenerAdapter.onMessage(MessagingMessageListenerAdapter.java:135)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.doInvokeListener(AbstractMessageListenerContainer.java:1608)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.actualInvokeListener(AbstractMessageListenerContainer.java:1527)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.invokeListener(AbstractMessageListenerContainer.java:1515)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.doExecuteListener(AbstractMessageListenerContainer.java:1506)
    at org.springframework.amqp.rabbit.listener.AbstractMessageListenerContainer.executeListener(AbstractMessageListenerContainer.java:1450)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer.doReceiveAndExecute(SimpleMessageListenerContainer.java:976)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer.receiveAndExecute(SimpleMessageListenerContainer.java:922)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer.access$1600(SimpleMessageListenerContainer.java:83)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer$AsyncMessageProcessingConsumer.mainLoop(SimpleMessageListenerContainer.java:1297)
    at org.springframework.amqp.rabbit.listener.SimpleMessageListenerContainer$AsyncMessageProcessingConsumer.run(SimpleMessageListenerContainer.java:1203)
    at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.NullPointerException: null
    at com.xxx.service.impl.XXXServiceImpl.xxx(XXXServiceImpl.java:292)
    at sun.reflect.GeneratedMethodAccessor175.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.springframework.messaging.handler.invocation.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:171)
    at org.springframework.messaging.handler.invocation.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:120)
    at org.springframework.amqp.rabbit.listener.adapter.HandlerAdapter.invoke(HandlerAdapter.java:53)
    at org.springframework.amqp.rabbit.listener.adapter.MessagingMessageListenerAdapter.invokeHandler(MessagingMessageListenerAdapter.java:222)
    ... 13 common frames omitted

原因:

调用了其他service的方法

解决方法:

将方法的private改为public

// private void sendSms2Guide
public void sendSms2Guide

### RabbitMQ STOMP 插件安装错误解决方案 当遇到RabbitMQ STOMP插件安装过程中出现问题时,可以按照以下方法排查并解决问题。 #### 验证权限 确保具有足够的权限来执行命令。通常情况下,这些操作需要超级用户权限。如果未以root身份运行命令,则可能会收到权限不足的错误消息。因此,在启用插件之前,请尝试使用`sudo`前缀再次运行命令[^1]: ```bash sudo rabbitmq-plugins enable rabbitmq_stomp ``` #### 检查网络连接 有时由于网络原因无法下载必要的依赖项而导致失败。确认主机能够访问互联网,并且没有任何防火墙阻止了到官方Erlang包存储库或其他必需资源的位置的流量。 #### 更新软件源列表 保持系统的软件源是最新的也很重要。对于基于Debian/Ubuntu的操作系统来说,可以通过下面这条指令更新APT缓存: ```bash sudo apt-get update ``` 而对于RedHat/CentOS系列则应使用yum工具做相同的事情: ```bash sudo yum makecache fast ``` 这有助于防止因过期或损坏的数据而引起的潜在冲突。 #### 清理旧版本残留文件 如果有先前不成功的安装尝试留下了一些临时文件或者部分解压的内容,那么清理它们可能有所帮助。移除 `/var/lib/rabbitmq/plugins` 下面所有的`.ez` 文件夹以及删除 `/usr/lib/rabbitmq/lib/rabbitmq_server-<version>/plugins/*stomp*.ez` 中的相关压缩包(其中 `<version>` 是实际安装的RabbitMQ服务器的具体版本号),然后再重新启动服务[^3]: ```bash service rabbitmq-server stop && rm -rf /var/lib/rabbitmq/plugins/*.ez \ && find /usr/lib/rabbitmq/lib/rabbitmq_server-* -name "*stomp*.ez" -exec rm {} \; ``` 之后再继续正常流程加载所需的STOMP支持功能模块。 #### 启用其他相关组件 除了核心的 `rabbitmq_stomp` 外,还可能存在一些辅助性的扩展也需要被激活才能让整个通信机制工作得更好。比如Web界面交互相关的部件就可以通过如下方式开启[^2]: ```bash sudo rabbitmq-plugins enable rabbitmq_web_stomp rabbitmq_web_stomp_examples ``` #### 查看日志记录 最后但同样重要的一步就是查看日志文件了解具体发生了什么异常情况。默认位置一般位于 `/var/log/rabbitmq/startup_log`, `/var/log/rabbitmq/startup_err` 和 `/var/log/rabbitmq/rabbit@hostname.log` 。利用grep或者其他文本处理工具快速定位关键字如“error”,从而更精准地分析根本原因所在。 完成上述步骤后记得重启一次RabbitMQ实例以便应用最新的更改设置。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值