Mule アプリケーションからCouchDB のデータにアクセス:CData JDBC Driver

古川えりか
古川えりか
コンテンツスペシャリスト
CData JDBC ドライバとHTTP、SQL を組み合わせれば、CouchDB のデータのJSON エンドポイントに接続できるMule アプリケーションを簡単に作成できます。

CData JDBC Driver for ApacheCouchDB はCouchDB のデータをMule アプリケーションと連携することで、読み、書き、更新、削除といった機能をおなじみのSQL クエリを使って実現します。JDBC ドライバーを使えば、CouchDB のデータをバックアップ、変換、レポート作成、分析するMule アプリケーションをユーザーは簡単に作成できます。

本記事では、Mule プロジェクト内でCData JDBC Driver for ApacheCouchDB を使用して、CouchDB のデータのWeb インターフェースを作成する方法を紹介します。作成したアプリケーションを使えば、HTTP 経由でCouchDB のデータをリクエストして、JSON 形式で結果を取得できます。まったく同様の手順で、すべてのCData JDBC ドライバで250 を超えるデータソースのWeb インターフェースを作成できます。手順は以下のとおりです。

  1. Anypoint Studio で新しいMule プロジェクトを作る。
  2. Message Flow にHTTP コネクタを追加する。
  3. HTTP コネクタのアドレスを設定する。 HTTP コネクタを追加・設定
  4. HTTP コネクタの追加後、Database Select コネクタを同じフローに追加する。
  5. データベースへの新しい接続を作成し(または既存の接続を編集し)、プロパティを設定する。
    • 接続を「Generic Connection」に設定
    • Required Libraries セクションでCData JDBC ドライバのJAR ファイルを指定する(例:cdata.jdbc.apachecouchdb.jar)。 JAR ファイルを追加(Salesforce の場合)。
    • CouchDB の接続文字列にURL を指定

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

      それでは、Apache CouchDB に接続していきましょう。Url 接続プロパティをApache CouchDB インスタンスのURL に設定します。例:http://localhost:5984

      ユーザー(またはJWT)が特定のデータベースだけにアクセスできるようにしたい場合は、Apache CouchDB インスタンスで"admin_only_all_dbs" オプションを設定し、テーブルをリストするためにCData 製品が必要とする"/_all_dbs" エンドポイントへのアクセス権をすべてのユーザーに付与する必要があります。

      Apache CouchDB への認証

      続いて、認証方法を設定しましょう。CData 製品では、3種類の認証をサポートしています。

      • Basic:基本的なユーザー名 / パスワード認証
      • JWT:JWT 認証
      • None:パブリックなデータベースへの匿名アクセス

      Basic 認証

      データに接続するには、以下のプロパティを設定してください。

      • AuthSchemeBasic
      • User:認証に使用されるApache CouchDB ユーザーアカウント
      • Password:認証するユーザーに関連付けられたApache CouchDB パスワード

      その他の認証方法については、ヘルプドキュメントの「接続の確立」セクションをご確認ください。

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

      JDBC 用のURL の作成にサポートが必要な場合は、CouchDB JDBC Driver に組み込まれた接続文字列デザイナを使用できます。JAR ファイルをダブルクリックするか、コマンドラインからJAR ファイルを実行してください。

      		java -jar cdata.jdbc.apachecouchdb.jar
      		

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

    • Driver クラス名をcdata.jdbc.apachecouchdb.ApacheCouchDBDriver に指定します。 設定したデータベース接続(Salesforce の場合)。
    • 「接続テスト」をクリックします。
  6. SQL Query Text をCouchDB のデータをリクエストするためのSQL クエリに設定します。例えば、
    SELECT MovieRuntime, MovieRating FROM Movies WHERE MovieRating = 'R'
    Select オブジェクトを設定(Salesforce の場合)
  7. Transform Message コンポーネントをフローに追加します。
  8. Output スクリプトを次のように設定して、ペイロードをJSON に変換します。
    %dw 2.0
    output application/json
    ---
    payload
            
    Transform Message コンポーネントをフローに追加
  9. CouchDB のデータを閲覧するには、HTTP コネクタ用に設定したアドレスに移動します(デフォルトでは、localhost:8081):http://localhost:8081。Web ブラウザおよびJSON エンドポイントを使用可能な他のツール内で、CouchDB のデータをJSON として利用できます。

これで、カスタムアプリケーションおよび他のさまざまなBI、帳票、ETL ツールからCouchDB のデータを(JSON データとして)扱うための簡易なWeb インターフェースを作成できました。Mule アプリケーションからお好みのデータソースにアクセスできる、JDBC Driver for ApacheCouchDB の30日の無償評価版のダウンロードはこちらから。

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

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

 ダウンロード

詳細:

CouchDB Icon CouchDB JDBC Driver お問い合わせ

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