使用连接前缀属性时,Spring Cloud Stream Rabbit活页夹会导致循环依赖项错误

问题描述

如果我删除前缀属性应用程序启动而没有问题,则我使用连接名称前缀属性时应用程序无法启动

spring.cloud.stream.rabbit.binder.connection-name-prefix=myPrefix

***************************
APPLICATION Failed TO START
***************************

Description:

The dependencies of some of the beans in the application context form a cycle:

   binderHealthindicator defined in org.springframework.cloud.stream.binder.rabbit.config.RabbitServiceAutoConfiguration$RabbitHealthindicatorConfiguration
      ↓
   rabbitTemplate defined in org.springframework.boot.autoconfigure.amqp.RabbitAutoConfiguration$RabbitTemplateConfiguration
┌─────┐
|  rabbitConnectionFactory defined in org.springframework.boot.autoconfigure.amqp.RabbitAutoConfiguration$RabbitConnectionFactoryCreator
↑     ↓
|  org.springframework.cloud.stream.binder.rabbit.config.RabbitMessageChannelBinderConfiguration (field private org.springframework.amqp.rabbit.connection.ConnectionFactory org.springframework.cloud.stream.binder.rabbit.config.RabbitMessageChannelBinderConfiguration.rabbitConnectionFactory)
└─────┘

我有一个具有5个处理器的单一资料夹应用程序,希望自定义连接工厂名称

spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.host=host
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.username=user
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.password=pswd

spring.cloud.stream.binders.simple-rabbit.type=rabbit
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.port=5672
spring.cloud.stream.binders.simple-rabbit.default-candidate=false
spring.cloud.stream.binders.simple-rabbit.inherit-environment=false
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.template.retry.enabled=true
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.template.retry.initial-interval=1000ms
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.template.retry.max-attempts=3 
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.template.retry.max-interval=10000ms
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.template.retry.multiplier=1
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.publisher-confirms=true
spring.cloud.stream.binders.simple-rabbit.environment.spring.rabbitmq.publisher-returns=true
spring.cloud.stream.rabbit.binder.connection-name-prefix=myFactory
spring.cloud.stream.bindings.input.binder=simple-rabbit
spring.cloud.stream.bindings.input.destination=dest
spring.cloud.stream.bindings.input.group=group
spring.cloud.stream.bindings.input.consumer.max-attempts=1
spring.cloud.stream.rabbit.bindings.input.consumer.queueNameGroupOnly=true
spring.cloud.stream.rabbit.bindings.input.consumer.exchange-type=fanout
spring.cloud.stream.rabbit.bindings.input.consumer.prefetch=100
spring.cloud.stream.rabbit.bindings.input.consumer.ackNowledge-mode=MANUAL
spring.cloud.stream.rabbit.bindings.input.consumer.max-concurrency=2
spring.cloud.stream.rabbit.bindings.input.consumer.consumer-tag-prefix=consumerprefix
spring.cloud.stream.rabbit.bindings.input.consumer.quorum.enabled=true
@EnableBinding(SimpleBinder.class)
public class SimpleProcessor {

    @StreamListener(target = SimpleBinder.INPUT,copyHeaders = "false")
    public void processMessage(@Payload byte[] payload,@Headers Map<String,Object> headers,@Header(AmqpHeaders.CHANNEL) Channel channel,@Header(AmqpHeaders.DELIVERY_TAG) long deliveryTag)
            throws Exception {

    }

    public interface SimpleBinder {

        /**
         * Input channel name
         */
        final String INPUT = "input";

        /**
         * @return input channel
         */
        @Input(INPUT)
        SubscribableChannel handleMessage();

    }
}

这是应用程序pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.3.RELEASE</version>
        <relativePath /> <!-- lookup parent from repository -->
    </parent>
    <groupId>circular-dependency</groupId>
    <artifactId>cd-jar</artifactId>
    <version>1.1</version>
    <name>mq-publisher</name>
    <description>publisher</description>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8
        </project.reporting.outputEncoding>
        <java.version>11</java.version>
        <jenkins.buildnumber>x</jenkins.buildnumber>
        <mongo-in-memory-mongo>1.28.0</mongo-in-memory-mongo>
        <jenkins.branchName>LOCALHOST</jenkins.branchName>
        <spring-cloud.version>Hoxton.SR6</spring-cloud.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-stream-rabbit</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-stream-test-support</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <finalName>mq-publisher-${project.version}.${jenkins.buildnumber}
        </finalName>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-failsafe-plugin</artifactId>
            </plugin>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <executions>
                    <execution>
                        <goals>
                            <goal>build-info</goal>
                        </goals>
                        <configuration>
                            <additionalProperties>
                                <buildnumber>${project.version}.${jenkins.buildnumber}
                                </buildnumber>
                                <branchName>${jenkins.branchName}</branchName>
                            </additionalProperties>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
            <plugin>
                <groupId>org.jacoco</groupId>
                <artifactId>jacoco-maven-plugin</artifactId>
                <version>0.8.2</version>
                <executions>
                    <execution>
                        <id>prepare-agent</id>
                        <goals>
                            <goal>prepare-agent</goal>
                        </goals>
                    </execution>
                    <execution>
                        <id>report</id>
                        <phase>prepare-package</phase>
                        <goals>
                            <goal>report</goal>
                        </goals>
                    </execution>
                    <execution>
                        <id>post-unit-test</id>
                        <phase>test</phase>
                        <goals>
                            <goal>report</goal>
                        </goals>
                        <configuration>
                            <dataFile>target/jacoco.exec</dataFile>
                            <outputDirectory>target/jacoco-ut</outputDirectory>
                        </configuration>
                    </execution>
                </executions>
                <configuration>
                    <excludes>
                        <exclude>com/Test.class
                        </exclude>
                    </excludes>
                    <systemPropertyVariables>
                        <jacoco-agent.destfile>target/jacoco.exec</jacoco-agent.destfile>
                    </systemPropertyVariables>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

解决方法

我无法使用您的配置来重现它(但名称未应用于连接)。我能够使用

进行复制
spring.cloud.stream.binders.simple-rabbit.type=rabbit
spring.cloud.stream.binders.simple-rabbit.environment.spring.cloud.stream.rabbit.binder.connection-name-prefix=myPrefix

spring.cloud.stream.bindings.input-in-0.binder=simple-rabbit

为什么您需要simple-rabbit作为命名资料夹?活页夹位于顶层时,它可以正常工作。

如果您必须将其作为命名的活页夹,我将看看是否可以解决。

编辑

这似乎行得通...

@EventListener
public void eventListener(ContextRefreshedEvent event) {
    event.getApplicationContext().getBean(CachingConnectionFactory.class).setConnectionNameStrategy(
            conn -> "myConnection#" + this.incr.incrementAndGet());
}

(而不是通过属性进行设置)。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...