Tomcat のコネクションプールで CData JDBC Driver for SAP を構成
CData JDBC Driver は、JVM 上で動作するWeb アプリケーションと連携するための標準JDBC インターフェースをサポートしています。ここでは、Tomcat のコネクションプールから SAP のデータ に接続する方法を説明します。
SAP データ連携について
CData は、SAP のライブデータにアクセスし、統合するための最も簡単な方法を提供します。お客様は CData の接続機能を以下の目的で使用しています:
- SAP R/3、SAP NetWeaver、SAP ERP / ECC 6.0、RFC によって公開されている SAP S/4 HANA オンプレミスデータを含む、すべてのエディションの SAP にアクセスできます。
- SQL ストアドプロシージャを通じて、IDoc または IDoc XML ファイルのサーバーへの送信、関数やクエリ用のスキーマの作成などのアクションを実行できます。
-
お客様の SAP インスタンスがホストされている場所に応じて、最適に接続できます。
- SAP S/4HANA クラウドパブリックエディションをご利用のお客様は、SAP NetWeaver Gateway 接続を使用します
- SAP S/4HANA プライベートエディションをご利用のお客様は、SAP ERP または SAP NetWeaver Gateway 接続のいずれかを使用します。
多くのユーザーは、SAP データをデータベースやデータウェアハウスにレプリケートするために当社のツールを活用していますが、Tableau、Power BI、Excel などの分析ツールとライブ SAP データを統合しているお客様も多数います。
はじめに
Tomcat のコネクションプールから SAP のデータ に接続
- CData JAR ファイルと CData .lic ファイルを $CATALINA_HOME/lib にコピーします。CData JAR ファイルは、インストールディレクトリの lib サブフォルダにあります。
- コンテキストにリソースの定義を追加します。ここでJDBC URL を指定します。
CData 製品はSAP system にJCo JAR ファイルで接続します。Jco JAR ファイルの使い方は、ヘルプドキュメントの「はじめに」を参照してください。
また、SAP システムにSOAP Web service で接続することが可能です。SOAP アクセスには、Client、RFCUrl、User、Password の接続プロパティを入力します。
詳細情報はobtaining the connection properties を参照してください。
組み込みの接続文字列デザイナー
JDBC URL の構成については、SAP JDBC Driver に組み込まれている接続文字列デザイナーを使用してください。JAR ファイルをダブルクリックするか、コマンドラインからJAR ファイルを実行します。
java -jar cdata.jdbc.saperp.jar
接続プロパティを入力し、接続文字列をクリップボードにコピーします。
以下のリソース定義で指定されたJDBC URL を確認できます。
<Resource name="jdbc/saperp" auth="Container" type="javax.sql.DataSource" driverClassName="cdata.jdbc.saperp.SAPERPDriver" factory="org.apache.tomcat.jdbc.pool.DataSourceFactory" url="jdbc:saperp:Host=sap.mydomain.com;User=EXT90033;Password=xxx;Client=800;System Number=09;ConnectionType=Classic;Location=C:/mysapschemafolder;" maxActive="20" maxIdle="10" maxWait="-1" />
特定のアプリケーションのみに SAP のデータ へのアクセスを許可するには、上記のコードをアプリケーションのMETA-INF ディレクトリにあるcontext.xml に追加します。
共有リソースの構成の場合は、上記のコードを $CATALINA_BASE/conf にあるcontext.xml に追加します。共有リソースの構成では、すべてのアプリケーションが SAP に接続できるようになります。
- アプリケーションの web.xml にリソースへの参照を追加します。
SAP のデータ JSP jdbc/SAPERP javax.sql.DataSource Container
-
コネクションプールから接続を初期化します。
Context initContext = new InitialContext(); Context envContext = (Context)initContext.lookup("java:/comp/env"); DataSource ds = (DataSource)envContext.lookup("jdbc/SAPERP"); Connection conn = ds.getConnection();
Tomcat との連携について
上記の手順では、シンプルなコネクションプーリングのシナリオで SAP のデータ に接続する方法を説明しました。その他のユースケースや詳細については、Tomcat のドキュメントに記載されている JNDI Datasource How-To を参照してください。