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

标签 tomcat jdbc derby embedded-database

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

相关文章:

tomcat - 部署到 Tomcat 上的非 appBase 位置

security - Tomcat安全访问

java - Apache POI SXSSF 在刷新行上显示 NullPointerException

java.sql.SQLException : Invalid handle

java - org.apache.thrift.TApplicationException:必填字段 'client_protocol'未设置

java - java中sql查询的正确格式

java - 哪些数据库支持同步复制(Java/嵌入式首选)?

java - Servlets , JPA - 登录问题

java - Apache Derby 嵌入式模式部署

java - 使用tomcat运行时在java中获取路径文件夹