監視サーバーの構成をカスタマイズする
TiUPを使用して TiDB クラスターをデプロイすると、 TiUP はPrometheus、Grafana、Alertmanager などの監視サーバーもデプロイします。その間に、このクラスターをスケールアウトすると、 TiUP は新しいノードを監視範囲に追加します。
上記の監視サーバーの構成をカスタマイズするには、以下の手順に従って、TiDB クラスターの topology.yaml に関連する構成項目を追加します。
注記:
監視サーバーの構成ファイルを直接変更しないでください。これらの変更は、デプロイメント、スケールアウト、スケールイン、再ロードなどの後のTiUP操作によって上書きされるためです。
監視サーバーがTiUPによって展開および管理されていない場合は、このドキュメントを参照する代わりに、監視サーバーの構成ファイルを直接変更できます。
この機能はTiUP v1.9.0 以降でサポートされています。したがって、この機能を使用する前にTiUP のバージョンを確認してください。
Prometheusの設定をカスタマイズする
現在、 TiUP はPrometheus ルールとスクレイプ構成ファイルのカスタマイズをサポートしています。
Prometheusルール設定をカスタマイズする
ルール構成ファイルをカスタマイズし、 TiUPが配置されているマシンのディレクトリの下に配置します。
topology.yaml ファイルで、カスタマイズされたルール構成ファイルのディレクトリに
rule_dir
を設定します。以下は、topology.yaml ファイル内の monitoring_servers の構成例です。
# # Server configs are used to specify the configuration of Prometheus Server. monitoring_servers: # # The ip address of the Monitoring Server. - host: 127.0.0.1 rule_dir: /home/tidb/prometheus_rule # prometheus rule dir on TiUP machine
上記の構成が完了したら、TiDB クラスターをデプロイ、スケールアウト、スケールイン、またはリロードすると、 TiUP はrule_dir
(たとえば/home/tidb/prometheus_rule
) からカスタマイズされたルール構成をロードし、それを Prometheus サーバーに送信してデフォルトのルール構成を置き換えます。
Prometheus スクレイプ設定をカスタマイズする
TiDB クラスターの topology.yaml ファイルを開きます。
monitoring_servers
構成にadditional_scrape_conf
フィールドを追加します。以下は、topology.yaml ファイル内の monitoring_servers の構成例です。
monitoring_servers: - host: xxxxxxx ssh_port: 22 port: 9090 deploy_dir: /tidb-deploy/prometheus-9090 data_dir: /tidb-data/prometheus-9090 log_dir: /tidb-deploy/prometheus-9090/log external_alertmanagers: [] arch: amd64 os: linux additional_scrape_conf: metric_relabel_configs: - source_labels: [__name__] separator: ; regex: tikv_thread_nonvoluntary_context_switches|tikv_thread_voluntary_context_switches|tikv_threads_io_bytes_total action: drop - source_labels: [__name__,name] separator: ; regex: tikv_thread_cpu_seconds_total;(tokio|rocksdb).+ action: drop
上記の構成が完了したら、TiDB クラスターをデプロイ、スケールアウト、スケールイン、またはリロードすると、 TiUP はadditional_scrape_conf
フィールドの内容を Prometheus 構成ファイルの対応するパラメーターに追加します。
Grafana 設定をカスタマイズする
現在、 TiUP はGrafana ダッシュボードやその他の構成のカスタマイズをサポートしています。
Grafanaダッシュボードをカスタマイズする
Grafana ダッシュボードの構成ファイルをカスタマイズし、 TiUPが配置されているマシンのディレクトリの下に配置します。
topology.yaml ファイルで、カスタマイズされたダッシュボード構成ファイルのディレクトリに
dashboard_dir
を設定します。以下は、topology.yaml ファイル内の grafana_servers の設定例です。
# # Server configs are used to specify the configuration of Grafana Servers. grafana_servers: # # The ip address of the Grafana Server. - host: 127.0.0.1 dashboard_dir: /home/tidb/dashboards # grafana dashboard dir on TiUP machine
上記の構成が完了したら、TiDB クラスターをデプロイ、スケールアウト、スケールイン、またはリロードすると、 TiUP はdashboard_dir
(たとえば/home/tidb/dashboards
) からカスタマイズされたダッシュボード構成をロードし、その構成を Grafana サーバーに送信してデフォルトのダッシュボード構成を置き換えます。
その他のGrafana設定をカスタマイズする
TiDB クラスターの topology.yaml ファイルを開きます。
grafana_servers
構成に他の構成項目を追加します。以下は、topology.yaml ファイルの
[log.file] level
フィールドとsmtp
フィールドの構成例です。# # Server configs are used to specify the configuration of Grafana Servers. grafana_servers: # # The ip address of the Grafana Server. - host: 127.0.0.1 config: log.file.level: warning smtp.enabled: true smtp.host: {IP}:{port} smtp.user: example@pingcap.com smtp.password: {password} smtp.skip_verify: true
上記の構成が完了したら、TiDB クラスターをデプロイ、スケールアウト、スケールイン、またはリロードすると、 TiUP はconfig
フィールドの内容を Grafana 構成ファイルgrafana.ini
に追加します。
Alertmanager 設定をカスタマイズする
現在、 TiUP はAlertmanager のリスニング アドレスのカスタマイズをサポートしています。
TiUPによってデプロイされた Alertmanager は、デフォルトでalertmanager_servers.host
をリッスンします。プロキシを使用すると、Alertmanager にアクセスできません。この問題に対処するには、クラスター構成ファイル topology.yaml にlisten_host
を追加して、リッスン アドレスを指定します。推奨値は 0.0.0.0 です。
次の例では、 listen_host
フィールドを 0.0.0.0 に設定します。
alertmanager_servers:
# # The ip address of the Alertmanager Server.
- host: 172.16.7.147
listen_host: 0.0.0.0
# # SSH port of the server.
ssh_port: 22
上記の構成が完了したら、TiDB クラスターをデプロイ、スケールアウト、スケールイン、またはリロードすると、 TiUP はAlertmanager 起動パラメータのlisten_host
フィールドの内容を--web.listen-address
に追加します。