Compute Group
Compute Groupは、ストレージ・コンピュート分離アーキテクチャにおいて、異なるワークロード間の物理的な分離を実現するメカニズムです。Compute Groupの基本原理を以下の図に示します:

-
1つまたは複数のBEノードがCompute Groupを構成できます。
-
BEノードはローカルではステートレスで、データは共有ストレージに保存されます。
-
複数のCompute Groupが共有ストレージを通じてデータにアクセスします。
Resource Groupのような強い分離の利点を維持しながら、Compute Groupは以下の利点を提供します:
-
より低いコスト:ストレージ・コンピュート分離アーキテクチャにより、データは共有ストレージに存在するため、Compute Groupの数がレプリカ数によって制限されなくなります。ユーザーはストレージコストを増加させることなく、必要な数だけCompute Groupを作成できます。
-
より高い柔軟性:ストレージ・コンピュート分離アーキテクチャでは、BEノード上のデータはキャッシュされるため、Compute Groupの追加に煩雑なデータ移行プロセスは必要ありません。新しいCompute Groupは、クエリ実行時にキャッシュをウォームアップするだけで済みます。
-
より優れた分離:データの可用性は共有ストレージ層で処理されるため、任意のCompute Group内のBEノードの障害が、Resource Groupで発生するようなデータロード失敗を引き起こすことはありません。
3.0.2以前は、Compute Clusterと呼ばれていました。
全てのCompute Groupの表示
SHOW COMPUTE GROUPSコマンドを使用して、現在のリポジトリ内の全てのcompute groupを表示します。返される結果は、ユーザーの権限レベルに基づいて異なる内容が表示されます:
ADMIN権限を持つユーザーは全てのcompute groupを表示できます- 一般ユーザーは使用権限(USAGE_PRIV)を持つcompute groupのみ表示できます
- ユーザーがいずれのcompute groupに対しても使用権限を持たない場合、空の結果が返されます
SHOW COMPUTE GROUPS;
Compute Groupの追加
Compute Groupを管理するには、ノード管理権限を制御するOPERATOR権限が必要です。詳細については、Privilege Managementを参照してください。デフォルトでは、rootアカウントのみがOPERATOR権限を持ちますが、GRANTコマンドを使用して他のアカウントに付与することができます。
BEを追加してCompute Groupに割り当てるには、Add BEコマンドを使用します。例:
ALTER SYSTEM ADD BACKEND 'host:9050' PROPERTIES ("tag.compute_group_name" = "new_group");
上記のsqlはhost:9050をcompute group new_groupに追加します。PROPERTIES文を省略した場合、BEはcompute group default_compute_groupに追加されます。例えば:
ALTER SYSTEM ADD BACKEND 'host:9050';
Compute Group アクセスの許可
前提条件:現在の操作ユーザーが'ADMIN'権限を持っている、または現在のユーザーが admin ロールに属している。
GRANT USAGE_PRIV ON COMPUTE GROUP {compute_group_name} TO {user}
Compute Group アクセスの取り消し
前提条件:現在の操作ユーザーが'ADMIN'権限を持っている、または現在のユーザーがadminロールに属している。
REVOKE USAGE_PRIV ON COMPUTE GROUP {compute_group_name} FROM {user}
デフォルトCompute Groupの設定
現在のユーザーのデフォルトcompute groupを設定するには(この操作には、現在のユーザーがすでにcomputing groupを使用する権限を持っている必要があります):
SET PROPERTY 'default_compute_group' = '{clusterName}';
他のユーザーのデフォルトcompute groupを設定するには(この操作にはAdmin権限が必要です):
SET PROPERTY FOR {user} 'default_compute_group' = '{clusterName}';
現在のユーザーのデフォルトcompute groupを確認するには、返された結果のdefault_compute_groupの値がデフォルトcompute groupになります:
SHOW PROPERTY;
他のユーザーのデフォルトcompute groupを表示するには、この操作では現在のユーザーが管理者権限を持っている必要があり、返される結果のdefault_compute_groupの値がデフォルトcompute groupです:
SHOW PROPERTY FOR {user};
現在のリポジトリで利用可能なすべてのコンピュートグループを表示するには:
SHOW COMPUTE GROUPS;
- 現在のユーザーがAdmin ロールを持つ場合、例:
CREATE USER jack IDENTIFIED BY '123456' DEFAULT ROLE "admin"、その場合:- 自分自身および他のユーザーのデフォルトコンピュートグループを設定できます;
- 自分自身および他のユーザーの
PROPERTYを表示できます。
- 現在のユーザーがAdmin ロールを持たない場合、例:
CREATE USER jack1 IDENTIFIED BY '123456'、その場合:- 自分自身のデフォルトコンピュートグループを設定できます;
- 自分自身の
PROPERTYを表示できます; - すべてのコンピュートグループを表示することはできません。この操作には
GRANT ADMIN権限が必要です。
- 現在のユーザーがデフォルトコンピュートグループを設定していない場合、既存のシステムはデータ読み書き操作を実行する際にエラーを発生させます。この問題を解決するには、ユーザーは
use @clusterコマンドを実行して現在のコンテキストで使用するコンピュートグループを指定するか、SET PROPERTY文を使用してデフォルトコンピュートグループを設定できます。 - 現在のユーザーがデフォルトコンピュートグループを設定しているが、そのクラスタが後で削除された場合、データ読み書き操作中にもエラーが発生します。ユーザーは
use @clusterコマンドを実行して現在のコンテキストで使用するコンピュートグループを再指定するか、SET PROPERTY文を使用してデフォルトクラスタ設定を更新できます。
コンピュートグループの切り替え
ユーザーは、コンピュート・ストレージ分離アーキテクチャで使用するデータベースとコンピュートグループを指定できます。
構文
USE { [catalog_name.]database_name[@compute_group_name] | @compute_group_name }
データベースまたはcompute group名に予約キーワードが含まれている場合、対応する名前はバッククォート```で囲む必要があります。
Compute Groupのスケーリング
ALTER SYSTEM ADD BACKENDおよびALTER SYSTEM DECOMMISION BACKENDを使用してBEを追加または削除することで、compute groupをスケールできます。