[英]Tomcat JNDI resource for Datanucleus (JDO)
我已经在Tomcat 7.0上开发了一个使用Datanucleus / JDO访问数据库的应用程序。 我目前在应用程序本身的“ datanucleus.properties”中存储了JDO连接属性。 连接工作正常,但是我想将连接信息存储为JNDI,以便将其存储在服务器上,而不再用于战争本身(远程部署它时,我总是必须在战争中替换该文件)。
我尝试了以下方法:
在应用程序的web.xml(jdbc / ConnectionDB)中创建一个
在“ Server.xml”中,我尝试添加以下应用程序上下文
<Resource name="jdbc/ConnectionDB" auth="Container" type="javax.jdo.PersistenceManagerFactory" /> <ResourceParams name="jdbc/ConnectionDB <parameter> <name>javax.jdo.PersistenceManagerFactoryClass</name> <value>org.datanucleus.api.jdo.JDOPersistenceManagerFactory</value> </parameter> <parameter> <name>javax.jdo.option.ConnectionDriverName</name> <value>com.mysql.jdbc.Driver</value> </parameter> <parameter> <name>javax.jdo.option.ConnectionURL</name> <value>jdbc:mysql://localhost/TomcatTest</value> </parameter> ...
然后,我尝试使用以下语法创建新的PMF:
上下文上下文= null; PersistenceManagerFactory pmf = JDOHelper.getPersistenceManagerFactory(“ java:comp / env / jdbc / ConnectionDB”,context);
运行我的应用程序时,我得到一个javax.jdo.JDOUserException:您已为此PMF指定使用“ datanucleus.properties”的“持久性单元”(但不存在!)
我不太了解我的设置有什么问题。
问候,
马塞尔
我终于找到了我想要的解决方案,我将其发布在这里,它可能会对其他人有所帮助:
在服务器的“ Context.xml”文件中创建资源
<Resource name="jdbc/SyncTestDB" auth="Container" type="javax.sql.DataSource" maxActive="100" maxIdle="30" maxWait="10000" username="root" password="mysql" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost/SyncTestDB"/>
在应用程序的“ web.xml”文件中创建对该资源的引用
<resource-ref> <description>MySQL Database Connection</description> <res-ref-name>jdbc/SyncTestDB</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref>
最后使用JNDI连接获得一个Persistence Manager Factory:
PersistenceManagerFactory pmf; Properties properties = new Properties(); properties.setProperty("datanucleus.ConnectionFactoryName","java:comp/env/jdbc/SyncTestDB");
阅读JDOHelper.getPersistenceManagerFactory(String)的javadoc,显然它不是用于传递某些JNDI数据源字符串。
阅读Tomcat的文档,您还将看到指定数据源不提供JDO连接详细信息。
您可以同样为“ javax.jdo.option.ConnectionFactoryName”属性使用该JNDI字符串指定persistence.xml。 根据JDO规范和DataNucleus / Tomcat文档,然后
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.