参考

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 配置文件

  • 配置文件保存在名为 prometheusConfigMap 对象中,获取如下:
kubectl get cm prometheus -n istio-system -o jsonpath='{.data.prometheus\.yml}'
扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。