Tomcat のコネクションプールで CData JDBC Driver for ServiceNow を構成
CData JDBC Driver は、JVM 上で動作するWeb アプリケーションと連携するための標準JDBC インターフェースをサポートしています。ここでは、Tomcat のコネクションプールから ServiceNow のデータ に接続する方法を説明します。
ServiceNow データ連携について
CData は、ServiceNow のライブデータへのアクセスと統合を簡素化します。お客様は CData の接続機能を以下の目的で活用しています:
- CData はデータには REST API を、スキーマには SOAP API を使用するため、最適化されたパフォーマンスを実現できます。
- Schedules、Timelines、Questions、Syslogs などの ServiceNow オブジェクトの読み取り、書き込み、更新、削除ができます。
- SQL ストアドプロシージャを使用して、カートへのアイテム追加、注文の送信、添付ファイルのダウンロードなどのアクションを実行できます。
- Basic(ユーザー名とパスワード)、OKTA、ADFS、OneLogin、PingFederate 認証スキームを含め、ServiceNow に安全に認証できます。
多くのユーザーは、Tableau、Power BI、Excel などのお気に入りの分析ツールからライブ ServiceNow データにアクセスし、CData ソリューションを使用して ServiceNow データをデータベースやデータウェアハウスに統合しています。
はじめに
Tomcat のコネクションプールから ServiceNow のデータ に接続
- CData JAR ファイルと CData .lic ファイルを $CATALINA_HOME/lib にコピーします。CData JAR ファイルは、インストールディレクトリの lib サブフォルダにあります。
- コンテキストにリソースの定義を追加します。ここでJDBC URL を指定します。
ServiceNow はOAuth 2.0 認証標準を利用しています。OAuth を使って認証するには、ServiceNow にOAuth アプリを登録してOAuthClientId を取得しなければなりません。OAuth 値の他に、Instance、User、およびPassword の指定が必要です。
OAuth 認証を介した接続について詳しくは、ヘルプドキュメントの「OAuth 認証の使用」を参照してください。
組み込みの接続文字列デザイナー
JDBC URL の構成については、ServiceNow JDBC Driver に組み込まれている接続文字列デザイナーを使用してください。JAR ファイルをダブルクリックするか、コマンドラインからJAR ファイルを実行します。
java -jar cdata.jdbc.servicenow.jar
接続プロパティを入力し、接続文字列をクリップボードにコピーします。
以下のリソース定義で指定されたJDBC URL を確認できます。
<Resource name="jdbc/servicenow" auth="Container" type="javax.sql.DataSource" driverClassName="cdata.jdbc.servicenow.ServiceNowDriver" factory="org.apache.tomcat.jdbc.pool.DataSourceFactory" url="jdbc:servicenow:OAuthClientId=MyOAuthClientId;OAuthClientSecret=MyOAuthClientSecret;Username=MyUsername;Password=MyPassword;Instance=MyInstance;" maxActive="20" maxIdle="10" maxWait="-1" />
特定のアプリケーションのみに ServiceNow のデータ へのアクセスを許可するには、上記のコードをアプリケーションのMETA-INF ディレクトリにあるcontext.xml に追加します。
共有リソースの構成の場合は、上記のコードを $CATALINA_BASE/conf にあるcontext.xml に追加します。共有リソースの構成では、すべてのアプリケーションが ServiceNow に接続できるようになります。
- アプリケーションの web.xml にリソースへの参照を追加します。
ServiceNow のデータ JSP jdbc/ServiceNow javax.sql.DataSource Container
-
コネクションプールから接続を初期化します。
Context initContext = new InitialContext(); Context envContext = (Context)initContext.lookup("java:/comp/env"); DataSource ds = (DataSource)envContext.lookup("jdbc/ServiceNow"); Connection conn = ds.getConnection();
Tomcat との連携について
上記の手順では、シンプルなコネクションプーリングのシナリオで ServiceNow のデータ に接続する方法を説明しました。その他のユースケースや詳細については、Tomcat のドキュメントに記載されている JNDI Datasource How-To を参照してください。