Jetty コネクションプールからAzure Data Lake Storage データに連携。

詳細情報をご希望ですか?

無償トライアル:

ダウンロードへ

製品の詳細情報へ:

Azure Data Lake Storage JDBC Driver

Azure Data Lake Storage データに連携するJava アプリケーションを素早く、簡単に開発できる便利なドライバー。



CData JDBC Driver for Azure Data Lake Storage は、コネクションプーリングをサポートします:本記事では、Jetty のWeb アプリからAzure Data Lake Storage データに連携する手順を説明します。

CData JDBC driver for Azure Data Lake Storage は、Java Web アプリケーションに簡単に統合して利用することができます。本記事では、Jetty でドライバーをコネクションプールとして設定することで、効率的にAzure Data Lake Storage データをアプリケーションで連携利用する方法を説明します。Jetty でJNDI resource for Azure Data Lake Storage を設定します。

DBC Driver for Azure Data Lake Storage を JNDI Data Source として設定

次の手順で、Jetty とAzure Data Lake Storage の接続を確立します。

  1. Jetty ベースでJNDI モジュールを有効化します。JNDI を有効化するコマンドラインは以下の通り:

    java -jar ../start.jar --add-to-startd=jndi
  2. JDBC Driver の.jar ファイルと.lic ファイル(インストールディレクトリのlib フォルダ下)をcontext path のlib フォルダに配置します。
  3. リソースおよびスコープを宣言します。リソース宣言で必要な接続プロパティを入力します。この例では、Azure Data Lake Storage データソースをWeb アプリケーションのWEB-INF\jetty-env.xml レベルにdeclare しています。

    <Configure id='azuredatalakedemo' class="org.eclipse.jetty.webapp.WebAppContext"> <New id="azuredatalakedemo" class="org.eclipse.jetty.plus.jndi.Resource"> <Arg><Ref refid="azuredatalakedemo"/></Arg> <Arg>jdbc/azuredatalakedb</Arg> <Arg> <New class="cdata.jdbc.adls.ADLSDriver"> <Set name="url">jdbc:adls:</Set> <Set name="Schema">ADLSGen2</Set> <Set name="Account">myAccount</Set> <Set name="FileSystem">myFileSystem</Set> <Set name="AccessKey">myAccessKey</Set> </New> </Arg> </New> </Configure>

    Authenticating to a Gen 1 DataLakeStore Account

    Gen 1 uses OAuth 2.0 in Azure AD for authentication.

    For this, an Active Directory web application is required. You can create one as follows:

    1. Sign in to your Azure Account through the .
    2. Select "Azure Active Directory".
    3. Select "App registrations".
    4. Select "New application registration".
    5. Provide a name and URL for the application. Select Web app for the type of application you want to create.
    6. Select "Required permissions" and change the required permissions for this app. At a minimum, "Azure Data Lake" and "Windows Azure Service Management API" are required.
    7. Select "Key" and generate a new key. Add a description, a duration, and take note of the generated key. You won't be able to see it again.

    To authenticate against a Gen 1 DataLakeStore account, the following properties are required:

    • Schema: Set this to ADLSGen1.
    • Account: Set this to the name of the account.
    • OAuthClientId: Set this to the application Id of the app you created.
    • OAuthClientSecret: Set this to the key generated for the app you created.
    • TenantId: Set this to the tenant Id. See the property for more information on how to acquire this.
    • Directory: Set this to the path which will be used to store the replicated file. If not specified, the root directory will be used.

    Authenticating to a Gen 2 DataLakeStore Account

    To authenticate against a Gen 2 DataLakeStore account, the following properties are required:

    • Schema: Set this to ADLSGen2.
    • Account: Set this to the name of the account.
    • FileSystem: Set this to the file system which will be used for this account.
    • AccessKey: Set this to the access key which will be used to authenticate the calls to the API. See the property for more information on how to acquire this.
    • Directory: Set this to the path which will be used to store the replicated file. If not specified, the root directory will be used.
  4. Web xml でリソースを設定します:

    jdbc/azuredatalakedb javax.sql.DataSource Container
  5. これで、java:comp/env/jdbc/azuredatalakedb へのルックアップでAzure Data Lake Storage データにアクセスできます: InitialContext ctx = new InitialContext(); DataSource myazuredatalake = (DataSource)ctx.lookup("java:comp/env/jdbc/azuredatalakedb");

Jetty にさらに統合

ここでは、シンプルなコネクションプーリングシナリオでのドライバーの接続について説明しました。追加での連携ケースについては、Jetty ドキュメントのWorking with Jetty JNDI  参照してください。