我正在尝试使用Spring JndiObjectFactoryBean配置DB DataSource,因此,我有tomcat:运行插件用于本地测试目的,context.xml文件位于src / test / resources / maven-tomcat-plugin /
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<contextFile>${basedir}/src/test/resources/maven-tomcat-plugin/context.xml</contextFile>
</configuration>
</plugin>
context.xml中
<?xml version='1.0' encoding='utf-8'?>
<Context>
<ResourceLink name="jdbc/MyLocalDB" global="jdbc/TestDB" auth="Container" type="javax.sql.DataSource" />
<Resource name="jdbc/MyDB" global="jdbc/MyDB" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver"
url="jdbc" username="" password="" maxActive="100" maxIdle="20" minIdle="5"
maxWait="10000" />
</Context>
但我有:名称[jdbc / TestDB]未在此上下文中绑定
看起来contextPath没有提供任何内容。
有没有人有任何idia如何解决?
答案 0 :(得分:0)
<ResourceLink>
元素旨在构建指向全局资源的链接,该资源应在server.xml
文件下声明,其外观如下所示:
<GlobalNamingResources>
<Resource name="jdbc/DatabaseName" auth="Container" type="javax.sql.DataSource"
username="dbUsername" password="dbPasswd"
url="jdbc:postgresql://localhost/dbname"
driverClassName="org.postgresql.Driver"
initialSize="5" maxWait="5000"
maxActive="120" maxIdle="5"
validationQuery="select 1"
poolPreparedStatements="true"/>
</GlobalNamingResources/>
请注意,name
属性必须与ResourceLink元素的global
属性匹配。
因此要么声明一个匹配的全局资源,要么只是删除资源链接并像你一样使用声明的资源。
答案 1 :(得分:0)
您可以尝试以下配置(不要忘记添加依赖项):
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<port>9090</port>
<path>/myapp</path>
<contextFile>${basedir}/tomcat7-maven-plugin/context.xml</contextFile>
</configuration>
<dependencies>
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0.3</version>
</dependency>
</dependencies>
</plugin>
还有context.xml:
<?xml version="1.0" encoding="UTF-8"?>
<Context debug="true" reloadable="true" crossContext="true"
antiJARLocking="true">
<Resource name="jdbc/myDS" auth="Container"
type="javax.sql.DataSource" maxActive="100" maxIdle="30"
maxWait="10000" validationQuery="select sysdate from dual"
username="userdb" password="pass123"
driverClassName="oracle.jdbc.driver.OracleDriver"
url="jdbc:oracle:thin:@server:1521:sid" />
</Context>
有关信息,您可以查看Apache Tomcat网页https://tomcat.apache.org/maven-plugin-2.2/tomcat7-maven-plugin/run-mojo.html