Blackbox Exporter@Prometheus¶
はじめに¶
本サイトにつきまして、以下をご認識のほど宜しくお願いいたします。
01. Blackbox Exporterの仕組み¶
アーキテクチャ¶
Blackbox Exporterは、外部システムに特定のプロトコル (例:HTTP、HTTPS、DNS、ICMP、SSH、SMTP) でヘルスチェックを実施する。
また、Prometheusにメトリクスを公開する。
Prometheusによるメトリクス収集¶
02. セットアップ¶
チャートとして¶
チャートリポジトリからチャートをインストールし、Kubernetesリソースを作成する。
$ helm repo add <チャートリポジトリ名> https://prometheus-community.github.io/helm-charts
$ helm repo update
$ kubectl create namespace prometheus
$ helm install <Helmリリース名> <チャートリポジトリ名>/prometheus-blackbox-exporter -n prometheus --version <バージョンタグ>
03. マニフェスト¶
ConfigMap¶
apiVersion: v1
kind: ConfigMap
metadata:
name: blackbox-exporter
namespace: prometheus
labels:
k8s-app: blackbox-exporter
data:
blackbox.yaml: |
modules:
http_2xx:
http:
no_follow_redirects: true
preferred_ip_protocol: ip4
valid_http_versions:
- HTTP/1.1
- HTTP/2.0
valid_status_codes: []
prober: http
timeout: 5s
Deployment配下のPod¶
外部システムに対してヘルスチェックを実施する。
apiVersion: v1
kind: Pod
metadata:
name: blackbox-exporter
namespace: prometheus
labels:
k8s-app: blackbox-exporter
spec:
restartPolicy: Always
containers:
- name: blackbox-exporter
image: "prom/blackbox-exporter"
imagePullPolicy: IfNotPresent
securityContext:
readOnlyRootFilesystem: true
runAsNonRoot: true
runAsUser: 1000
args:
# 設定ファイルを読み込む
- "--config.file=/config/blackbox.yaml"
resources: {}
ports:
- containerPort: 9115
name: http
livenessProbe:
httpGet:
path: /health
port: http
readinessProbe:
httpGet:
path: /health
port: http
volumeMounts:
- mountPath: /config
name: config
volumes:
- name: config
configMap:
name: blackbox-exporter
Service¶
Prometheusは、ServiceMonitorを介して、Blackbox ExporterのPodからメトリクスを収集する。
この時にPodの前段にServiceを配置する必要がある。
kind: Service
apiVersion: v1
metadata:
name: blackbox-exporter
namespace: prometheus
labels:
k8s-app: blackbox-exporter
spec:
type: ClusterIP
ports:
- name: http
port: 9115
protocol: TCP
selector:
k8s-app: blackbox-exporter
03. blackbox.yaml¶
module¶
▼ http¶
外形監視でHTTPリクエストを送信する。
modules:
<好きな名前>:
prober: http
http: ...
▼ tcp¶
外形監視でTCPスリーウェイハンドシェイクを実行する。
modules:
<好きな名前>:
prober: tcp
tcp: ...
▼ dns¶
外形監視でHTTPリクエストを送信する。
modules:
<好きな名前>:
prober: dns
dns: ...
▼ icmp¶
外形監視でPing (ICMPエコーリクエスト) を送信する。
modules:
<好きな名前>:
prober: icmp
http: ...
▼ grpc¶
外形監視でgRPCによるHTTPリクエストを送信する。
modules:
<好きな名前>:
prober: grpc
http: ...
http probe¶
▼ http probeとは¶
監視対象に送信するHTTPリクエストを定義する。
▼ GETリクエストの場合¶
外形監視でGETリクエストを送信する。
modules:
# GETリクエストの場合 (HTTPS)
https_2xx_get:
# HTTPプロトコルを使用する
prober: http
timeout: 5s
# http probe
http:
# レスポンスの期待ステータスコード
valid_http_versions:
- HTTP/1.1
- HTTP/2.0
# 優先するIPアドレスの種類
preferred_ip_protocol: ip4
# IPV6が使えない場合に、IPv4に切り替える
ip_protocol_fallback: "true"
follow_redirects: "true"
tcp:
ip_protocol_fallback: "true"
icmp:
ip_protocol_fallback: "true"
dns:
ip_protocol_fallback: "true"
recursion_desired: "true"
# GETリクエストの場合 (HTTPS)
http_2xx_get:
# HTTPプロトコルを使用する
prober: http
timeout: 5s
# http probe
http:
# レスポンスの期待ステータスコード
valid_http_versions:
- HTTP/1.1
# 優先するIPアドレスの種類
preferred_ip_protocol: ip4
# IPV6が使えない場合に、IPv4に切り替える
ip_protocol_fallback: "true"
tls_config:
# SSL証明書を任意にする
insecure_skip_verify: "true"
▼ POSTリクエストの場合¶
外形監視にて、HTTPプロトコルでPOSTリクエストを送信する。
modules:
# POSTリクエストの場合
http_2xx_post:
# HTTPプロトコルを使用する
prober: http
timeout: 30s
# http probe
http:
# レスポンスの期待ステータスコード
valid_status_codes:
- 200
# IPV6が使えない場合に、IPv4に切り替える
ip_protocol_fallback: "true"
method: POST
# リクエストヘッダー
headers:
# データ形式
Accept: application/json
# 入力フォームへのデータ送信に必要
Content-Type: application/x-www-form-urlencode
# メッセージボディ
body: "{}"
follow_redirects: "true"
tcp:
ip_protocol_fallback: "true"
icmp:
ip_protocol_fallback: "true"
dns:
ip_protocol_fallback: "true"
recursion_desired: "true"
メトリクスの一覧¶
▼ 確認方法¶
Blackbox Exporterの場合は、Nodeの『127.0.0.1:9115/probe?target=google.com&module=http_2xx
』をコールすると、PromQLで使用できるメトリクスを取得できる。
$ curl http://127.0.0.1:9115/probe?target=google.com&module=http_2xx
...
probe_success
...
▼ よく使用するメトリクス¶
メトリクス | メトリクスの種類 | 説明 | PromQL例 |
---|---|---|---|
probe_success |
Gauge | 監視対象の状態を表す。1 であれば稼働中、0 であれば停止中である。 |
sum((probe_success{namespace="foo-namespace"})) / count((probe_success{namespace="foo-namespace"})) |