2015-05-26 79 views
0

Howdie do,JNDI在服务器初始化函数中抛出Servlet异常

我试图将应用程序部署到我的新Tomcat托管服务。问题是我现在正在运行服务器初始化函数时得到一个Servlet异常。

下面的错误是:

26-May-2015 12:56:48.668 SEVERE [http-nio-12937-exec-2] org.apache.catalina.core.StandardWrapperValve.invoke Allocate exception for servlet Controller 
javax.servlet.ServletException 
    at controller.Controller.init(Controller.java:42) 
    at org.apache.catalina.core.StandardWrapper.initServlet(StandardWrapper.java:1241) 
    at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1154) 
    at org.apache.catalina.core.StandardWrapper.allocate(StandardWrapper.java:827) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:135) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:503) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:136) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:526) 
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1078) 
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:655) 
    at org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:222) 
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1566) 
    at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1523) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) 
    at java.lang.Thread.run(Thread.java:744) 

现在,这是我的web.xml文件中,设置了数据源:

<Resource name="jdbc/drkplaya_pkRater" auth="Container" 
      type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" 
      url="jdbc:mysql://localhost:3306/drkplaya_pkRater" 
      username="drkplaya_pkRater" password="" initialSize="1" maxActive="30" maxIdle="30" 
      maxWait="15000" removeAbandoned="true" removeAbandonedTimeout="300" logAbandoned="true" 
      validationQuery="select now();" 
    /> 
    <servlet> 
    <description></description> 
    <display-name>Controller</display-name> 
    <servlet-name>Controller</servlet-name> 
    <servlet-class>controller.Controller</servlet-class> 
    </servlet> 
    <servlet-mapping> 
    <servlet-name>Controller</servlet-name> 
    <url-pattern>/gallery</url-pattern> 
    </servlet-mapping> 

最后,这是我的初始化函数调用数据源:

public void init(ServletConfig config) throws ServletException { 
     try { 
      InitialContext initContext = new InitialContext(); 
      Context env = (Context) initContext.lookup("java:comp/env"); 

      ds = (DataSource) env.lookup("jdbc/drkplaya_pkRater"); 

     } catch (NamingException e) { 
      throw new ServletException(); 
     } 
    } 

现在,这是我的本地服务器上运行的100%,但在上传,我收到异常清单当然d以上。

在我的init函数中是否存在导致此错误的错误?

编辑:有人指出,我吞下了NameException。修复后,我知道有以下错误:

message javax.naming.NameNotFoundException: Name [jdbc/drkplaya_pkRater] is not bound in this Context. Unable to find [jdbc]. 

description The server encountered an internal error that prevented it from fulfilling this request. 

exception 

javax.servlet.ServletException: javax.naming.NameNotFoundException: Name [jdbc/drkplaya_pkRater] is not bound in this Context. Unable to find [jdbc]. 
    controller.Controller.init(Controller.java:42) 
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:503) 
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79) 
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:526) 
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1078) 
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:655) 
    org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:222) 
    org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1566) 
    org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1523) 
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) 
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 
    org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) 
    java.lang.Thread.run(Thread.java:744) 
root cause 

javax.naming.NameNotFoundException: Name [jdbc/drkplaya_pkRater] is not bound in this Context. Unable to find [jdbc]. 
    org.apache.naming.NamingContext.lookup(NamingContext.java:818) 
    org.apache.naming.NamingContext.lookup(NamingContext.java:166) 
    controller.Controller.init(Controller.java:39) 
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:503) 
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79) 
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:526) 
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1078) 
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:655) 
    org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:222) 
    org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1566) 
    org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1523) 
    java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) 
    java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) 
    org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) 
+1

你为什么吞咽可能包含根本原因线索的'NamingException'?绝对不要这样做,例外。总是将它们包装为根本原因,就像这样抛出新的ServletException(e);'。然后你会在堆栈跟踪中看到一个“由...引起”,最底层的通常已经代表整个答案。您的问题标题也是误导性的。 JNDI没有这样做。你自己做到了。 – BalusC

+0

我很欣赏答案,但是,这是我的第一个JNDI应用程序。我只是试图找到我的错误的原因。 – Jimmy

回答

1

您的mysql服务器可能运行在不同于tomcat的主机上。您将本地主机置于您的资源配置中。请咨询您的托管服务提供商什么是您的数据库服务器的主机。

+0

谢谢你的回复。我已将Resource配置更新为:url =“jdbc:mysql://mysql3000.mochahost.com:3306/drkplaya_pkRater”,因为这是我从主机服务器获得的主机。但是,仍然完全相同的错误 – Jimmy

1

运行良好的本地机器上,因为这样的:

url="jdbc:mysql://localhost:3306/drkplaya_pkRater" 
     username="drkplaya_pkRater" password="" 

但是当你的主机服务器上部署相同web.xml,该localhost是指特定的主机服务器。

所以,你有两个选择:

1)无论是确保有一个mysql服务器上host server与特定的用户名在3306端口上运行。

(或)

2)更改url=username, password以配合mysql数据库实例上该特定host server

+0

你好,谢谢你的回复。问题是我已将连接字符串更改为:url =“jdbc:mysql://mysql3000.mochahost.com:3306/drkplaya_pkRater” ,因为这是我从主机服务器获得的主机。但是,仍然是完全相同的错误 – Jimmy

0

的问题是两件事情

1)我没有使用mysql-connector在我的Apache/lib目录

2)我从来没有设置我的context.xml文件,包括上下文为此服务器应该连接。所以我增加了以下我的context.xml文件:

<Resource name="jdbc/drkplaya_pkRater" auth="Container" 
      type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" 
      url="jdbc:mysql://mysql3000.mochahost.com:3306/drkplaya_pkRater" 
      username="drkplaya_pkRater" password="" initialSize="1" maxActive="30" maxIdle="30" 
      maxWait="15000" removeAbandoned="true" removeAbandonedTimeout="300" logAbandoned="true" 
      validationQuery="select now();" 
    /> 

3)我不得不更新我的web.xml文件只引用context.xml文件中创建的资源:

<resource-ref> 
    <description>DB Connection</description> 
    <res-ref-name>jdbc/drkplaya_pkRater</res-ref-name> 
    <res-type>javax.sql.DataSource</res-type> 
    <res-auth>Container</res-auth> 
    </resource-ref> 

4)感谢BalusC指出我在init函数中吞下了异常。所以它已被更改为:

public void init(ServletConfig config) throws ServletException { 
     try { 
      InitialContext initContext = new InitialContext(); 
      Context env = (Context) initContext.lookup("java:comp/env"); 

      ds = (DataSource) env.lookup("jdbc/drkplaya_pkRater"); 

     } catch (NamingException e) { 
      throw new ServletException(e); 
     } 
    } 

我现在已成功连接到数据源。

再次感谢

相关问题