我有一个在 Tomcat 8 服务器上运行的 restful api 实现。我决定使用嵌入式 Derby 版本通过 JDBC(使用 Eclipse)将数据存储在数据库中。在我看来,嵌入式版本的官方教程不是很有帮助。我按照这里的步骤操作: http://www.nailedtothex.org/roller/kyle/entry/defining-embedded-derby-as-a
我的问题是,找不到与 Derby 的连接,并且由于我使用的是 Derby 的嵌入式版本,所以我不知道如何调试未连接到 Derby 的原因。
我将 derby.jar 和 derby-shutdown-listener.jar 复制到我的 Tomcat 服务器的 lib 文件夹中。我修改了 context.xml 和 server.xml。
上下文.xml:
<Context docBase="myapp"
path="/myapp"
reloadable="true">
<ResourceLink name="jdbc/derby"
global="jdbc/derby"
type="javax.sql.DataSource" />
</Context>
我也试过这个版本的context.xml:
<Context docBase="myapp"
path="/myapp"
reloadable="true">
<Resource name="jdbc/derby" auth="Container"
driverClassName="org.apache.derby.jdbc.EmbeddedDriver"
username="bot" password="carmeq!"
type="javax.sql.DataSource"
url="jdbc:derby:mydb;create=true"/>
</Context>
服务器.xml:
<Listener className="org.nailedtothex.derby.DerbyShutdownLifecycleListener" />
然后我更改了我的 web.xml:
<resource-ref>
<res-ref-name>jdbc/derby</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
在我关于数据库连接的 Java 类中,我有以下规范:
String dbURL2 = "jdbc:derby:mydb;create=true";
这是我在调用 restful 函数时收到的异常。
javax.servlet.ServletException: java.lang.NullPointerException
org.glassfish.jersey.servlet.WebComponent.serviceImpl(WebComponent.java:487)
org.glassfish.jersey.servlet.WebComponent.service(WebComponent.java:425)
org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:383)
org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:336)
org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:223)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
调试代码时,显示没有找到适合指定url的驱动。
此外,我正在使用 Maven,在我的 Tomcat 文件夹中的 derby.jar 旁边(显示在 Libraries/Apache Tomcat v8.0 下),我还在我的 pom 中添加了相同的 derby.jar(版本 10.9.1.0)。 XML.
谢谢
最佳答案
Tomcat original documentation (至少对于 8.0)还指出,作者运气不好,网络上的其他文档也不太清楚。以下是它对我的工作方式...
在 server.xml 中,您应该在 GlobalNamingResources 中添加资源:
<GlobalNamingResources>
<!-- Keep non DB Resource stuff here ... -->
<Resource auth="Container"
driverClassName="org.apache.derby.jdbc.EmbeddedDriver"
maxActive="100" maxIdle="30" maxWait="10000"
name="jdbc/myDerby" username="" password=""
type="javax.sql.DataSource"
url="jdbc:derby:Databases/myDerbyDB;create=true"/>
</GlobalNamingResources>
在 context.xml 中,您应该像这样链接到它:
<ResourceLink name="jdbc/myDerbyLink"
global="jdbc/myDerby"
type="javax.sql.DataSource" />
我相信,将资源本身放在 context.xml 中是行不通的,至少对我来说是行不通的。
在您的代码中,数据库通常可以作为链接/引用名称访问,jdbc/myDerbyLink
:
Context initContext = new InitialContext();
Context envContext = (Context)initContext.lookup("java:/comp/env");
DataSource ds = (DataSource)envContext.lookup("jdbc/myDerbyLink");
Connection conn = ds.getConnection();
如果您避免对链接的名称和全局属性使用相同的名称,那么麻烦就会少很多。只是为了更清楚一点,这里是如何处理链接的(类似于 XPath):
Java Code "java:/comp/env/<JDBCString>"
==> context.xml:/Context/ResourceLink/@name == <JDBCString>
==> ./@global == server.xml:/GlobalNamingResources/Resource/@name
在 web.xml 中,不使用 context.xml,您应该能够直接使用资源的短名称 jdbc/myDerby
。如果没有,请尝试使用完整的 java:/comp/env/jdbc/myDerby
。
顺便说一句:如果您粘贴导致错误的代码片段,也会很有帮助。
关于tomcat - 无法访问 Tomcat 8 中的嵌入式 Derby,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40593093/