Wydrukuj wszystkie załadowane ziarna wiosenne


95

Czy istnieje sposób na wydrukowanie wszystkich ziaren wiosennych, które są ładowane podczas uruchamiania? Używam Spring 2.0.

Odpowiedzi:


88

Tak, odbierz ApplicationContexti zadzwoń.getBeanDefinitionNames()

Możesz uzyskać kontekst poprzez:

  • realizowanie ApplicationContextAware
  • wstrzyknięcie go z @Inject/ @Autowired(po 2,5)
  • posługiwać się WebApplicationContextUtils.getRequiredWebApplicationContext(..)

Powiązane: rejestrację każdego ziarna można również wykryć, rejestrując BeanPostprocessorziarno. Zostanie powiadomiony o każdym ziarnie.


1
Powodem implementacji ApplicationContextAwareinterfejsu jest to, że Spring Framework daje mu szansę na dostęp do kontekstu aplikacji. Powinieneś umieścić go w @Configurationklasie dla zamierzonego kontekstu aplikacji.
smwikipedia


1
applicationContext.getBeanDefinitionNames () nie wyświetla komponentów bean zarejestrowanych bez instancji BeanDefinition. Nie będzie można wyświetlić listy pojedynczych ziaren, które zostały zarejestrowane ręcznie. ex- :) nie można wymienić komponentów bean environment, systemProperties, systemEnvironment. Jednak te ziarna są dostępne w pojemniku. Można autowire je za pomocą @Auwired Środowisko env itp stackoverflow.com/a/54863282/1840774
Velu

67
public class PrintBeans {
    @Autowired
    ApplicationContext applicationContext;

    public void printBeans() {
        System.out.println(Arrays.asList(applicationContext.getBeanDefinitionNames()));
    }
}

applicationContext.getBeanDefinitionNames () nie wyświetla komponentów bean zarejestrowanych bez instancji BeanDefinition. Nie będzie można wyświetlić listy pojedynczych ziaren, które zostały zarejestrowane ręcznie. ex- :) nie można wymienić komponentów bean environment, systemProperties, systemEnvironment. Jednak te ziarna są dostępne w pojemniku. Można autowire je za pomocą @Auwired Środowisko env itp stackoverflow.com/a/54863282/1840774
Velu

22

Wydrukuj wszystkie nazwy ziaren i ich klasy:

package com.javahash.spring.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;

@Controller
public class HelloWorldController {

    @Autowired
    private ApplicationContext applicationContext;

    @RequestMapping("/hello")
    public String hello(@RequestParam(value="key", required=false, defaultValue="World") String name, Model model) {

        String[] beanNames = applicationContext.getBeanDefinitionNames();

        for (String beanName : beanNames) {

            System.out.println(beanName + " : " + applicationContext.getBean(beanName).getClass().toString());
        }

        model.addAttribute("name", name);

        return "helloworld";
    }
}

1
applicationContext.getBeanDefinitionNames () nie wyświetla komponentów bean zarejestrowanych bez instancji BeanDefinition. Nie będzie można wyświetlić listy pojedynczych ziaren, które zostały zarejestrowane ręcznie. ex- :) nie można wymienić komponentów bean environment, systemProperties, systemEnvironment. Jednak te ziarna są dostępne w pojemniku. Można autowire je za pomocą @Auwired Środowisko env itp stackoverflow.com/a/54863282/1840774
Velu

19

Ze sprężyną rozruchową i rozrusznikiem siłownika

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

możesz sprawdzić punkt końcowy /beans


2
Pytanie dotyczy wiosny 2.0, a nie Spring Boot.
TMN

8

applicationContext.getBeanDefinitionNames () czy nie pokazać ziarna, które są zarejestrowane bez instancji BeanDefinition.

package io.velu.core;

import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

@Configuration
@ComponentScan
public class Core {

public static void main(String[] args) {
    AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(Core.class);
    String[] singletonNames = context.getDefaultListableBeanFactory().getSingletonNames();
    for (String singleton : singletonNames) {
        System.out.println(singleton);
    }       
}

}


Wyjście konsoli

environment
systemProperties
systemEnvironment
org.springframework.context.annotation.internalConfigurationAnnotationProcessor
org.springframework.context.annotation.ConfigurationClassPostProcessor.importRegistry
org.springframework.context.event.internalEventListenerProcessor
org.springframework.context.event.internalEventListenerFactory
org.springframework.context.annotation.internalAutowiredAnnotationProcessor
org.springframework.context.annotation.internalCommonAnnotationProcessor
messageSource
applicationEventMulticaster
lifecycleProcessor

Jak widać w danych wyjściowych, komponenty bean environment, systemProperties, systemEnvironment nie zostaną wyświetlone przy użyciu funkcji context.getBeanDefinitionNames () metody .

Spring Boot

W przypadku aplikacji internetowych uruchamianych wiosną wszystkie komponenty bean można wyświetlić za pomocą poniższego punktu końcowego.

@RestController
@RequestMapping("/list")
class ExportController {

@Autowired
private ApplicationContext applicationContext;

@GetMapping("/beans")
@ResponseStatus(value = HttpStatus.OK)
String[] registeredBeans() {
    return printBeans();
}

private String[] printBeans() {
    AutowireCapableBeanFactory autowireCapableBeanFactory = applicationContext.getAutowireCapableBeanFactory();
    if (autowireCapableBeanFactory instanceof SingletonBeanRegistry) {
        String[] singletonNames = ((SingletonBeanRegistry) autowireCapableBeanFactory).getSingletonNames();
        for (String singleton : singletonNames) {
            System.out.println(singleton);
        }
        return singletonNames;
    }
    return null;
}

}


["autoConfigurationReport", "springApplicationArguments", "springBootBanner", "springBootLoggingSystem", "environment", "systemProperties", "systemEnvironment", "org.springframework.context.annotation.internalConfigurationAnnotationProcessor", "org.springfraut. internalCachingMetadataReaderFactory "," org.springframework.boot.autoconfigure.condition.BeanTypeRegistry "," org.springframework.context.annotation.ConfigurationClassPostProcessor.importRegistry "," propertySourcesPlaceholderConfigurer "," org.springframework.context.annotation.ConfigurationClassPostProcessor.importRegistry "," propertySourcesPlaceholderConfigurer "," org.springframework.context.annotation.ConfigurationClassPostProcessor.importRegistry "," propertySourcesPlaceholderConfigurer "," org.springframework. , "preserveErrorControllerTargetClassPostProcessor "," org.springframework.context.annotation.internalAutowiredAnnotationProcessor "," org.springframework.context.annotation.internalRequiredAnnotationProcessor "," org.springframework.context.annotationProcessor. " ConfigurationPropertiesBindingPostProcessor "," org.springframework.scheduling.annotation.ProxyAsyncConfiguration "," org.springframework.context.annotation.internalAsyncAnnotationProcessor "," methodValidationPostProcessor "," embeddedServletContainerCustomessorProcessorBeanProcessorBean "," message "," embeddedServletContainerCustomessorProcessorBeanProcessorBean ","applicationEventMulticaster "," org.springframework.boot.autoconfigure.web.EmbeddedServletContainerAutoConfiguration $ EmbeddedTomcat "," tomcatEmbeddedServletContainerFactory "," org.springframework.boot.autoconfigure.websocket.WebSttdedTomcat "," tomcatEmbeddedServletContainerFactory "," org.springframework.boot.autoconfigure.websocket. org.springframework.boot.autoconfigure.web.HttpEncodingProperties "," org.springframework.boot.autoconfigure.web.HttpEncodingAutoConfiguration "," localeCharsetMappingsCustomizer "," org.springframework.boot.autoconfigure.web.HttpEncodingAutoConfiguration "," localeCharsetMappingsCustomizer "," org.springframework.boot.autoconfigure.web.HttpEncodingAutoConfiguration "," localeCharsetMappingsCustomizer "," org.springframework.boot.autoconfigure.web. duplicateServerPropertiesDetector "," spring.resources-org.springframework.boot.autoconfigure.web.ResourceProperties "," org.springframework.boot.autoconfigure.web.ErrorMvcAutoConfiguration $ DefaultErrorViewResolverConfiguration "," conventionErrorViewResolver "," org.springframework.boot.autoconfigure.web.ErrorViewResolverConfiguration "," conventionErrorViewResolver "," org.springframework.boot.autoconfigure.web. contextParameters "," contextAttributes "," spring.mvc-org.springframework.boot.autoconfigure.web.WebMvcProperties "," spring.http.multipart-org.springframework.boot.autoconfigure.web.MultipartProperties "," org.springframework. boot.autoconfigure.web.MultipartAutoConfiguration "," multipartConfigElement "," org.springframework.boot.autoconfigure.web.DispatcherServletAutoConfiguration $ DispatcherServletRegistrationConfiguration "," org.springframework.boot.autoconfigure.web.DispatcherServletAutoConfiguration $ DispatcherServletConfiguration "," dispatcherServlet "," dispatcherServletRegistration "," requestContextFilter.ServletAutoConfiguration. , "httpPutFormContentFilter", "characterEncodingFilter", "org.springframework.context.event.internalEventListenerProcessor", "org.springframework.context.event.internalEventListenerFactory", "reportGeneratorApplication", "exportController. bagażnik.autoconfigure.AutoConfigurationPackages "," org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoConfiguration "," org.springframework.boot.autoconfigure.jackson.JacksonAutoConfiguration $ Jackson2ObjectMapperBuilderCustomoture.Configuration "," org.springframework.boot.autoconfigure.jackson.JacksonAutoConfiguration $ Jackson2ObjectMapperBuilderCustomoture.Configuration.jameworkson ", JacksonProperties "," standardJacksonObjectMapperBuilderCustomizer "," org.springframework.boot.autoconfigure.jackson.JacksonAutoConfiguration $ JacksonObjectMapperBuilderConfiguration "," org.springframework.boot.autoconfigure.jackson.Jackson.JacksonAutoConfiguration $ JacksonObjectMapperBuilderConfiguration "," org.springframework.boot.autoconfigure.jackson.Jackson.ModoBuilder, "org.springframework.boot.autoconfigure.jackson.Jackson.AutoConfiguration," boot.autoconfigure.jackson.JacksonAutoConfiguration $ JacksonObjectMapperConfiguration "," jacksonObjectMapper "," org.springframework.boot.autoconfigure.websocket.WebSocketAutoConfiguration "," org.springframework.boot.autoconfigure.web.EmbeddedServletContainerAutoConfiguration.websocket.WebSocketAutoConfiguration "," org.springframework.boot.autoconfigure.web.EmbeddedServletContainerAutoConfiguration.websocket.WebSocketAutoConfiguration "," , "org.springframework.boot.autoconfigure.validation.ValidationAutoConfiguration", "defaultValidator", "org.springframework.boot.autoconfigure.web.ErrorMvcAutoConfiguration $ WhitelabelErrorViewConfiguration", "error", "beanNtribameViewResolver.boot.autoconfigure.web.ErrorMvcAutoConfiguration $ WhitelabelErrorViewConfiguration", "błąd", "beanNtribameViewResolverArror", , „org.springframework.boot.autoconfigure.web.WebMvcAutoConfiguration $ EnableWebMvcConfiguration "," org.springframework.boot.autoconfigure.web.WebMvcAutoConfiguration $ WebMvcAutoConfigurationAdapter "," mvcContentNegotiationManager "," org.springframework.boot.autoconfigpertageConfiguration.web.boot.autoconfigageConfiguration.web. boot.autoconfigure.web.JacksonHttpMessageConvertersConfiguration $ MappingJackson2HttpMessageConverterConfiguration "," mappingJackson2HttpMessageConverter "," org.springframework.boot.autoconfigure.web.HttpMessageConverterConfiguration "," mappingJackson2HttpMessageConverter "," org.springframework.boot.autoconfigure.web.HttpMessageConverterConfiguration "," mappingJackson2HttpMessageConverter "," org.springframework.boot.autoconfigure.web.HttpMessageConvertersAutoConversion "," mrequestMappingHandlerAdapter”, "mvcResourceUrlProvider", "requestMappingHandlerMapping", "mvcPathMatcher", "mvcUrlPathHelper", "viewControllerHandlerMapping", "beanNameHandlerMapping", "resourceHandlerMapping", "defaultServletHandlerMapping", "mvcUriComponentsContributor", "httpRequestHandlerAdapter", "simpleControllerHandlerAdapter", "handlerExceptionResolver" , "mvcViewResolver", "org.springframework.boot.autoconfigure.web.WebMvcAutoConfiguration $ WebMvcAutoConfigurationAdapter $ FaviconConfiguration", "faviconRequestHandler", "faviconHandlerMapping", "defaultViewResolver", "viewResolver "," welcomePageHandlerMapping "," org.springframework.boot.autoconfigure.jmx.JmxAutoConfiguration "," objectNamingStrategy "," mbeanServer "," mbeanExporter "," org.springframework.boot.autoconfigure.adminication "," org.springframework.boot.autoconfigure.adminication " , „org.springframework.boot.autoconfigure.context.ConfigurationPropertiesAutoConfiguration”, „org.springframework.boot.autoconfigure.web.JacksonHttpMessageConvertersConfiguration”, „spring.info-org.springframework.boot.autoconfigure.info.Project”, „org.springframework.boot.autoconfigure.info.Project” springframework.boot.autoconfigure.info.ProjectInfoAutoConfiguration "," multipartResolver "," org.springframework.boot.autoconfigure.web.WebClientAutoConfiguration $ RestTemplateConfiguration "," restTemplateBuilder "," org.springframework.boot.autoconfigure.web.WebClientAutoConfiguration "," spring.devtools-org.springframework.boot.devtools.evroperties "," org.springframework.boot.devtools.autoconfigure.LocalDevToolsAutoConfiguration $ RestartConfiguration "," fileSystemWatcherFactory "," classPathRestartStrategy "," classPathFileSystemWatcher "," hateoasLocalDevToolsAutoConfiguration $ RestartConfiguration "," fileSystemWatcherFactory "," classPathRestartStrategy "," classPathFileSystemWatcher "," hateoas LiveolsObjenesisCacheDisabler configuration "ConfigurationConfig. org.springframework.boot.devtools.autoconfigure.LocalDevToolsAutoConfiguration $ LiveReloadConfiguration "," optionalLiveReloadServer "," org.springframework.boot.devtools.autoconfigure.LocalDevToolsAutoConfiguration "," lifecycleProcessor "]


6

Możesz spróbować zadzwonić

org.springframework.beans.factory.ListableBeanFactory.getBeansOfType(Object.class)

Lub włącz rejestrowanie debugowania dla org.springframework. (W butach wiosennych używa się parametru --logging.level.org.springframework=DEBUG)


ListableBeanFactoryto interfejs. Skąd można uzyskać instancję klasy rozszerzającej ten interfejs w celu wykonania metody getBeansOfTypelub dowolnej innej metody w interfejsie? Widzę, że ApplicationContextto przedłuża, ale twój przykład nie pokazuje, jak zdobyć jedną z nich.
ErikE

Możesz po prostu dodać pole @Autowired ListableBeanFactory listableBeanFactoryi je otrzymasz (typ implementacji nie powinien mieć znaczenia)
artbristol.

1

Za pomocą spring-boot-starter-actuatormożna łatwo uzyskać dostęp do wszystkich fasoli.

Oto proces konfiguracji:

  1. Dodaj zależność do gradle :

Dodaj poniżej do pliku gradle:

compile("org.springframework.boot:spring-boot-starter-actuator")
  1. Włącz zabezpieczenia w application.properties :

Dodaj management.security.enabled=falsedo pliku application.property

  1. punkt końcowy połączenia / fasoli :

    Po tej konfiguracji wiosna włączy niektóre punkty końcowe związane z metrykami. Jednym z jego punktów końcowych jest / fasola Po wywołaniu tych punktów końcowych dostarczy plik json, który zawiera wszystkie komponenty bean, w tym jego zależności i zakres.

Oto przykładowy plik json:

[{"context":"application:8442","parent":null,"beans":[{"bean":"beanName","aliases":[],"scope":"singleton","type":"packageName$$4b46c703","resource":"null","dependencies":["environment","beanName1","beanName2"]},{"bean":"org.springframework.boot.autoconfigure.internalCachingMetadataReaderFactory","aliases":[],"scope":"singleton","type":"org.springframework.core.type.classreading.CachingMetadataReaderFactory","resource":"null","dependencies":[]}]

Aby uzyskać więcej informacji, odwiedź poniższe linki:

Mam nadzieję, że to ci pomoże. Dzięki :)


1
spring! = spring-boot
Himanshu Bhardwaj

Tak, to prawdziwy brat :). To rozwiązanie jest dla butów sprinterskich.
Md. Sajedul Karim,

1

Oto inny sposób wydrukowania wszystkich nazw ziaren z kontekstu aplikacji wiosennej:

import java.util.Arrays;
import java.util.concurrent.atomic.AtomicInteger;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;

/***********************************************************************************************************
 * Java File: MainApplication.java
 * Description: Main class to run the application.
 * 
 ***********************************************************************************************************/

@SpringBootApplication
public class MainApplication {

private static final Logger logger = LogManager.getLogger(MainApplication.class);

public static void main(String[] args) 
{
    final ConfigurableApplicationContext context = SpringApplication.run(MainApplication.class, args);

    final AtomicInteger counter = new AtomicInteger(0);
    logger.info("**************** START: Total Bean Objects: {} ******************", context.getBeanDefinitionCount());

    Arrays.asList(context.getBeanDefinitionNames())
    .forEach(beanName -> {
        logger.info("{}) Bean Name: {} ", counter.incrementAndGet(), beanName);
    });

    logger.info("**************** END: Total Bean: {} ******************", context.getBeanDefinitionCount());
}

}


Sample Output:

2019-11-27 20:08:02.821 INFO  [main] [c.c.a.MainApplication:18] - **************** START: Total Bean Objects: 564 ****************** 
...........................
2019-11-27 20:08:02.821 INFO  [main] [c.c.a.MainApplication:22] - 460) Bean Name: mvcPathMatcher  
2019-11-27 20:08:02.821 INFO  [main] [c.c.a.MainApplication:22] - 461) Bean Name: mvcUrlPathHelper  
2019-11-27 20:08:02.821 INFO  [main] [c.c.a.MainApplication:22] - 462) Bean Name: viewControllerHandlerMapping  
2019-11-27 20:08:02.821 INFO  [main] [c.c.a.MainApplication:22] - 463) Bean Name: beanNameHandlerMapping  
2019-11-27 20:08:02.821 INFO  [main] [c.c.a.MainApplication:22] - 464) Bean Name: resourceHandlerMapping 
...........................
2019-11-27 20:08:02.821 INFO  [main] [c.c.a.MainApplication:25] - **************** END: Total Bean: 564 ****************** 
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.