web-dev-qa-db-ja.com

WebSphere Liberty Profile8.5を使用したデータソースのセットアップ

私のウェブアプリは、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

私がここで欠けているものは何ですか?

8
avernet

WebSphere server.xml

<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-INF/ibm-web-bnd.xml

<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>

WEB-INF/web.xml

<resource-ref>
    <res-ref-name>jdbc/Oracle</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
</resource-ref>

リソースインジェクション(web.xml + ibm-web-bnd.xmlの代わりに):

@Resource(lookup = "jdbc/Oracle")
DataSource ds;
12
avernet

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>

多分それを助けます。

ロバート

3
Robert

私の場合、以下の解決策は私にとってはうまくいきます。

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>
0
Anderson