Jetty の接続プールから Google Cloud Storage のデータ に接続

Jerod Johnson
Jerod Johnson
Senior Technology Evangelist
Google Cloud Storage JDBC Driver は接続プールをサポートしています。この記事では、Jetty の Web アプリから Google Cloud Storage のデータ に高速に接続する方法を説明します。

CData JDBC Driver for Google Cloud Storage は、Java Web アプリケーションへの統合が簡単です。この記事では、接続プールを設定することで Jetty から Google Cloud Storage のデータ に効率的に接続する方法を説明します。Jetty で Google Cloud Storage 用の JNDI リソースを設定していきましょう。

Salesforce 用の JDBC Driver を JNDI データソースとして設定

以下のステップで Jetty から Salesforce に接続します。

  1. Jetty ベースで JNDI モジュールを有効にします。次のコマンドは、コマンドラインから JNDI を有効にします。

    java -jar ../start.jar --add-to-startd=jndi
    
  2. インストールディレクトリの lib サブフォルダにある CData およびライセンスファイルを、コンテキストパスの lib サブフォルダに追加します。
  3. リソースとそのスコープを宣言します。リソース宣言に必要な接続プロパティを入力します。次の例では、WEB-INF\jetty-env.xml に Web アプリレベルで Google Cloud Storage データソースを宣言しています。

    
    <Configure id='googlecloudstoragedemo' class="org.eclipse.jetty.webapp.WebAppContext">
        <New id="googlecloudstoragedemo" class="org.eclipse.jetty.plus.jndi.Resource">
        <Arg><Ref refid="googlecloudstoragedemo"/></Arg>
        <Arg>jdbc/googlecloudstoragedb</Arg>
        <Arg>
          <New class="cdata.jdbc.googlecloudstorage.GoogleCloudStorageDriver">
            <Set name="url">jdbc:googlecloudstorage:</Set>
            <Set name="ProjectId">'project1'</Set>
          </New>
        </Arg>
      </New>
    </Configure>
    

    ユーザーアカウントでの認証

    ユーザー資格情報の接続プロパティを設定することなく接続できます。InitiateOAuth をGETANDREFRESH に設定したら、接続の準備が完了です。

    接続すると、Google Cloud Storage OAuth エンドポイントがデフォルトブラウザで開きます。ログインして権限を付与すると、OAuth プロセスが完了します。

    サービスアカウントでの認証

    サービスアカウントには、ブラウザでユーザー認証を行わないサイレント認証があります。サービスアカウントを使用して、企業全体のアクセススコープを委任することもできます。

    このフローでは、OAuth アプリケーションを作成する必要があります。詳しくは、ヘルプドキュメントを参照してください。以下の接続プロパティを設定したら、接続の準備が完了です:

    • InitiateOAuth: GETANDREFRESH に設定。
    • OAuthJWTCertType: PFXFILE に設定。
    • OAuthJWTCert: 生成した.p12 ファイルへのパスに設定。
    • OAuthJWTCertPassword: .p12 ファイルのパスワードに設定。
    • OAuthJWTCertSubject: 証明書ストアの最初の証明書が選ばれるように"*" に設定。
    • OAuthJWTIssuer: 「サービスアカウント」セクションで「サービスアカウントの管理」をクリックし、このフィールドをサービスアカウントID フィールドに表示されているE メールアドレスに設定。
    • OAuthJWTSubject: サブジェクトタイプが"enterprise" に設定されている場合はエンタープライズID に設定し、"user" に設定されている場合はアプリユーザーID に設定。
    • ProjectId: 接続するプロジェクトのID に設定。

    これで、サービスアカウントのOAuth フローが完了します。

  4. Web.xml でリソースを設定します。

    
      jdbc/googlecloudstoragedb
      javax.sql.DataSource
      Container
    
    
  5. これで、java:comp/env/jdbc/googlecloudstoragedb をルックアップして Google Cloud Storage にアクセスできます。

    InitialContext ctx = new InitialContext();
    DataSource mygooglecloudstorage = (DataSource)ctx.lookup("java:comp/env/jdbc/googlecloudstoragedb");
    

Jetty 統合の詳細

上記のステップでは、シンプルな接続プールのシナリオでドライバーを設定する方法を説明しました。その他のユースケースや詳細については、Jetty ドキュメントのWorking with Jetty JNDI の章を参照してください。

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

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

 ダウンロード

詳細:

Google Cloud Storage Icon Google Cloud Storage JDBC Driver お問い合わせ

Google Cloud Storage データを組み込んだパワフルなJava アプリケーションを短時間・低コストで作成して配布できます。