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

Jerod Johnson
Jerod Johnson
Director, Technology Evangelism
Tomcat のコネクションプールから Coinbase のデータ に接続。

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

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

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

    まず、Profile 接続プロパティをディスク上のCoinbase プロファイルの場所に設定します(例:C:\profiles\Coinbase.apip)。次に、ProfileSettings 接続プロパティをCoinbase の接続文字列に設定します(以下を参照)。

    Coinbase API プロファイル設定

    Coinbase はOAuth ベースの認証を使用します。

    まず、Coinbase でOAuth アプリを登録する必要があります。これはアカウントの「Settings」>「API Access」>「New OAuth2 Application」から行えます。

    以下の接続プロパティを設定すると、接続できるようになります。

    • AuthScheme:OAuth に設定します。
    • InitiateOAuth:GETANDREFRESH に設定します。InitiateOAuth を使用して、OAuthAccessToken を取得するプロセスを管理できます。
    • OAuthClientId:アプリ設定で指定されたClientID に設定します。
    • OAuthClientSecret:アプリ設定で指定されたClientSecret に設定します。
    • CallbackURL:アプリ設定で指定したRedirect URI に設定します。

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

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

    java -jar cdata.jdbc.api.jar
    

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

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

    
    <Resource name="jdbc/api"   auth="Container" type="javax.sql.DataSource" driverClassName="cdata.jdbc.api.APIDriver" factory="org.apache.tomcat.jdbc.pool.DataSourceFactory" url="jdbc:api:Profile=C:\profiles\Coinbase.apip;Authscheme=OAuth;OAuthClientId=your_client_id;OAuthClientSecret=your_client_secret;CallbackUrl=your_callback_url;" maxActive="20" maxIdle="10" maxWait="-1" />
    

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

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

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

Tomcat との連携について

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

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

API Driver で Coinbase のライブデータに接続

Coinbase に接続 お問い合わせ