gpt4 book ai didi

java - 启动消费者时抛出异常 - (无法为微服务中的不同 channel 分配相同的组名称)

转载 作者:行者123 更新时间:2023-11-30 02:09:15 25 4
gpt4 key购买 nike

我是 Spring Cloud Stream 和 RabbitMQ 的新手。最近,我在启动我的一项微服务后遇到了异常。它指出无法注册对象,因为它已经注册,我认为这是因为为每个 channel 分配的组名称,请检查异常,

 2018-05-28 10:01:38.420 ERROR 10244 --- [ask-scheduler-2] o.s.cloud.stream.binding.BindingService  : Failed to create consumer binding; retrying in 30 seconds
org.springframework.cloud.stream.binder.BinderException: Exception thrown while starting consumer:
at org.springframework.cloud.stream.binder.AbstractMessageChannelBinder.doBindConsumer(AbstractMessageChannelBinder.java:326) ~[spring-cloud-stream-2.0.0.RC3.jar:2.0.0.RC3]
at org.springframework.cloud.stream.binder.AbstractMessageChannelBinder.doBindConsumer(AbstractMessageChannelBinder.java:77) ~[spring-cloud-stream-2.0.0.RC3.jar:2.0.0.RC3]
at org.springframework.cloud.stream.binder.AbstractBinder.bindConsumer(AbstractBinder.java:129) ~[spring-cloud-stream-2.0.0.RC3.jar:2.0.0.RC3]
at org.springframework.cloud.stream.binding.BindingService.lambda$rescheduleConsumerBinding$0(BindingService.java:154) ~[spring-cloud-stream-2.0.0.RC3.jar:2.0.0.RC3]
at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE]
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) ~[na:1.8.0_101]
at java.util.concurrent.FutureTask.run(FutureTask.java:266) ~[na:1.8.0_101]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180) ~[na:1.8.0_101]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293) ~[na:1.8.0_101]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) ~[na:1.8.0_101]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) ~[na:1.8.0_101]
at java.lang.Thread.run(Thread.java:745) ~[na:1.8.0_101]
Caused by: java.lang.IllegalStateException: Could not register object [org.springframework.integration.handler.advice.ErrorMessageSendingRecoverer@70a0362b] under bean name 'org.nets.ups.alertService.errors.recoverer': there is already object [org.springframework.integration.handler.advice.ErrorMessageSendingRecoverer@cfd5cd2] bound
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.registerSingleton(DefaultSingletonBeanRegistry.java:126) ~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
at org.springframework.beans.factory.support.DefaultListableBeanFactory.registerSingleton(DefaultListableBeanFactory.java:932) ~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
at org.springframework.cloud.stream.binder.AbstractMessageChannelBinder.registerErrorInfrastructure(AbstractMessageChannelBinder.java:519) ~[spring-cloud-stream-2.0.0.RC3.jar:2.0.0.RC3]
at org.springframework.cloud.stream.binder.AbstractMessageChannelBinder.registerErrorInfrastructure(AbstractMessageChannelBinder.java:478) ~[spring-cloud-stream-2.0.0.RC3.jar:2.0.0.RC3]
at org.springframework.cloud.stream.binder.rabbit.RabbitMessageChannelBinder.createConsumerEndpoint(RabbitMessageChannelBinder.java:391) ~[spring-cloud-stream-binder-rabbit-2.0.0.RC3.jar:2.0.0.RC3]
at org.springframework.cloud.stream.binder.rabbit.RabbitMessageChannelBinder.createConsumerEndpoint(RabbitMessageChannelBinder.java:104) ~[spring-cloud-stream-binder-rabbit-2.0.0.RC3.jar:2.0.0.RC3]
at org.springframework.cloud.stream.binder.AbstractMessageChannelBinder.doBindConsumer(AbstractMessageChannelBinder.java:279) ~[spring-cloud-stream-2.0.0.RC3.jar:2.0.0.RC3]
... 11 common frames omitted

当我为这个微服务中的每个 channel 指定相同的组名称时,就会发生这种情况。像这样的东西,

 spring:
cloud:
stream:
bindings:
useroperation:
destination: org.nets.ups
content-type: application/json
group: alertService
departmentoperation:
destination: org.nets.ups
content-type: application/json
group: alertService
roleoperation:
destination: org.nets.ups
content-type: application/json
group: alertService
rabbit:
bindings:
useroperation:
consumer:
bindingRoutingKey: 'adminservice.user.#'
departmentoperation:
consumer:
bindingRoutingKey: 'adminservice.department.#'
roleoperation:
consumer:
bindingRoutingKey: 'adminservice.role.#'

我可以通过删除组名称来删除此异常,但是组名称始终是获得已知队列名称和更好的负载平衡的完美选择。如果我做错了什么或者如果您需要 java 代码(它只是每个 channel 的流监听器),请告诉我。

谢谢。

最佳答案

您的 YAML 格式不正确。应该是...

spring:
cloud:
stream:
bindings:
useroperation:
destination: org.nets.ups
content-type: application/json
group: alertService
departmentoperation:
destination: org.nets.ups
content-type: application/json
group: alertService
roleoperation:
destination: org.nets.ups
content-type: application/json
group: alertService
rabbit:
bindings:
useroperation:
consumer:
bindingRoutingKey: 'adminservice.user.#'
departmentoperation:
consumer:
bindingRoutingKey: 'adminservice.department.#'
roleoperation:
consumer:
bindingRoutingKey: 'adminservice.role.#'

编辑

哦,我明白了;是的,看起来像一个错误;如果多个绑定(bind)使用相同的目标和组,我们无法注册错误基础结构。请针对 spring-cloud-stream 打开 github 问题。我们应该添加另一个属性以允许使用同一组。

解决方法是在每个地方使用不同的组。

关于java - 启动消费者时抛出异常 - (无法为微服务中的不同 channel 分配相同的组名称),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50559187/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com