メインコンテンツまでスキップ
バージョン: 3.9

Helm Charts の入門 (Scalar Manager)

注記

このページは英語版のページが機械翻訳されたものです。英語版との間に矛盾または不一致がある場合は、英語版を正としてください。

Scalar Manager は、Kubernetes クラスタ環境内の ScalarDB および ScalarDL の集中管理および監視ソリューションであり、次のことができます:

  • ScalarDB または ScalarDL の可用性を確認します。
  • ScalarDB または ScalarDL が使用するデータベースにおいて、トランザクションが一貫した期間を作成するジョブのスケジュールや実行を行います。
  • Grafana ダッシュボードを通じて、ScalarDB または ScalarDL の時系列メトリクスやログを確認します。

Scalar Manager の詳細については、Scalar Manager 概要ページを参照してください。

このガイドでは、Kubernetes クラスターに Scalar Manager を展開し、アクセスする方法を説明します。

予測

このガイドでは、モニタリングおよびロギングツールを使用して ScalarDB または ScalarDL を Kubernetes クラスターにデプロイする方法を理解していることを前提としています。

要件

私たちが作るもの

次のように、次のコンポーネントを Kubernetes クラスターにデプロイします。

+--------------------------------------------------------------------------------------------------+
| +----------------------+ |
| | scalar-manager | |
| | | |
| | +------------------+ | --------------------------(管理)--------------------------+ |
| | | Scalar Manager | | | |
| | +------------------+ | | |
| +--+-------------------+ | |
| | | |
| +------------------------------------+ | |
| | loki-stack | V |
| | | +-----------------+ |
| | +--------------+ +--------------+ | <----------------(ログ)--------------- | Scalar 製品 | |
| | | Loki | | Promtail | | | | |
| | +--------------+ +--------------+ | | +-----------+ | |
| +------------------------------------+ | | ScalarDB | | |
| | | +-----------+ | |
| +------------------------------------------------------+ | | |
| | kube-prometheus-stack | | +-----------+ | |
| | | | | ScalarDL | | |
| | +--------------+ +--------------+ +--------------+ | -----(監視)----> | +-----------+ | |
| | | Prometheus | | Alertmanager | | Grafana | | +-----------------+ |
| | +-------+------+ +------+-------+ +------+-------+ | |
| | | | | | |
| | +----------------+-----------------+ | |
| | | | |
| +--------------------------+---------------------------+ |
| | | |
| | | Kubernetes |
+----+-----------------------+---------------------------------------------------------------------+
| |
localhost (127.0.0.1) に公開するか、ロードバランサーなどを使用してアクセスします
| |
(HTTP経由でダッシュボードにアクセス)
| |
+----+----+ +----+----+
| ブラウザ | <-(埋め込む)-- + ブラウザ |
+---------+ +---------+

ステップ 1. Grafana を埋め込めるように kube-prometheus-stack をアップグレードします。

  1. この値を kube-prometheus-stack のカスタム値ファイル (scalar-prometheus-custom-values.yaml など) に追加または修正します。

    kubeStateMetrics:
    enabled: true
    nodeExporter:
    enabled: true
    kubelet:
    enabled: true
    grafana:
    grafana.ini:
    users:
    default_theme: light
    security:
    allow_embedding: true
    auth.anonymous:
    enabled: true
    org_name: "Main Org."
    org_role: Editor
  2. Helm インストールをアップグレードします。

    helm upgrade scalar-monitoring prometheus-community/kube-prometheus-stack -n monitoring -f scalar-prometheus-custom-values.yaml

ステップ 2. Scalar Manager のカスタム値ファイルを準備する

  1. scalar-manager 用に scalar-manager-custom-values.yaml という名前の空の .yaml ファイルを作成します。

  2. Scalar Manager にアクセスするためのサービス タイプを設定します。 デフォルト値は ClusterIP ですが、minikube tunnel コマンドや何らかのロードバランサを使ってアクセスする場合は、LoadBalancer として設定することができます。

    service:
    type: LoadBalancer
    port: 8000

ステップ 3. scalar-manager をデプロイする

  1. scalar-manager Helm Chart をデプロイします。
    helm install scalar-manager scalar-labs/scalar-manager -f scalar-manager-custom-values.yaml

ステップ 4. Scalar Manager にアクセスする

minikubeを使用する場合

  1. Scalar Manager のサービス リソースを localhost (127.0.0.1) として公開するには、別のターミナルを開き、minikube tunnel コマンドを実行します。

    minikube tunnel
  2. URL http://localhost:8000 でブラウザを開きます。

minikube 以外の Kubernetes を使用する場合

Minikube 以外の Kubernetes クラスターを使用している場合は、各 Kubernetes クラスターの方法に従って LoadBalancer サービスにアクセスする必要があります。 例えば、クラウドサービスプロバイダーが提供するロードバランサーを使用するか、kubectl port-forward コマンドを使用する必要があります。

注記

Scalar Manager は Grafana の外部IPを検出して、そのIPに基づいて Grafana を埋め込もうとします。 そのため、Grafana のサービスタイプを LoadBalancer に設定し、外部 IP がブラウザからアクセス可能でなければなりません。

ステップ 5. Scalar Manager を削除する

  1. scalar-manager をアンインストールします。
    helm uninstall scalar-manager

追加詳細

このセクションでは、設定とリソース検出に関する追加詳細を提供します。

設定

Scalar Managerの設定については、Scalar Manager用のカスタム値ファイルの設定をご覧ください。

リソース検出

Scalar Managerは、特定のラベルセレクターを使用して、クラスター内の以下のKubernetesリソースを検出します:

  • 依存関係
    • Prometheusサービス
    • Lokiサービス
    • Grafanaサービス
  • ターゲット
    • ScalarDB Clusterデプロイメント
    • ScalarDL Ledgerデプロイメント
    • ScalarDL Auditorデプロイメント

以下のセクションでは、Scalar Managerがこれらのリソースをどのように検出するかを説明します。

依存関係

Scalar Managerは、kube-prometheus-stackloki-stack Helm Chartsで設定されたデフォルトのラベルと値を検索します。Scalar Managerが依存関係の検出に使用するデフォルトのラベルと値の詳細については、api.applicationPropertiesで設定できるプロパティをご覧ください。

また、kube-prometheus-stackまたはloki-stackのインストール時に値をカスタマイズした場合は、Scalar Managerのカスタム値api.applicationPropertiesでラベルセレクターを更新する必要があります。

ターゲット

Scalar Managerは、以下のラベルと値を使用してScalarDB Cluster、ScalarDL Ledger、ScalarDL Auditorのデプロイメントを検索します:

  • ScalarDB Cluster: app.kubernetes.io/app=scalardb-cluster
  • ScalarDL Ledger: app.kubernetes.io/app=ledger
  • ScalarDL Auditor: app.kubernetes.io/app=auditor

Scalar Helm ChartsはScalarDB Cluster、ScalarDL Ledger、ScalarDL Auditorのデプロイメントに固定のラベルと値を使用しているため、Scalar Helm Chartsを使用してScalarDBとScalarDLをインストールした場合、Scalar Managerはこれらのデプロイメントを自動的に検出します。