javax.naming.NameNotFoundException: mysql_ds not bound

前天单位招外包,让我给出点题,然后跟两个老大哥去面试一下,说实话,我还想出去参加面试呢,现在这点工资,实在是难以糊口啊!出了两道上机题,一个EJB的,一个struts2的,题很简单,结果面了五个人,没一个完成的,领导很郁闷,我也很无奈。刚才想用给考生配的环境玩点东西,结果发现当时数据源配的居然有点问题,我晕啊,还好不影响那两道上机题,不然丢人可就丢大了。

 

问题 是这样:我用jboss docs中mysql数据源的模板配了一个数据源,当调用的时候报如下错误

 

javax.naming.NameNotFoundException: mysql_ds not bound
	at org.jnp.server.NamingServer.getBinding(NamingServer.java:771)
	at org.jnp.server.NamingServer.getBinding(NamingServer.java:779)
	at org.jnp.server.NamingServer.getObject(NamingServer.java:785)
	at org.jnp.server.NamingServer.lookup(NamingServer.java:443)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
	at java.lang.reflect.Method.invoke(Unknown Source)
	at sun.rmi.server.UnicastServerRef.dispatch(Unknown Source)
	at sun.rmi.transport.Transport$1.run(Unknown Source)
	at java.security.AccessController.doPrivileged(Native Method)
	at sun.rmi.transport.Transport.serviceCall(Unknown Source)
	at sun.rmi.transport.tcp.TCPTransport.handleMessages(Unknown Source)
	at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(Unknown Source)
	at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(Unknown Source)
	at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
	at java.lang.Thread.run(Unknown Source)
	at sun.rmi.transport.StreamRemoteCall.exceptionReceivedFromServer(Unknown Source)
	at sun.rmi.transport.StreamRemoteCall.executeCall(Unknown Source)
	at sun.rmi.server.UnicastRef.invoke(Unknown Source)
	at org.jnp.server.NamingServer_Stub.lookup(Unknown Source)
	at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:726)
	at org.jnp.interfaces.NamingContext.lookup(NamingContext.java:686)
	at javax.naming.InitialContext.lookup(Unknown Source)
	at test.Test.main(Test.java:44)
 

在jboss的控制台中可以看到这个JNDI

 

 

原因 :在配置mysql数据源时,没有指定<use-java-context>属性,因此无法在jboss的JVM外VM中找到这个数据源。可以到http://community.jboss.org/wiki/ConfigDataSources 查看关于这个配置的说明。这个属性的默认值为true,也就是说,如果你想在jboss的JVM以外访问这个数据源,需要手动将该值改为false。

 

 

解决 :在数据源配置文件中(我的是mysql-ds.xml),加入<use-java-context>false</use-java-context>,就可以得到这个数据源了。如:

<datasources>
  <local-tx-datasource>
    <jndi-name>mysql_ds</jndi-name>
    <use-java-context>false</use-java-context>


    <connection-url>jdbc:mysql://127.0.0.1:3306/exam</connection-url>
    <driver-class>com.mysql.jdbc.Driver</driver-class>
    <user-name>root</user-name>
    <password>wuhongyu1985</password>
    <exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</exception-sorter-class-name>
    <metadata>
       <type-mapping>mySQL</type-mapping>
    </metadata>
  </local-tx-datasource>
</datasources>
 

 

 

 

 

 

 

 

你可能感兴趣的:(java,mysql,面试,jboss,sun)