私のウェブアプリは、JNDIから次のデータソースを取得しています。
javax.naming.InitialContext ctx = new javax.naming.InitialContext();
javax.sql.DataSource ds = (javax.sql.DataSource)
ctx.lookup("Java:comp/env/jdbc/db");
アプリのWEB-INF/web.xml
、 私が持っています:
<resource-ref>
<description>DataSource</description>
<res-ref-name>jdbc/db</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
アプリのWEB-INF/ibm-web-bnd.xml
、 私が持っています:
<web-bnd
xmlns="http://websphere.ibm.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://websphere.ibm.com/xml/ns/javaee http://websphere.ibm.com/xml/ns/javaee/ibm-web-bnd_1_0.xsd"
version="1.0">
<virtual-Host name="default_Host"/>
<resource-ref name="jdbc/db" binding-name="jdbc/db"/>
</web-bnd>
WebSphere LibertyProfileのserver.xml
、私は持っています(関連する部分を維持します):
<server description="new server">
<featureManager>
<feature>jsp-2.2</feature>
<feature>jdbc-4.0</feature>
</featureManager>
<library id="Oracle-lib">
<fileset dir="lib" includes="ojdbc5_g.jar"/>
</library>
<dataSource jndiName="jdbc/db" jdbcDriverRef="Oracle-driver" type="javax.sql.DataSource">
<jdbcDriver libraryRef="Oracle-lib" id="Oracle-driver"/>
<connectionManager numConnectionsPerThreadLocal="10" id="ConnectionManager" minPoolSize="1"/>
<properties user="user" password="password"
url="jdbc:Oracle:thin:@//db-server:1521/db"/>
</dataSource>
</server>
アプリがJNDIからデータソースを取得しようとすると、次のエラーで失敗します。
CWNEN0030E: The @Resource factory encountered a problem getting
the object instance jdbc/Oracle binding object. The exception message was:
failed to resolve jdbc/Oracle to javax.sql.DataSource:
javax.naming.NameNotFoundException:
Intermediate context does not exist: jdbc/Oracle
私がここで欠けているものは何ですか?
<server>
<featureManager>
<feature>jndi-1.0</feature>
<feature>jdbc-4.1</feature>
</featureManager>
<httpEndpoint id="defaultHttpEndpoint"
Host="localhost"
httpPort="9080"
httpsPort="9443" />
<library id="Oracle-lib">
<fileset dir="lib" includes="ojdbc6_g.jar"/>
</library>
<dataSource jndiName="jdbc/Oracle">
<jdbcDriver libraryRef="Oracle-lib"/>
<properties.Oracle user="orbeon" password="password"
url="jdbc:Oracle:thin:@//localhost:1521/orbeon"/>
</dataSource>
<application name="orbeon" location="war/orbeon" type="war">
<classloader commonLibraryRef="Oracle-lib"/>
</application>
</server>
<web-bnd version="1.0"
xmlns="http://websphere.ibm.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://websphere.ibm.com/xml/ns/javaee http://websphere.ibm.com/xml/ns/javaee/ibm-web-bnd_1_0.xsd">
<virtual-Host name="default_Host"/>
<resource-ref name="jdbc/Oracle" binding-name="jdbc/Oracle"/>
</web-bnd>
<resource-ref>
<res-ref-name>jdbc/Oracle</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
@Resource(lookup = "jdbc/Oracle")
DataSource ds;
liberty 8.5.5でDB2を使用し、server.xmlにあります。
<dataSource id="db2" isolationLevel="TRANSACTION_READ_COMMITTED" jndiName="jdbc/db2" type="javax.sql.DataSource">
<jdbcDriver>
<library>
<fileset dir="/usr/lib/Java/ibm-db2-universal-driver" includes="db2jcc4.jar, db2jcc_license_cisuz.jar, db2jcc_license_cu.jar"/>
</library>
</jdbcDriver>
<properties.db2.jcc databaseName="DB2T" portNumber="21020" serverName="db2t.lvm.de"/>
<containerAuthData password="{xor}KzspMC04" user="tdvorg"/>
</dataSource>
多分それを助けます。
ロバート
私の場合、以下の解決策は私にとってはうまくいきます。
Eclipseで「Resources」という「Genericproject」を作成しました。このプロジェクト内で、次の内容のファイルdataSource.xml
を作成しました。
<server>
<dataSource id="ccm" jndiName="jdbc/ccm" type="javax.sql.DataSource">
<jdbcDriver id="Oracle-driver" libraryRef="Oracle-lib"/>
<connectionManager id="ConnectionManager" minPoolSize="1" numConnectionsPerThreadLocal="10"/>
<properties.Oracle password="password" url="jdbc:Oracle:thin:@128.1.30.150:1521:ccmdes" user="ccm"/>
</dataSource>
<library id="Oracle-lib">
<fileset dir="C:\Oracle\product\10.1.0\Client_1\jdbc\lib" includes="ojdbc14_g.jar"/>
</library>
<jdbcDriver id="Oracle" libraryRef="Oracle-lib"/>
</server>
そして、Eclipseでサーバーを構成するためにこのファイルをドラッグアンドドロップするか、server.xml
に行を作成します。
<include location="${shared.config.dir}/dataSource.xml"/>
ファイルserver.xml
は次のようになりました。
<server description="new server">
<!-- Enable features -->
<featureManager>
<feature>jsp-2.3</feature>
<feature>adminCenter-1.0</feature>
<feature>jdbc-4.1</feature>
<feature>jndi-1.0</feature>
<feature>servlet-3.1</feature>
</featureManager>
<httpEndpoint Host="localhost" httpPort="9080" httpsPort="9443" id="defaultHttpEndpoint"/>
<applicationMonitor updateTrigger="mbean"/>
<!-- Define your admin user name and password -->
<quickStartSecurity userName="admin" userPassword="password"/>
<!-- Define a keystore for the HTTPS port -->
<keyStore id="defaultKeyStore" password="Liberty"/>
<!-- Allows remote file access for config changes -->
<remoteFileAccess>
<writeDir>${server.config.dir}</writeDir>
</remoteFileAccess>
<!-- <applicationMonitor updateTrigger="mbean"/> -->
<webApplication id="TestPage" location="TestPage.war" name="TestPage"/>
<webApplication id="MonitoriaAtendimento" location="MonitoriaAtendimento.war" name="MonitoriaAtendimento"/>
<include location="${shared.config.dir}/dataSource.xml"/>
</server>