【发布时间】:2017-03-28 08:19:42
【问题描述】:
我在 Tomcat 8 服务器上运行了一个安静的 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。
context.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>
server.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.jar 中添加了相同的 derby.jar(版本 10.9.1.0)。 xml。
谢谢
【问题讨论】:
-
“未找到与 Derby 的连接”是什么意思?您收到错误消息吗?例外?尽可能准确地描述您所经历的特定症状,人们可以提供帮助。
-
嗨@BryanPendleton,我添加了例外。
-
我发现讨论:stackoverflow.com/questions/3816015/…,但 derby.jar 位于 tomcat 文件夹中,并显示在 Libraries 的 tomcat 部分中。关于网址,我几乎尝试了所有内容..
-
你能补充更多关于“调试代码,它显示没有找到适合指定url的驱动程序”的细节吗?
-
在 java.sql.DriverManager 类中,如果范围://如果我们到达这里,没有人可以连接。 if (reason != null) { println("getConnection failed: " + reason);抛出理由; } println("getConnection: 没有找到适合 "+ url) 的驱动程序; throw new SQLException("没有为 "+ url, "08001" 找到合适的驱动程序); }
标签: tomcat jdbc derby embedded-database