Как настроить источник данных JNDI с помощью Spring Boot & WildFly 11.0 - PullRequest
0 голосов
/ 03 мая 2018

Я хочу настроить JNDI DataSource с Spring Boot & WildFly 11.0. В настоящее время я использую Postgres DB и имею конфигурацию источника данных в application.properties.

Я знаю, что jndi можно создать с помощью следующего в application.properties. С чем я борюсь, как связать это с JBoss WildFly?

а. Что мне нужно добавить / изменить в standalone.xml в WildFly и б. Любые изменения, необходимые в классе основного приложения Spring Boot ProjectPocApiApplication

Спасибо

ProjectPocApiApplication.java

@SpringBootApplication
public class ProjectPocApiApplication  extends SpringBootServletInitializer{

public static void main(String[] args) {

    SpringApplication.run(ProjectPocApiApplication.class, args);
}

@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
    return builder.sources(ProjectPocApiApplication.class);

}}

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>com.poc.project</groupId>
<artifactId>project-poc-api</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>

<name>project-poc-api</name>
<description>POC for Project Management Dashboard </description>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.12.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-tomcat</artifactId>
            </exclusion>
         </exclusions>
    </dependency>

    <dependency>
        <groupId>org.postgresql</groupId>
        <artifactId>postgresql</artifactId>
        <version>9.4-1206-jdbc42</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>javax.servlet-api</artifactId>
        <scope>provided</scope>
     </dependency>
    </dependencies> 

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

1 Ответ

0 голосов
/ 03 мая 2018

Я бы предположил, что вам нужно иметь нижеуказанную конфигурацию в подсистеме источников данных автономного xml. (убедитесь, что структура модуля org.postgresql существует в домашнем каталоге WildFly)

<subsystem xmlns="urn:jboss:domain:datasources:2.0">
    <datasources>
        <datasource jndi-name="java:jboss/datasources/PostgreSQLDataSource" pool-name="PostgreSQLDataSourcePool" enabled="true" use-java-context="true">
            <connection-url>jdbc:postgresql://localhost/test</connection-url>
            <driver>postgresql</driver>
        </datasource>
        <drivers>
            <driver name="postgresql" module="org.postgresql">
                <datasource-class>org.postgresql.Driver</datasource-class>
            </driver>
        </drivers>
    </datasources>
</subsystem>

И я предполагаю, что вы можете настроить источник данных в основном классе, используя следующий подход

@Bean
public DataSource dataSource() 
{
  JndiDataSourceLookup dataSourceLookup = new JndiDataSourceLookup();
  DataSource dataSource = dataSourceLookup.getDataSource("java:jboss/datasources/PostgreSQLDataSource");
  return dataSource;
}

(Ничего особо не проверено, просто выбрасываю)

...