【问题标题】:Why invocation bean failed error while initializing springboot为什么初始化springboot时调用bean失败错误
【发布时间】:2019-11-01 01:03:33
【问题描述】:

我正在尝试在课堂上设置 rabbitmq 连接工厂。想使用 @Value 注释读取 application.properties 文件中定义的属性。但是,不知何故 bean 配置不正确。我无法理解。 这是代码:

@Controller
@Configuration
@RequestMapping("/unittestdata")
@Component
@PropertySource("classpath:application.properties")
public class UnitAmqpRestController {


    @Value("${spring.rabbitmq.port}")
    public static int mqPort;

    public UnitAmqpRestController() {

    }
    private static final Logger logger = LoggerFactory.getLogger(UnitAmqpRestController.class);

    private static RabbitTemplate rabbitTemplate;
    private String replyQueueName;

    private static Connection connection;
    private static Channel channel;
    private String requestQueueName = "rpc_queue_unit";

    public UnitAmqpRestController(RabbitTemplate rabbitTemplate, String replyQueueName, Connection connection, Channel channel, String requestQueueName) {

        this.rabbitTemplate = rabbitTemplate;
        this.replyQueueName = replyQueueName;
        this.connection = connection;
        this.channel = channel;
        this.replyQueueName = requestQueueName;

    }

    @PostConstruct  
    public static void main() throws Exception {

        rabbitTemplate.setReplyTimeout(15_000L);
        ConnectionFactory factory = new ConnectionFactory();
        factory.setHost(getHostProperty());

        factory.setPort(mqPort);
        connection = factory.newConnection();
        channel = connection.createChannel();

    }


    public static String getHostProperty() {
        Properties properties = new Properties();
        try {
            File file = ResourceUtils.getFile("classpath:application.properties");
            InputStream in = new FileInputStream(file);
            properties.load(in);
        } catch (IOException e) {

        }
        return properties.getProperty("spring.rabbitmq.host");

    }

这是错误:

2019-06-18 10:58:02.642 信息 29037 --- [主要] o.apache.catalina.core.StandardService :停止服务 [Tomcat] 2019-06-18 10:58:02.661 信息 29037 --- [主要] autoConfigurationReportLoggingInitializer :

启动 ApplicationContext 时出错。显示自动配置 报告启用“调试”后重新运行您的应用程序。 2019-06-18 10:58:02.667 错误 29037 --- [主要] os.s.boot.SpringApplication : 应用启动失败

org.springframework.beans.factory.BeanCreationException: 错误 创建名为“unitAmqpRestController”的bean:调用init 方法失败;嵌套异常是 java.lang.NullPointerException 在 org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:137) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsBeforeInitialization(AbstractAutowireCapableBeanFactory.java:409) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1620) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:555) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:483) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:761) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867) ~[spring-context-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:543) ~[spring-context-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) ~[spring-boot-1.5.10.RELEASE.jar!/:1.5.10.RELEASE] 在 org.springframework.boot.SpringApplication.refresh(SpringApplication.java:693) [spring-boot-1.5.10.RELEASE.jar!/:1.5.10.RELEASE] 在 org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:360) [spring-boot-1.5.10.RELEASE.jar!/:1.5.10.RELEASE] 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:303) [spring-boot-1.5.10.RELEASE.jar!/:1.5.10.RELEASE] 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:1118) [spring-boot-1.5.10.RELEASE.jar!/:1.5.10.RELEASE] 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:1107) [spring-boot-1.5.10.RELEASE.jar!/:1.5.10.RELEASE] 在 com.infy.ci.unitamqpservice.UnitamqpserviceApplication.main(UnitamqpserviceApplication.java:10) [课程!/:0.0.1-SNAPSHOT] 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_212] 在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_212] 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_212] 在 java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_212] 在 org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:48) [unitamqpservice-0.0.1-SNAPSHOT.jar:0.0.1-SNAPSHOT] 在 org.springframework.boot.loader.Launcher.launch(Launcher.java:87) [unitamqpservice-0.0.1-SNAPSHOT.jar:0.0.1-SNAPSHOT] 在 org.springframework.boot.loader.Launcher.launch(Launcher.java:50) [unitamqpservice-0.0.1-SNAPSHOT.jar:0.0.1-SNAPSHOT] 在 org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:51) [unitamqpservice-0.0.1-SNAPSHOT.jar:0.0.1-SNAPSHOT] 原因: java.lang.NullPointerException:空 在 com.infy.ci.unitamqpservice.UnitAmqpRestController.main(UnitAmqpRestController.java:69) ~[classes!/:0.0.1-SNAPSHOT] 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_212] 在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_212] 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_212] 在 java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_212] 在 org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleElement.invoke(InitDestroyAnnotationBeanPostProcessor.java:366) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor$LifecycleMetadata.invokeInitMethods(InitDestroyAnnotationBeanPostProcessor.java:311) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] 在 org.springframework.beans.factory.annotation.InitDestroyAnnotationBeanPostProcessor.postProcessBeforeInitialization(InitDestroyAnnotationBeanPostProcessor.java:134) ~[spring-beans-4.3.14.RELEASE.jar!/:4.3.14.RELEASE] ... 省略了 26 个常用帧

不知道问题是在构造函数中还是在主方法中?? 我错过了@Bean 配置之类的东西吗??

请推荐

【问题讨论】:

  • 这根本行不通。您不能在静态字段上使用 @Value。您需要 rabbit 模板可用于构建控制器,但您是在控制器内部创建它。接下来,您还将自己阅读属性。简而言之,您正在反对/围绕框架工作,而不是实际使用它。 Spring Boot 已经为你创建了ConnectionFactoryRabbitTemplate 等,不要自己动手。从控制器中删除所有这些东西,只留下@controller@RequestMapping。控制器中似乎也没有暴露任何东西。
  • 谢谢。你能把修改后的代码贴出来吗?
  • 删除类即可。 Spring Boot 将配置所有 Rabbit 的东西(假设您添加了 spring-boot-starter-amqp 作为依赖项。

标签: java spring-boot rabbitmq


【解决方案1】:

感谢 M.Deinum 的评论和帖子。 我参考了

上的详细文档

spring-boot-starter-amqp

https://spring.io/guides/gs/messaging-rabbitmq/

https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-messaging.html#boot-features-amqp

它清楚地提到了我自己处理rabbitmq连接工厂的必要性。通过在 application.properties 文件中定义标准关键参数,AmQPTemplate 可以完成所有工作。

谢谢

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2017-06-10
    • 1970-01-01
    • 2021-06-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多