參考
1. 使用 Prometheus
1.1 訪問 Prometheus
1.1.1 端口轉發
- Prometheus 服務默認啟用。
# option1:本地 localhost 端口轉發
kubectl -n istio-system port-forward \
$(kubectl -n istio-system get pod -l app=prometheus -o jsonpath='{.items[0].metadata.name}') \
9090:9090 &
# option2:kube-proxy 端口轉發
kubectl proxy --address='100.64.198.131' --port=9090 --accept-hosts='^*$'
URL:http://100.64.198.131:9090/api/v1/namespaces/istio-system/services/http:prometheus:9090/proxy
1.1.2 開放 Prometheus 服務
1.1.2.1 定制 prometheus values.yaml
- 同 Grafana 一致,通過定制
values.yaml
,可以開放 Promethehs 的 Service 服務。
vim install/kubernetes/helm/istio/charts/prometheus/values.yaml
# "ingress" 資源的 "spec.rules.host.http.paths.path" 字段,即 "subpath"
contextPath: /
ingress:
# 啟用 "ingress"
enabled: enable
## Used to create an Ingress record.
hosts:
# 修改 "domain"
- prometheus.istio
annotations:
# kubernetes.io/ingress.class: nginx
# kubernetes.io/tls-acme: "true"
tls:
# Secrets must be manually created in the namespace.
# - secretName: prometheus-tls
# hosts:
# - prometheus.local
注意:定制 values.yaml
文件后,需要利用 helm template
重新生成部署清單。
1.1.2.2 自定義 prometheus ingress
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
labels:
app: prometheus
chart: prometheus
heritage: Tiller
release: istio
name: prometheus
namespace: istio-system
spec:
rules:
- host: prometheus.istio
http:
paths:
- backend:
serviceName: prometheus
servicePort: 9090
path: /
1.2 Prometheus 配置文件
- 配置文件保存在名為
prometheus
的ConfigMap
對象中,獲取如下:
kubectl get cm prometheus -n istio-system -o jsonpath='{.data.prometheus\.yml}'