2014-09-06 88 views
0

我在spring-boot應用程序中使用spring-data-neo4j。通過繼承Neo4jConfiguration類,我按照spring.io guides和許多其他地方的建議進行了配置。這在數據庫位置在所提供的示例中被硬編碼時起作用。但是,當我想使用佔位符從屬性文件中檢索數據庫位置時,它不會被檢索到,並且我會得到空值。下面的代碼Neo4jConfiguration有循環引用

@Configuration 
@EnableNeo4jRepositories(basePackageClasses = {MyRepository.class}) 
public class Neo4jConfig extends Neo4jConfiguration { 

    @Value("${neo4j.location}") 
    private String neo4jDatabaseLocation; 

    @Bean 
    public GraphDatabaseService graphDatabaseService() { 
     return new GraphDatabaseFactory() 
       .newEmbeddedDatabase(neo4jDatabaseLocation); 
    } 
    ... 

這通常可以在任何其他配置類,但不是在這一個,因爲Neo4jConfiguration class有標有@Autowired一些幾種方法。這會導致循環引用,並且未正確初始化。這可以在日誌中看到:

2014-09-06 20:59:45.168 DEBUG 4665 --- [   main] o.s.b.f.annotation.InjectionMetadata  : Registered injected element on class [c.m.f.Neo4jConfig$$EnhancerBySpringCGLIB$$7165d752]: AutowiredFieldElement for private javax.validation.Validator org.springframework.data.neo4j.config.Neo4jConfiguration.validator 
2014-09-06 20:59:45.169 DEBUG 4665 --- [   main] o.s.b.f.annotation.InjectionMetadata  : Registered injected element on class [c.m.f.Neo4jConfig$$EnhancerBySpringCGLIB$$7165d752]: AutowiredMethodElement for public void org.springframework.data.neo4j.config.Neo4jConfiguration.setConversionService(org.springframework.core.convert.ConversionService) 
2014-09-06 20:59:45.169 DEBUG 4665 --- [   main] o.s.b.f.annotation.InjectionMetadata  : Registered injected element on class [c.m.f.Neo4jConfig$$EnhancerBySpringCGLIB$$7165d752]: AutowiredMethodElement for public void org.springframework.data.neo4j.config.Neo4jConfiguration.setGraphDatabaseService(org.neo4j.graphdb.GraphDatabaseService) 
2014-09-06 20:59:45.169 DEBUG 4665 --- [   main] o.s.b.f.annotation.InjectionMetadata  : Registered injected element on class [c.m.f.Neo4jConfig$$EnhancerBySpringCGLIB$$7165d752]: AutowiredFieldElement for private java.lang.String c.m.f.Neo4jConfig.neo4jDatabaseLocation 
2014-09-06 20:59:45.169 DEBUG 4665 --- [   main] o.s.b.f.s.DefaultListableBeanFactory  : Eagerly caching bean 'c.m.f.Neo4jConfig' to allow for resolving potential circular references 
2014-09-06 20:59:45.171 DEBUG 4665 --- [   main] o.s.b.f.annotation.InjectionMetadata  : Processing injected method of bean 'c.m.f.Neo4jConfig': AutowiredFieldElement for private javax.validation.Validator org.springframework.data.neo4j.config.Neo4jConfiguration.validator 
2014-09-06 20:59:45.182 DEBUG 4665 --- [   main] o.s.b.f.annotation.InjectionMetadata  : Processing injected method of bean 'c.m.f.Neo4jConfig': AutowiredMethodElement for public void org.springframework.data.neo4j.config.Neo4jConfiguration.setConversionService(org.springframework.core.convert.ConversionService) 
2014-09-06 20:59:45.183 DEBUG 4665 --- [   main] o.s.b.f.annotation.InjectionMetadata  : Processing injected method of bean 'c.m.f.Neo4jConfig': AutowiredMethodElement for public void org.springframework.data.neo4j.config.Neo4jConfiguration.setGraphDatabaseService(org.neo4j.graphdb.GraphDatabaseService) 
2014-09-06 20:59:45.184 DEBUG 4665 --- [   main] o.s.b.f.s.DefaultListableBeanFactory  : Creating shared instance of singleton bean 'graphDatabaseService' 
2014-09-06 20:59:45.184 DEBUG 4665 --- [   main] o.s.b.f.s.DefaultListableBeanFactory  : Creating instance of bean 'graphDatabaseService' 
2014-09-06 20:59:45.185 DEBUG 4665 --- [   main] o.s.b.f.s.DefaultListableBeanFactory  : Returning cached instance of singleton bean 'org.springframework.transaction.config.internalTransactionAdvisor' 
2014-09-06 20:59:45.185 DEBUG 4665 --- [   main] o.s.b.f.s.DefaultListableBeanFactory  : Returning cached instance of singleton bean 'org.springframework.transaction.config.internalTransactionAdvisor' 
2014-09-06 20:59:45.188 DEBUG 4665 --- [   main] o.s.b.f.s.DefaultListableBeanFactory  : Returning eagerly cached instance of singleton bean 'c.m.f.Neo4jConfig' that is not fully initialized yet - a consequence of a circular reference 

正如你可以看到我在這裏試圖實現的不是硬編碼數據庫位置。有沒有解決這個循環引用問題的方法?或者也許還有其他配置方式?由於這是一個spring-boot應用程序,我沒有任何Xml配置,如果可能的話我想保留它。

+0

代替'@ Value'注入'Environment'並使用'getProperty'或'getRequiredProperty'方法來獲取實際值。在配置類中,我總是傾向於使用'Environment'而不是'@Value'。 – 2014-09-08 10:34:41

回答

1

擬議的建議並沒有爲我使用Spring Framework版本。作爲一種解決方法,我在另一個不擴展Neo4jConfiguration的配置文件中定義了GraphDatabaseService bean。請注意,無論如何,這個Neo4jConfig類都是需要的。

+0

面對上Neo4j的彈簧數據Neo4j的3.3.2和閱讀您的評論後,同樣的問題,我只創建包含@Bean GraphDatabaseService graphDatabaseService()其他類{ 返回新SpringCypherRestGraphDatabase(neo4jProperties.getServerUrl(), neo4jProperties。 getUsername(),neo4jProperties.getPassword()); }定義。你解決了我的問題! – Stephane 2015-09-13 14:41:17

+0

@rosencreuz,斯蒂芬你能分享你的應用程序/配置/額外的類源?我正試圖解決這個問題,但目前還沒有運氣...... – 2016-04-25 12:51:48

1

您是否嘗試過在neo4jDatabaseLocation作爲參數傳遞:

@Configuration 
@EnableNeo4jRepositories(basePackageClasses = {MyRepository.class}) 
public class Neo4jConfig extends Neo4jConfiguration { 

    @Bean 
    public GraphDatabaseService graphDatabaseService(@Value("${neo4j.location}") String neo4jDatabaseLocation) { 
     return new GraphDatabaseFactory() 
       .newEmbeddedDatabase(neo4jDatabaseLocation); 
    } 
    ... 
} 
+0

我有同樣的問題,這個答案爲我工作。 – 2015-01-22 17:50:19