Doris カタログ
この機能はバージョン4.0.2以降でサポートされています。
これは実験的な機能です。
使用例
複数のDorisクラスター間でクロスクラスター連合分析を実行します。
JDBC カタログを通じて他のDorisクラスターに接続する方法とは異なり、このソリューションはArrow FlightまたはVirtual クラスターモードを通じて複数のDorisクラスター間で効率的な連合分析を可能にします。
カタログの設定
構文
CREATE CATALOG [IF NOT EXISTS] catalog_name PROPERTIES (
'type' = 'doris', -- required
'fe_http_hosts' = 'http://<fe-host1>:<fe-http-port>,<fe-host2>:<fe-http-port>', -- required
'fe_arrow_hosts' = '<fe-host1>:<fe-arrow-flight-port>,<fe-host2>:<fe-arrow-flight-port>', -- required
'fe_thrift_hosts' = '<fe-host1>:<fe-thrift-port>,<fe-host2>:<fe-thrift-port>', -- required
'use_arrow_flight' = 'true/false', -- required
'user' = '', -- required
'password' = '', -- required
{QueryProperties},
{HttpClientProperties},
{CommonProperties}
);
-
fe_http_hostsリモートDorisクラスターのFE HTTPサービスエンドポイントのリスト。
-
fe_arrow_hostsリモートDorisクラスターのFE Arrow Flightサービスエンドポイントのリスト。
-
fe_thrift_hostsリモートDorisクラスターのFE Thriftサービスエンドポイントのリスト。
バージョン4.0.2では、Master FEアドレスを入力してください。この問題は今後のバージョンで修正される予定です。
-
use_arrow_flightArrow Flight経由でリモートDorisクラスターにアクセスするか、リモートテーブルを内部テーブルかのように実行計画をリモートDorisクラスターに送信するかを指定します。
-
{QueryProperties}オプションのプロパティ。
パラメータ名 説明 デフォルト enable_parallel_result_sink有効にすると、ローカルDoris BEノードは、リモートDorisクラスターの様々なBEノードから並列でデータを取得します。(Arrow Flightモード用) true query_retry_countリモートDorisに送信された失敗したクエリリクエストの最大リトライ回数。(リクエスト受理後の非同期実行中に発生する可能性がある失敗は含まれません) 3 query_timeout_secリモートDorisへのクエリ送信タイムアウト。(リクエスト受理後の非同期実行時間は含まれません) 15 compatibleローカルクラスターより低いバージョンのリモートDorisにアクセスする際にメタデータフォーマットとの互換性を試行するために使用されます。クラスターバージョンが一致している場合は有効にする必要はありません。 false -
{HttpClientProperties}HttpClientPropertiesセクションは、HTTP Client関連のパラメータを設定するために使用されます。このクライアントは、リモートクラスターからメタデータを同期するためのHTTPリクエストを送信するために使用されます。これらはすべてオプションのパラメータです。
パラメータ名 説明 デフォルト metadata_http_ssl_enabledHTTPメタデータ同期でSSL/TLS暗号化通信を有効にするかどうか。 false metadata_sync_retry_count失敗したHTTPリクエストの最大リトライ回数。 3 metadata_max_idle_connectionsHTTPメタデータ同期クライアントのアイドル接続最大数。 5 metadata_keep_alive_duration_secHTTPメタデータ同期クライアントのアイドル接続キープアライブ持続時間。 300 metadata_connect_timeout_secHTTPメタデータ同期クライアントのTCP接続タイムアウト。 10 metadata_read_timeout_secHTTPメタデータ同期クライアントのソケット読み取りタイムアウト。 10 metadata_write_timeout_secHTTPメタデータ同期クライアントのソケット書き込みタイムアウト。 10 metadata_call_timeout_secHTTPメタデータ同期クライアントのHTTPリクエスト総タイムアウト。 10 -
{CommonProperties}CommonPropertiesセクションは、共通のプロパティを入力するために使用されます。Data Catalog Overviewの[Common Properties]セクションを参照してください。
アクセスモード
Arrow Flightモード
バージョン4.0.2からサポートされています。
use_arrow_flightプロパティがtrueに設定されている場合、Arrow Flightモードです。

このモードでは、クロスクラスタークエリ中に、FEはHTTPプロトコルを通じてSchemaなどのメタデータを同期し、その後ローカルクラスターのBEノードがArrow FlightインターフェースでリモートDorisクラスターにアクセスします。
利点: FEのオーバーヘッドがほとんどありません。実行計画はリモートクラスターに送信するクエリSQLを生成するのみです。
欠点: 集約プッシュダウン、制限されたpredicate pushdownなど、Doris内部テーブルの様々な最適化機能を活用できない場合があります。
Virtual Clusterモード
バージョン4.0.3からサポートされています。
use_arrow_flightプロパティがfalseに設定されている場合、Virtual Clusterモードです。
このモードは現在、ストレージ・コンピュート結合モードでデプロイされたDorisクラスターのみをサポートしています。

このモードでは、クロスクラスタークエリ中に、リモートDorisクラスターのBackendノードがクエリプランニングの仮想ノードとして扱われます。
FEはHTTPプロトコルを通じてSchemaなどのメタデータを同期します。BEは内部通信プロトコルを通じて直接データを転送します。
利点: Doris内部テーブルクエリのすべての最適化機能を基本的に活用できます。クエリ実行フローは単一クラスター内部フローと一致します。
欠点: 大きなリモートテーブルの場合、リモートテーブルのすべての情報(パーティション情報、レプリカ情報)が取得されます。FEメモリオーバーヘッドが増加し、FEメモリの拡張が必要になります。クラスターバージョンが一致しない場合、例えば高バージョンが低バージョンをクエリする場合、クエリ失敗が発生する可能性があります。
バージョン4.1以降、Virtual Clusterモードはinsert loading機能をサポートしています。
カラムタイプマッピング
Arrow Flightモード
このモードでサポートされるカラムタイプとテーブルタイプは、Arrow Flight SQLのサポート機能に依存します。現在、以下の機能と制限があります:
- すべてのプリミティブタイプをサポートします。
- すべてのネストタイプ(Array、Map、Struct)をサポートします。
- hll、bitmap、variantタイプはサポートしません。
- すべてのテーブルモデル(Duplicate、Aggregate、Uniqueテーブル)をサポートします。
Virtual Clusterモード
Virtual Clusterモードでは、すべてのカラムタイプとすべてのテーブルモデル(Duplicate、Aggregate、Uniqueテーブル)がサポートされています。
クエリ操作
Catalogを設定した後、以下の方法でCatalog内のテーブルデータをクエリできます:
-- 1. switch to catalog, use database and query
SWITCH doris_ctl;
USE doris_db;
SELECT * FROM doris_tbl LIMIT 10;
-- 2. use doris database directly
USE doris_ctl.doris_db;
SELECT * FROM doris_tbl LIMIT 10;
-- 3. use full qualified name to query
SELECT * FROM doris_ctl.doris_db.doris_tbl LIMIT 10;
クエリ最適化
Arrow Flight モード
このモードでは、Doris は述語や関数条件のプッシュダウンを試行し、それらを生成されたSQLに連結します。
生成されたSQL文は EXPLAIN SQL を通じて確認できます。
...
| 0:VREMOTE_DORIS_SCAN_NODE(68) |
| TABLE: test.test_time |
| QUERY: SELECT /*+ SET_VAR(enable_parallel_result_sink=true) */ `timestamp` FROM test.test_time WHERE (timestamp > '2025-11-03 00:00:00.000') |
| PREDICATES: (timestamp[#0] > '2025-11-03 00:00:00.000')
...
Virtual Cluster Mode
このモードでは、実行プランで表示されるのは依然としてVOlapScanNodeです。
内部テーブルクエリに対するDorisの様々な最適化は、Join Runtime Filterなどのように引き続き利用することができます。
MySQL [(none)]> explain select * from demo.inner_table a join edoris.external.example_tbl_duplicate b on (a.log_type = b.log_type) where error_code=2;
+-------------------------------------------------------------------------------------------------------------------------------------------+
| Explain String(Nereids Planner) |
+-------------------------------------------------------------------------------------------------------------------------------------------+
| PLAN FRAGMENT 0 |
| OUTPUT EXPRS: |
| log_type[#16] |
| reason[#17] |
| log_time[#18] |
| log_type[#19] |
| error_code[#20] |
| error_msg[#21] |
| op_id[#22] |
| op_time[#23] |
| PARTITION: HASH_PARTITIONED: log_type[#6] |
| |
| HAS_COLO_PLAN_NODE: false |
| |
| VRESULT SINK |
| MYSQL_PROTOCOL |
| |
| 3:VHASH JOIN(200) |
| | join op: INNER JOIN(BROADCAST)[] |
| | equal join conjunct: (log_type[#6] = log_type[#1]) |
| | cardinality=3 |
| | vec output tuple id: 3 |
| | output tuple id: 3 |
| | vIntermediate tuple ids: 2 |
| | hash output slot ids: 0 1 2 3 4 5 6 7 |
| | runtime filters: RF000[min_max] <- log_type[#1](1/1/1048576), RF001[in_or_bloom] <- log_type[#1](1/1/1048576) |
| | final projections: log_type[#8], reason[#9], log_time[#10], log_type[#11], error_code[#12], error_msg[#13], op_id[#14], op_time[#15] |
| | final project output tuple id: 3 |
| | distribute expr lists: log_type[#6] |
| | distribute expr lists: |
| | |
| |----1:VEXCHANGE |
| | offset: 0 |
| | distribute expr lists: log_type[#1] |
| | |
| 2:VOlapScanNode(187) |
| TABLE: demo.inner_table(inner_table), PREAGGREGATION: ON |
| partitions=1/1 (inner_table) |
| tablets=1/1, tabletList=1762832514491 |
| cardinality=3, avgRowSize=901.6666, numNodes=1 |
| pushAggOp=NONE |
| runtime filters: RF000[min_max] -> log_type[#6], RF001[in_or_bloom] -> log_type[#6] |
| |
| PLAN FRAGMENT 1 |
| |
| PARTITION: HASH_PARTITIONED: log_type[#1] |
| |
| HAS_COLO_PLAN_NODE: false |
| |
| STREAM DATA SINK |
| EXCHANGE ID: 01 |
| UNPARTITIONED |
| |
| 0:VOlapScanNode(188) |
| TABLE: external.example_tbl_duplicate(example_tbl_duplicate), PREAGGREGATION: ON |
| PREDICATES: (error_code[#2] = 2) |
| partitions=1/1 (example_tbl_duplicate) |
| tablets=1/1, tabletList=1762481736238 |
| cardinality=1, avgRowSize=7425.0, numNodes=1 |
| pushAggOp=NONE
Write Operations
バージョン4.1以降でサポートされています。
Catalogを設定した後、以下のinsert方法を使用してVirtual ClusterモードでCatalog内のテーブルにデータをインポートできます:
-- 1. switch to catalog, use database and insert
SWITCH doris_ctl;
USE doris_db;
insert into doris_tbl values (1,2);
-- 2. use doris database directly
USE doris_ctl.doris_db;
insert into doris_tbl values (1,2);
-- 3. use full qualified name to insert
insert into doris_ctl.doris_db.doris_tbl values (1,2);
サポートされているインポート形式
-- 1. insert into values
insert into doris_ctl.doris_db.doris_tbl values (1,2);
-- 2. insert into select
insert into doris_ctl.doris_db.doris_tbl select * from doris_db.doris_tbl;
-- 3. insert overwrite
insert overwrite table doris_ctl.doris_db.doris_tbl select * from doris_db.doris_tbl;
サポートされていないインポート機能
Catalogを設定した後、以下のインポート機能は現在サポートされていません: