我对Spring Boot还是比较陌生,并且已经按照How to create JNDI context in Spring Boot with Embedded Tomcat Container
中的建议实施了一种在JNDI上下文中放置数据源的方法。我通过将这些bean添加到应用程序中来使其工作,这样可以命名并将数据源放置在JNDI上下文中,如下所示:
@Autowired
Environment env;
public static void main(final String[] args) {
SpringApplication.run(MyApplication.class, args);
}
@Bean
public TomcatEmbeddedServletContainerFactory tomcatFactory() {
return new TomcatEmbeddedServletContainerFactory(){
@Override
public TomcatEmbeddedServletContainer getTomcatEmbeddedServletContainer(final Tomcat tomcat) {
tomcat.enableNaming();
return super.getTomcatEmbeddedServletContainer(tomcat);
}
@Override
public void postProcessContext(final Context context) {
final String dataSourceURL = env.getProperty("datasource.url");
// more properties
final ContextResource resource = new ContextResource();
resource.setType(DataSource.class.getName());
resource.setProperty("url", dataSourceURL);
// more properties
resource.setName("jdbc/myDB");
resource.setAuth("Container");
resource.setType("javax.sql.DataSource");
resource.setScope("Sharable");
resource.setProperty("factory", "org.apache.commons.dbcp.BasicDataSourceFactory");
context.getNamingResources().addResource(resource);
}
};
}
@Bean(destroyMethod = "")
public DataSource jndiDataSource() throws IllegalArgumentException, NamingException {
final JndiObjectFactoryBean bean = new JndiObjectFactoryBean();
bean.setJndiName("java:comp/env/jdbc/myDB");
bean.setProxyInterface(DataSource.class);
bean.setLookupOnStartup(false);
bean.afterPropertiesSet();
return (DataSource)bean.getObject();
}
到目前为止,一切顺利。但是现在该项目的规范已更改。除了提供启动嵌入式Tomcat的胖JAR(按最初计划)之外,我还需要能够提供没有对嵌入式Tomcat的引用的WAR。 因此,我创建了用于打包的其他项目,并通过Maven依赖项处理了嵌入式Tomcat的可选包含。问题是,我不得不将上面显示的代码移出我的主类,并移到一个单独的程序包中,该程序包是通过Maven依赖项包含的。现在,它不再有用。
我承认我对@Autowired和@Bean的Spring-magic的工作方式不太熟悉,所以我在这里徘徊了一点。
我该怎么做才能使JNDI上下文的创建在我的主类之外进行?
答案 0 :(得分:0)
该解决方案非常简单,我可以通过学习更多有关Spring bean的方法来找到它。我创建了另一个创建了bean的类,并用@Configuration
对其进行了注释,并将其添加到主类的@ComponentScan
规范中。看起来像这样:
@ComponentScan(basePackages = {"myBasePackage",
"externalPackageContainingConfiguration"})
externalPackageContainingConfiguration
仅在通过Maven Dependency添加工件时发现。有点hacky,但是可以解决问题。