NameNotFoundException: имя jdbc не связано в этом контексте - PullRequest
7 голосов
/ 19 февраля 2012

Я пытаюсь определить соединение JNDI DB в тестовом проекте со Spring.Я загрузил проект с Spring Roo и, таким образом, Mavenized.Вот скрипт Roo для справки (Roo 1.2.1)

project --topLevelPackage org.obliquid.cpool
jpa setup --database MYSQL --provider HIBERNATE --jndiDataSource /jdbc/cpool 
web mvc setup
entity jpa --class org.obliquid.cpool.entity.Person
field string --fieldName name 
web mvc scaffold --class ~.entity.Person 
web mvc all --package ~.web

В src/main/resources/META-INF/spring/applicationContext.xml У меня есть следующее (созданное Roo):

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:jee="http://www.springframework.org/schema/jee"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop-3.1.xsd
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.1.xsd
        http://www.springframework.org/schema/jee
        http://www.springframework.org/schema/jee/spring-jee-3.1.xsd
        http://www.springframework.org/schema/tx
        http://www.springframework.org/schema/tx/spring-tx-3.1.xsd">
   ...
   <jee:jndi-lookup id="dataSource" jndi-name="/jdbc/cpool" resource-ref="true"/>
   ...

Я создалsrc/main/resources/META-INF/context.xml со следующим содержимым:

<?xml version="1.0" encoding="UTF-8"?>
<Context path="/myapp" docBase="cpool" reloadable="true" debug="1">  
    <Resource name = "jdbc/cpool"
        auth = "Container"
        type = "javax.sql.DataSource"
        username = "dbusername"
        password = "dbpassword"
        driverClassName = "com.mysql.jdbc.Driver"
        url = "jdbc:mysql://localhost:3306/dbname?DateTimeBehavior=convertToNull&amp;characterEncoding=UTF-8"
        maxActive = "100"
        maxIdle = "4"
        maxWait = "20000"
        removeAbandoned = "true"
        removeAbandonedTimeout="600"
        logAbandoned="true"/>   
</Context>

Однако при попытке запустить приложение в Tomcat 7.0 я получаю следующую ошибку:

ОШИБКА org.springframework.web.context.ContextLoader - Сбой инициализации контекста org.springframework.beans.factory.BeanCreationException: Ошибка создания бина с именем «dataSource»: сбой вызова метода init;вложенное исключение - javax.naming.NameNotFoundException: имя jdbc не связано в этом контексте

Что мне следует сделать, чтобы правильно определить источник данных?

1 Ответ

11 голосов
/ 19 февраля 2012

Файл context.xml должен находиться в каталоге META-INF файла war .Он не должен находиться в каталоге классов или в файле jar.

Поместите каталог META-INF с context.xml в каталог, содержащий корень веб-приложения в дереве исходных папок.

...