潇湘夜雨移动版

主页 > 系统 > 云计算与云原生 >

promtail添加自定义指标

1、配置文件
server:
  log_level: info
  http_listen_port: 3101
  
 
clients:
  - url: http://loki-distributed-gateway/loki/api/v1/push
 
positions:
  filename: /run/promtail/positions.yaml
 
scrape_configs:
  - job_name: kubernetes-pods
    pipeline_stages:
      - cri: {}
      - metrics:
          log_lines_total:
            type: Counter
            description: "total number of log lines"
            prefix: my_promtail_custom_
            max_idle_duration: 24h
            config:
              match_all: true
              action: inc
          log_bytes_total:
            type: Counter
            description: "total bytes of log lines"
            prefix: my_promtail_custom_
            max_idle_duration: 24h
            config:
              match_all: true
              count_entry_bytes: true
              action: add
      - regex:
          expression: '(?i)(?P<error_flag>error|fail|exception|fatal|panic|timeout|crash|denied|reject)'
      - metrics:
          log_errors_total:
            type: Counter
            description: "Total number of error log lines"
            prefix: my_promtail_custom_
            max_idle_duration: 24h
            source: error_flag
            config:
              action: inc
 
      - match:
          selector: '{app="kubernetes-event-exporter"}'
          stages:
          - json:
              expressions:
                namespace: involvedObject.namespace
          - labels:
              namespace: ""
    kubernetes_sd_configs:
      - role: pod
    relabel_configs:
      - source_labels:
          - __meta_kubernetes_pod_controller_name
        regex: ([0-9a-z-.]+?)(-[0-9a-f]{8,10})?
        action: replace
        target_label: __tmp_controller_name
      - source_labels:
          - __meta_kubernetes_pod_label_app_kubernetes_io_name
          - __meta_kubernetes_pod_label_app
          - __tmp_controller_name
          - __meta_kubernetes_pod_name
        regex: ^;*([^;]+)(;.*)?$
        action: replace
        target_label: app
      - source_labels:
          - __meta_kubernetes_pod_label_app_kubernetes_io_instance
          - __meta_kubernetes_pod_label_release
        regex: ^;*([^;]+)(;.*)?$
        action: replace
        target_label: instance
      - source_labels:
          - __meta_kubernetes_pod_label_app_kubernetes_io_component
          - __meta_kubernetes_pod_label_component
        regex: ^;*([^;]+)(;.*)?$
        action: replace
        target_label: component
      - action: replace
        source_labels:
        - __meta_kubernetes_pod_node_name
        target_label: node_name
      - action: replace
        source_labels:
        - __meta_kubernetes_namespace
        target_label: namespace
      - action: replace
        replacement: $1
        separator: /
        source_labels:
        - namespace
        - app
        target_label: job
      - action: replace
        source_labels:
        - __meta_kubernetes_pod_name
        target_label: pod
      - action: replace
        source_labels:
        - __meta_kubernetes_pod_container_name
        target_label: container
      - action: replace
        replacement: /var/log/pods/*$1/*.log
        separator: /
        source_labels:
        - __meta_kubernetes_pod_uid
        - __meta_kubernetes_pod_container_name
        target_label: __path__
      - action: replace
        regex: true/(.*)
        replacement: /var/log/pods/*$1/*.log
        separator: /
        source_labels:
        - __meta_kubernetes_pod_annotationpresent_kubernetes_io_config_hash
        - __meta_kubernetes_pod_annotation_kubernetes_io_config_hash
        - __meta_kubernetes_pod_container_name
        target_label: __path__
  
  
 
limits_config:


2、Prometheus配置服务发现

容器版本配置参考:

apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
  labels:
    app.kubernetes.io/name: promtail
 
 
  name: promtail
  namespace: loki
spec:
  endpoints:
  - interval: 30s
    path: /metrics
    port: http-metrics
    relabelings:
    - action: replace
      sourceLabels:
      - __meta_kubernetes_pod_node_name
      targetLabel: instance
  selector:
    matchLabels:
      app.kubernetes.io/name: promtail


apiVersion: v1
kind: Service
metadata:
  name: promtail
  labels:
    app.kubernetes.io/name: promtail
#    key: string
  namespace: loki
  resourceVersion: '1831319066'
 
    - app.kubernetes.io/name=promtail
spec:
  selector:
    app.kubernetes.io/name: promtail
 
3、统计多天日志量对比
label_replace(
sum by (exported_container)(delta(my_promtail_custom_log_lines_total{namespace="$namespace", container="promtail",cluster="$cluster",exported_namespace=~"$exported_namespace",exported_container=~"$exported_container"}[$__range])),
  "period", "today", "", ".*"
)
or
label_replace(
sum by (exported_container)(delta(my_promtail_custom_log_lines_total{namespace="$namespace", container="promtail",cluster="$cluster",exported_namespace=~"$exported_namespace",exported_container=~"$exported_container"}[$__range] offset 1d)),
  "period", "yesterday", "", ".*"
)
or
label_replace(
sum by (exported_container)(delta(my_promtail_custom_log_lines_total{namespace="$namespace", container="promtail",cluster="$cluster",exported_namespace=~"$exported_namespace",exported_container=~"$exported_container"}[$__range] offset 2d)),
  "period", "2_days_ago", "", ".*"
)
 

(责任编辑:liangzh)