gpt4 book ai didi

tomcat - 无法访问 Tomcat 8 中的嵌入式 Derby

转载 作者:行者123 更新时间:2023-11-28 22:17:21 24 4
gpt4 key购买 nike

我有一个在 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com