エンタープライズサーチのNeuron にAzure DevOps データを取り込んで検索利用
企業内検索エンジンサービスの Neuron にAzure DevOps のデータを取り込んで検索する方法:CData JDBC Driver。
杉本和也
リードエンジニア
最終更新日:2021-03-01
CData
こんにちは!リードエンジニアの杉本です。
ブレインズテクノロジー社のNeuron は、先端OSS 技術(Apache Solr)を活用したエンタープライズサーチ(企業内検索エンジン)サービスです。Apache Solr は、エンタープライズサーチ機能をAPI として提供してくれますが、Neuron はApache Solr に企業ユーザーがデータを探索するためのシンプルかつ使いやすいユーザーインターフェースと管理画面・運用機能を提供してくれます。これによりエンドユーザーが簡単にエンタープライズサーチを利用することができます。管理画面では、ファイルやデータのクローリング設定がUI で行えるようになっています。この記事では、Neuron に備わっているJDBC インターフェース経由で、CData JDBC Driver for AzureDevOps を利用することでNeuron にAzure DevOps データを取り込んで検索で利用できるようにします。
Neuron にCData JDBC Driver for AzureDevOps データをロード
CData JDBC Driver for AzureDevOps のインストールと.jar ファイルの配置
- CData JDBC Driver for AzureDevOps をNeuron と同じマシンにインストールします。
-
以下のパスにJDBC Driver がインストールされます。
C:\Program Files\CData\CData JDBC Driver for AzureDevOps 20xxJ\lib\cdata.jdbc.azuredevops.jar
-
このcdata.jdbc.azuredevops.jar とcdata.jdbc.azuredevops.lic ファイルをコピーして、Neuron のC:\APP
cf\lib フォルダに配置します。
Neuron CF でのAzure DevOps データを扱うリポジトリの作成
-
Neuron CF でクローラーの設定をGUI で行います。JDBC を読み取るためのリポジトリを作成します。Neuron の管理画面にログインし、[リポジトリ]→[リポジトリコレクション一覧]→[新規]をクリックします。
-
任意のリポジトリ名を入力します。タイプは[JDBC]を選択します。
-
次に、ドライバーのクラス名とJDBC 接続文字列でAzure DevOps への接続を行います。
AzureDevOps 接続プロパティの取得・設定方法
Azure DevOps アカウントに接続するには、Profile -> Organizations に移動して、アカウント内の組織名であるOrganization を指定します。
例: Organization=MyAzureDevOpsOrganization
NOTE :Analytics スキーマに接続する場合は、Organization と一緒にProjectId を指定する必要があります。
Azure DevOps への認証
Basic
Organization とPersonalAccessToken を指定することで、Azure DevOps アカウントに接続できます。
パーソナルアクセストークンを生成するには、Azure DevOps Organization アカウントにログインし、Profile -> Personal Access Tokens
-> New Token に移動します。生成されたトークンが表示されます。
Azure AD
Azure ADは、OAuth を利用して認証する接続形式です。OAuth は、認証ユーザーがインターネットブラウザを使用してAzure DevOps と通信することを要求します。
CData 製品は、いくつかの方法でこれをサポートします。AuthScheme をAzureAD に設定し、Organization をAzure
DevOps の組織名に設定します。
詳しくは、ヘルプドキュメント の「Azure DevOps
への認証」セクションを参照してください。
ドライバクラス名:cdata.jdbc.azuredevops.AzureDevOpsDriver
接続文字列:jdbc:azuredevops:AuthScheme=Basic;Organization=MyAzureDevOpsOrganization;ProjectId=MyProjectId;PersonalAccessToken=MyPAT;InitiateOAuth=REFRESH
-
[更新]をクリックして、Azure DevOps に接続するリポジトリコレクションができました。
Neuron でAzure DevOps のデータをクローリングするジョブを作成
続いて、Azure DevOps のどのデータをどのようにクローリングするのかをジョブで定義していきます。
-
管理画面で[ジョブ]→[ジョブ一覧]→[新規]とクリックします。
-
任意のジョブ名を入力します。出力先にはSolr を選択します。リポジトリは先ほど作成したAzure DevOps に接続するリポジトリコレクションを選びます。
-
次に基本タブからジョブ実行を手動にするか、定期実行するかを自由に設定します。
-
SQL タブでは、どんなデータを取得するのか、テーブル名やカラム、フィルタリング条件などを設定できます。CData JDBC ドライバがAzure DevOps データをテーブルにモデル化しているので、標準SQL でAzure DevOps をクエリすることができます。
-
SQL文:SELECT Id, BuildNumber FROM Builds
-
キーカラム:Id など取得テーブルのキーとなるカラム
-
検索対象カラム:検索の対象とするカラム
-
タイトルカラム:検索結果のタイトルとするカラム
-
タイムスタンプカラム:タイムスタンプとなるカラムがあれば、ここで指定します
-
リクエストパラメータでは、検索結果レコードのURL (があれば)を設定することもできます。URL を表示できると表示された検索結果からレコードに簡単に移動できます。
-
取得元では、ラベルを設定しておきます。[更新]をクリックして、クローラージョブの設定を完了します。
Neuron でAzure DevOps データをクロールするジョブを実行
実際にNeuron で作成したジョブを実行します。[ジョブ]→[状態とジョブ管理]をクリックし、作成したジョブの[Start]をクリックします。
ジョブが正常完了すると、[Done]がステータスとして表示されます。
Neuron 上でのAzure DevOps データの検索の実施
実際にNeuron 上で検索ができるか確認してみます。取得元を絞り込むこと、内容やファイル名での検索、ファイルサイズやファイル更新日の絞り込み、部分一致や全部一致で検索が可能です。
検索をかけてみると、以下のようにデータを取得できました。
CData JDBC Driver for AzureDevOps をNeuron で使うことで、Azure DevOps コネクタとして機能し、簡単にデータを取得して同期することができました。ぜひ、30日の無償評価版をお試しください。
関連コンテンツ