Looker には、少なくとも MongoDB バージョン 4.0 以降と BI 用のMongoDB コネクタ バージョン 2.6.0 以降(
type_conversion_mode
セッション変数が導入されている)が必要です。
Looker は、次の 2 つのオプションを使用して BI 用の MongoDB コネクタを使用して MongoDB にアクセスできます。
- MongoDB Atlas で BI 用の MongoDB コネクタを使用する。
- MongoDB データベースと同じサーバーにインストールされた、BI 用の MongoDB コネクタを使用する。
MongoDB Atlas
MongoDB Atlas では、M10 以上のクラスタを使用する必要があります。Looker で、MongoDB Atlas で実行する MongoDB データベースを使用するには、BI 用のMongoDB コネクタ(MongoBI)を使用する必要があります。Atlas 向けの BI コネクタを有効にするには、MongoDB Atlas で M10 以上のクラスタを使用する必要があります。
また、目的のデータベースに対する読み取り権限を持つユーザー アカウントも作成する必要があります。
BI 用のMongoDB コネクタの構成
Looker で接続を作成する前に、MongoDB または Atlas 管理者は、このページで説明している以下の手順に沿って BI 用のMongoDB コネクタを設定する必要があります。
Looker サーバーの Atlas IP アクセスリストへの追加
Atlas では、プロジェクトの IP アクセスリストのエントリからのクライアント接続のみが許可されます。Looker の IP アドレスを Atlas プロジェクトの IP アクセスリストに追加します。
- Looker の IP アドレスを取得します。
- Atlas IP アクセスリストの設定の手順に沿って、Looker の IP アドレスを Atlas IP アクセスリストに追加します。
BI 用の MongoDB コネクタを有効にする
BI 用の MongoDB コネクタを有効にします。
- M10 以上のクラスタを使用していることを確認します。
- Atlas でクラスタの [接続] ページを開きます。ホスト名、ポート、ユーザーをメモしておきます。この情報は、Looker で接続を構成するときに使用する必要があります。
同じサーバー上の MongoDB
Looker で接続を作成する前に、MongoDB 管理者はこのページに記載されている次の手順の沿って、MongoDB と BI 用の Mongo コネクタを設定する必要があります。
BI 用の Mongo コネクタのインストール
MongoDB ドキュメント ページのオンプレミスでBI コネクタをインストールするに沿って、MongoDB データベースと同じサーバーに BI 用の MongoDB コネクタをインストールします。
ネットワークトラフィックの暗号化
BI 用の MongoDB コネクタでは、MongoDB のサーバーと Looker アプリケーションの間で SSL 暗号化を使用する必要があります。MongoDB ドキュメント ページのBI コネクタ用の SSL の構成にある SSL 設定手順に従います。
Looker のユーザーと権限の設定
MongoDB シェルで use
コマンドを入力し、Looker が接続するデータベースに切り替えます。次に、ロール readWrite
で db.createUser()
を使って Looker のユーザーを作成します。
use looker_database
db.createUser({ user: looker,
pwd: `some_password_here`,
roles: [ "readWrite" ]
})
MongoBI JDBC ドライバ ファイルのインストール
BI 用の MongoDB コネクタのオプションのどちらの場合でも、Lookerでは以下の手順で JDBC ドライバ ファイルを構成する必要があります。
次の 2 つの JAR ファイルをダウンロードします。
パッケージ化されていない JDBC ドライバのドキュメント ページの手順に沿って、次の値を使用します。
ドライバ シンボル: mongobi
ドライバ エントリ:
- name: mongobi
dir_name: mongobi
module_path: com.mysql.jdbc.Driver
override_jdbc_url_subprotocol: mysql
Looker 6.2 以前を使用している場合:
- name: maria15x
dir_name: mongobi
module_path: com.mysql.jdbc.Driver
override_jdbc_url_subprotocol: mysql
ドライバを言語のディレクトリに配置する手順の場合、これらのファイルへのパスは次のようになります。looker/custom_jdbc_drivers/mongobi/mongosql-auth-1.0.0-rc0.jar
looker/custom_jdbc_drivers/mongobi/mysql-connector-java-5.1.47.jar
標準派生テーブルの使用の許可(推奨)
派生テーブルは分析の洗練度を高めることができるLookerの重要なツールです。クエリのパフォーマンスを向上させる重要な役割を担う可能性もあります。簡単に説明すると、Lookerの派生テーブル機能はデータベース内にまだ存在しない新たなテーブルを作成するための手段です。
BI 用の MongoDB コネクタは、一時的な標準派生テーブルをサポートしていますが、永続的な派生テーブルはまだサポートしていません。
標準派生テーブルは一時的なものであるため、保存する必要はありません。したがって、標準派生テーブルのスキーマを作成する必要はありません。ただし、スキーマが存在しない場合でも、looker_tmp
スキーマに dbOwner
ロールを付与する必要があります。
この MongoDB ドキュメント ページの [MongoDB ユーザーの変更] セクションに沿って、Looker が接続に使用するユーザーの looker_tmp
に dbOwner
ロールを追加します。
db.grantRolesToUser("looker", [ {role: "dbOwner", db: "looker_tmp"} ])
データベースへの Looker 接続の作成
Looker の [管理者] セクションで [接続] を選択し、[新しい接続] をクリックします。
接続の詳細を入力します。設定の大部分は、ほとんどのデータベース言語に共通するものです。詳細については、Looker をデータベースに接続するのドキュメント ページをご覧ください。
接続が成功したことを確認するには、[テスト] をクリックします。トラブルシューティング情報については、データベース接続のテストのドキュメント ページをご覧ください。
これらの設定を保存するには、[接続] をクリックします。
BI 用の MongoDB コネクタでの SQL 関数と演算子の使用
BI 接続で MongoDB コネクタを使用して開発する場合は、こちらの MongoDB ドキュメント ページに記載されている SQL 関数と演算子を使用できます。
機能のサポート
一部の機能については、Looker でサポートするには、データベース言語が同じ機能に対応している必要があります。
MongoBI は、Looker 23.8 の時点で、次の機能をサポートしています。
特徴 | サポート対象 |
---|---|
サポート レベル | サポート対象 |
Looker(Google Cloud コア) | いいえ |
対称集計 | いいえ |
派生テーブル | あり |
永続的な SQL 派生テーブル | いいえ |
永続的なネイティブ派生テーブル | いいえ |
安定したビュー | いいえ |
クエリの強制終了 | はい |
SQL ベースのピボット | いいえ |
タイムゾーン | いいえ |
SSL | あり |
Subtotals | いいえ |
JDBC の追加パラメータ | あり |
Case Sensitive | あり |
ロケーション タイプ | あり |
リストのタイプ | いいえ |
パーセンタイル | いいえ |
個別のパーセンタイル | いいえ |
SQL Runner の表示プロセス | あり |
SQL Runner の説明テーブル | あり |
SQL Runner 表示インデックス | あり |
SQL Runner Select 10 | あり |
SQL ランナーの数 | あり |
SQL の説明 | あり |
Oauth 認証情報 | いいえ |
コンテキスト コメント | あり |
接続プーリング | いいえ |
HLL スケッチ | いいえ |
集計認識 | いいえ |
増分PDT | いいえ |
ミリ秒 | いいえ |
マイクロ秒 | いいえ |
マテリアライズド ビュー | いいえ |
Approximate Count Distinct | いいえ |
次の特長があります。
- MongoDB では、ディメンション グループのmillisecondとmicrosecondのタイムフレームはサポートされていません。
- MongoDB では、ディメンションのmillisecond、millisecondX、microsecondのタイプはサポートされていません。
- Looker は、MongoBI からアクセスされたすべてのタイムスタンプを、協定世界時(UTC)のタイムゾーンとして扱います。