【问题标题】:Can't access to Embedded Derby in Tomcat 8无法在 Tomcat 8 中访问 Embedded Derby
【发布时间】: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


【解决方案1】:

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

顺便说一句:如果您粘贴导致错误的代码段也会很有帮助。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2016-12-16
    • 2015-05-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多