Tomcat のコネクションプールで CData JDBC Driver for SAP HANA XS Advanced を構成

Jerod Johnson
Jerod Johnson
Senior Technology Evangelist
Tomcat のコネクションプールから SAP HANA XS Advanced のデータ に接続。

CData JDBC Driver は、JVM 上で動作するWeb アプリケーションと連携するための標準JDBC インターフェースをサポートしています。ここでは、Tomcat のコネクションプールから SAP HANA XS Advanced のデータ に接続する方法を説明します。

Tomcat のコネクションプールから SAP HANA XS Advanced のデータ に接続

  1. CData JAR ファイルと CData .lic ファイルを $CATALINA_HOME/lib にコピーします。CData JAR ファイルは、インストールディレクトリの lib サブフォルダにあります。
  2. コンテキストにリソースの定義を追加します。ここでJDBC URL を指定します。

    SAP HANA XSA 接続プロパティの取得・設定方法

    SAP HANA XSA はOAuth 認証標準を利用しています。接続する前に、SAP HANA XSA OData サービスを確立する必要があります。ヘルプドキュメントの「カスタムOAuth アプリの作成」セクションを参照してください。

    OAuthPassword グラント種別を使用してSAP HANA XSA に接続するには、以下を設定します。

    • OAuthClientId:UAA サービスJSON ファイルで指定されたClient Id に設定。
    • OAuthClientSecret:UAA サービスJSON ファイルで指定されたClient Secret に設定。
    • Url:OData サービスエンドポイントに設定。
    • XSUAAURL:UAA サービスURL に設定。
    • User:アカウントのユーザー名に設定。
    • Password:アカウントのパスワードに設定。

    OData サービスを設定したら、カスタムクレデンシャルを使用して接続を確立できます。

    組み込みの接続文字列デザイナー

    JDBC URL の構成については、SAP HANA XS Advanced JDBC Driver に組み込まれている接続文字列デザイナーを使用してください。JAR ファイルをダブルクリックするか、コマンドラインからJAR ファイルを実行します。

    java -jar cdata.jdbc.saphanaxsa.jar
    

    接続プロパティを入力し、接続文字列をクリップボードにコピーします。

    以下のリソース定義で指定されたJDBC URL を確認できます。

    
    <Resource name="jdbc/saphanaxsa"   auth="Container" type="javax.sql.DataSource" driverClassName="cdata.jdbc.saphanaxsa.SAPHanaXSADriver" factory="org.apache.tomcat.jdbc.pool.DataSourceFactory" url="jdbc:saphanaxsa:OAuthClientID=my-ouath-client-id;OAuthClientSecret=my-oauth-client-secret;URL=https://hxehost:51027/euro.xsodata;CallbackURL=http://localhost:33333;" maxActive="20" maxIdle="10" maxWait="-1" />
    

    特定のアプリケーションのみに SAP HANA XS Advanced のデータ へのアクセスを許可するには、上記のコードをアプリケーションのMETA-INF ディレクトリにあるcontext.xml に追加します。

    共有リソースの構成の場合は、上記のコードを $CATALINA_BASE/conf にあるcontext.xml に追加します。共有リソースの構成では、すべてのアプリケーションが SAP HANA XS Advanced に接続できるようになります。

  3. アプリケーションの web.xml にリソースへの参照を追加します。
    
      SAP HANA XS Advanced のデータ JSP
      jdbc/SAPHanaXSA
      javax.sql.DataSource
      Container
    
    
  4. コネクションプールから接続を初期化します。
    Context initContext = new InitialContext();
    Context envContext  = (Context)initContext.lookup("java:/comp/env");
    DataSource ds = (DataSource)envContext.lookup("jdbc/SAPHanaXSA");
    Connection conn = ds.getConnection();
      

Tomcat との連携について

上記の手順では、シンプルなコネクションプーリングのシナリオで SAP HANA XS Advanced のデータ に接続する方法を説明しました。その他のユースケースや詳細については、Tomcat のドキュメントに記載されている JNDI Datasource How-To を参照してください。

はじめる準備はできましたか?

SAP HANA XS Advanced Driver の無料トライアルをダウンロードしてお試しください:

 ダウンロード

詳細:

SAP HANA XS Advanced Icon SAP HANA XS Advanced JDBC Driver お問い合わせ

SAP HANA XS Advanced データベースに連携するJava アプリケーションを素早く、簡単に開発できる便利なドライバー。