ノーコードでクラウド上のデータとの連携を実現。
詳細はこちら →CData
こんにちは!ウェブ担当の加藤です。マーケ関連のデータ分析や整備もやっています。
PostgreSQL には多くの対応クライアントがあります。標準のドライバーからBI、アナリティクスツールまで、PostgreSQL はデータ接続の人気のインターフェースです。JDBC ドライバーを使用することで、簡単に任意の標準クライアントから接続できるPostgreSQL エントリポイントを作成できます。
Elasticsearch にPostgreSQL データベースとしてアクセスするには、CData JDBC Driver for Elasticsearch とJDBC foreign data wrapper (FDW) を使用します。この記事ではFDW をコンパイルしてインストールし、PostgreSQL サーバーからElasticsearch にクエリを実行します。
JDBC データソースとしてElasticsearch に接続するには、以下が必要です。
Driver クラス
cdata.jdbc.elasticsearch.ElasticsearchDriver
接続するには、Server およびPort 接続プロパティを設定します。 認証には、User とPassword プロパティ、PKI (public key infrastructure)、またはその両方を設定します。 PKI を使用するには、SSLClientCert、SSLClientCertType、SSLClientCertSubject、およびSSLClientCertPassword プロパティを設定します。
CData 製品は、認証とTLS/SSL 暗号化にX-Pack Security を使用しています。TLS/SSL で接続するには、Server 値に'https://' を接頭します。Note: PKI を 使用するためには、TLS/SSL およびクライアント認証はX-Pack 上で有効化されていなければなりません。
接続されると、X-Pack では、設定したリルムをベースにユーザー認証およびロールの許可が実施されます。
JDBC URL の構成については、Elasticsearch JDBC Driver に組み込まれている接続文字列デザイナを使用できます。JAR ファイルのダブルクリック、またはコマンドラインからJAR ファイルを実行します。
java -jar cdata.jdbc.elasticsearch.jar
接続プロパティを入力し、接続文字列をクリップボードにコピーします。
以下は一般的なJDBC URL です。
jdbc:elasticsearch:Server=127.0.0.1;Port=9200;User=admin;Password=123456;
FDW は、PostgreSQL を再コンパイルせずに、PostgreSQL の拡張機能としてインストールできます。例としてjdbc2_fdw 拡張子を使用します。
ln -s /usr/lib/jvm/java-6-openjdk/jre/lib/amd64/server/libjvm.so /usr/lib/libjvm.so
make install USE_PGXS=1
拡張機能をインストールした後、以下のステップに従ってElasticsearch へのクエリの実行を開始します。
CREATE EXTENSION jdbc2_fdw;
CREATE SERVER Elasticsearch
FOREIGN DATA WRAPPER jdbc2_fdw OPTIONS (
drivername 'cdata.jdbc.elasticsearch.ElasticsearchDriver',
url 'jdbc:elasticsearch:Server=127.0.0.1;Port=9200;User=admin;Password=123456;',
querytimeout '15',
jarfile '/home/MyUser/CData/CData\ JDBC\ Driver\ for\ Salesforce MyDriverEdition/lib/cdata.jdbc.elasticsearch.jar');
CREATE USER MAPPING for postgres SERVER Elasticsearch OPTIONS (
username 'admin',
password 'test');
postgres=# CREATE FOREIGN TABLE orders (
orders_id text,
orders_OrderName text,
orders_Freight numeric)
SERVER Elasticsearch OPTIONS (
table_name 'orders');
postgres=# SELECT * FROM orders;
このようにCData JDBC Driver for Elasticsearch を使って簡単にElasticsearch データを取得して検索対象にすることができました。ぜひ、30日の無償評価版 をお試しください。