带有可选嵌入式Tomcat容器的Spring Boot中的JNDI

时间:2019-02-06 09:35:09

标签: java spring maven spring-boot tomcat

我对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上下文的创建在我的主类之外进行?

1 个答案:

答案 0 :(得分:0)

该解决方案非常简单,我可以通过学习更多有关Spring bean的方法来找到它。我创建了另一个创建了bean的类,并用@Configuration对其进行了注释,并将其添加到主类的@ComponentScan规范中。看起来像这样:

@ComponentScan(basePackages = {"myBasePackage",
                           "externalPackageContainingConfiguration"})

externalPackageContainingConfiguration仅在通过Maven Dependency添加工件时发现。有点hacky,但是可以解决问题。