Tomcat のコネクションプールで CData JDBC Driver for Active Directory を構成

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

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

Tomcat のコネクションプールから Active Directory のデータ に接続

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

    ActiveDirectory 接続プロパティの取得・設定方法

    接続には以下の情報が必要です。

    • 有効なユーザーおよびパスワード情報 (例:Domain\BobF or cn=Bob F,ou=Employees,dc=Domain)。
    • 接続するサーバーのIP、ホスト名、ポートを含むサーバー情報。
    • BaseDN: 指定されたname にLDAP 検索の範囲を制限します。

      ちなみに、BaseDN を狭い範囲に設定することで大幅にパフォーマンスを改善できます。例えば、cn=users,dc=domain は、cn=users およびその子の範囲に戻り値の結果を制限します。

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

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

    java -jar cdata.jdbc.activedirectory.jar
    

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

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

    
    <Resource name="jdbc/activedirectory"   auth="Container" type="javax.sql.DataSource" driverClassName="cdata.jdbc.activedirectory.ActiveDirectoryDriver" factory="org.apache.tomcat.jdbc.pool.DataSourceFactory" url="jdbc:activedirectory:User=cn=Bob F,ou=Employees,dc=Domain;Password=bob123;Server=10.0.1.2;Port=389;" maxActive="20" maxIdle="10" maxWait="-1" />
    

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

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

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

Tomcat との連携について

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

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

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

 ダウンロード

詳細:

Active Directory Icon Active Directory JDBC Driver お問い合わせ

Active Directory ユーザー、グループ、ロール、連絡先などを組み込んだパワフルなJava アプリケーションを短時間・低コストで作成して配布できます。