9-1 Kubernetes二进制部署的Prometheus实现服务发现
创始人
2024-01-16 05:42:38
0

文章目录

  • 前言
  • 创建用户
  • 复制Token
  • 配置文件
    • 全局配置
    • Master节点发现
    • Node节点发现
    • Namespace Pod发现
    • 自定义Pod发现

前言

在上一章节介绍了 8-5 在Prometheus实现Kubernetes-apiserver及Coredns服务发现 基于K8s集群内部安装的Prometheus,添加服务发现时更加方便。Prometheus的安装方式有多种,详情参考 8-1 基于Operator和二进制安装Prometheus系统。

对于二进制部署的Prometheus,即集群外部的监控系统。配置服务发现时涉及到创建用户,授权,添加job,重写标签等。



创建用户

创建用户prometheus和密码:

---
# 创建用户
apiVersion: v1
kind: ServiceAccount
metadata:name: prometheusnamespace: monitoring---
# 创建密码
apiVersion: v1
kind: Secret
type: kubernetes.io/service-account-token
metadata:name: monitoring-tokennamespace: monitoringannotations:kubernetes.io/service-account.name: "prometheus"

设置权限,并将用户与权限绑定:

---
# 设置权限
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:name: prometheus
rules:
- apiGroups:- ""resources:- nodes- services- endpoints- pods- nodes/proxy# 对于基本资源可读可观察verbs:- get- list- watch
- apiGroups:- "extensions"resources:- ingressesverbs:- get- list- watch
- apiGroups:- ""resources:- configmaps- nodes/metrics# 配置资源只读verbs:- get
- nonResourceURLs:- /metricsverbs:- get---
# 绑定权限
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:name: prometheus
roleRef:apiGroup: rbac.authorization.k8s.iokind: ClusterRolename: prometheus
subjects:
- kind: ServiceAccountname: prometheusnamespace: monitoring

复制Token

在K8s集群内查看secret 资源,复制token的值:

sudo kubectl describe secret monitoring-token -n monitoring
Name:         monitoring-token
Namespace:    monitoring
Labels:       
Annotations:  kubernetes.io/service-account.name: prometheuskubernetes.io/service-account.uid: da94b15f-55bb-4eba-9d20-52f0b33a9852Type:  kubernetes.io/service-account-tokenData
====
ca.crt:     1302 bytes
namespace:  10 bytes
token:      eyJhbGciOiJSUzI1NiIsImtpZCI6IkF3Y3h6QklHbXh3S1g3Nl9LNlBIcTNTVEQ3MWpJRU9NcEdJM2hTZDU4SzgifQ.eyJpc3
MiOiJrdWJlcm5ldGVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5poTd1njdbdMYlmaUuAPIT_5hY5D3pRgabQ6tysWc0QuFN_mn6U-E
nbBlka6ZUB3gjlvk4XBKZJutqHyFHtkc6RYN98kKSPeRBCXFd8vZROx9PsOjL1uIseox4IeaZ8BvGje3RkGHiyTp_djmc8eyBBA6DwtKKldsd
3hhuD0eX2hbbg2YZVbiYOkLK976gL5pX_8BPQeZ66McDTCPlaoiYOIcegVGwZs49kA4YlYV_A5bO8WUSvnKQfPK_74qLy0BGp-rx0gjTc7w

到K8s集群外的Prometheus服务器,粘贴token的值:

vim /apps/prometheus/k8s.token
eyJhbGciOiJSUzI1NiIsImtpZCI6IkF3Y3h6QklHbXh3S1g3Nl9LNlBIcTNTVEQ3MWpJRU9NcEdJM2hTZDU4SzgifQ.eyJpc3MiOiJrdWJlcm5l
GVzL3NlcnZpY2VhY2NvdW50Iiwia3ViZXJuZXRlcy5poTd1njdbdMYlmaUuAPIT_5hY5D3pRgabQ6tysWc0QuFN_mn6U-EnbBlka6ZUB3gjlvk4
XBKZJutqHyFHtkc6RYN98kKSPeRBCXFd8vZROx9PsOjL1uIseox4IeaZ8BvGje3RkGHiyTp_djmc8eyBBA6DwtKKldsd3hhuD0eX2hbbg2YZVbi
OkLK976gL5pX_8BPQeZ66McDTCPlaoiYOIcegVGwZs49kA4YlYV_A5bO8WUSvnKQfPK_74qLy0BGp-rx0gjTc7w

配置文件

修改Prometheus全局配置,再依次添加收集node,pod,service,endpoint等工作。

全局配置

在二进制部署的Prometheus服务器,找出配置文件并修改:

vim /apps/prometheus/prometheus.yml# my global config
global:# 每15秒收集一次信息scrape_interval: 15s # 每15秒刷新一次规则evaluation_interval: 15s# Alertmanager configuration
alerting:alertmanagers:- static_configs:- targets:# - alertmanager:9093rule_files:# - "first_rules.yml"# - "second_rules.yml"scrape_configs:
# The job name is added as a label `job=` to any timeseries scraped from this config. - job_name: "prometheus"# metrics_path defaults to '/metrics' # scheme defaults to 'http'# 示例工作,收集服务器自己的运行指数:static_configs: - targets: ["localhost:9090"]

Master节点发现

在上述通用配置文件prometheus.yml,末尾添加API Server工作:

# API Serevr 节点发现- job_name: 'kubernetes-apiservers-monitor' kubernetes_sd_configs: - role: endpoints# 填写一个master即可,会自动发现三个。api_server: https://192.168.100.191:6443# 连续该master所需的tokentls_config:insecure_skip_verify: truebearer_token_file: /apps/prometheus/k8s.tokenscheme: https# 连续其它master所需的tokentls_config:insecure_skip_verify: truebearer_token_file: /apps/prometheus/k8s.tokenrelabel_configs:# 配置这些类型保留采集- source_labels: [__meta_kubernetes_namespace, __meta_kubernetes_service_name, __meta_kubernetes_endpoint_port_name]action: keepregex: default; kubernetes; https# 替换发现的服务端口、协议等- source_labels: [__address__]regex: '(.*):6443' replacement: '${1}:9100' target_label: __address__ action: replace- source_labels: [__scheme__]regex: httpsreplacement: httptarget_label: __scheme__ action: replace

可以看到服务端口和协议变成了9100和http:

在这里插入图片描述

Node节点发现

在通用配置文件prometheus.yml,末尾添加Node节点发现:

# node 节点发现- job_name: 'kubernetes-nodes-monitor' # 通过连接master,获取集群node信息kubernetes_sd_configs: - role: nodeapi_server: https://192.168.100.192:6443tls_config:insecure_skip_verify: truebearer_token_file: /apps/prometheus/k8s.token# 连接api-server所需的tokenscheme: httptls_config:insecure_skip_verify: truebearer_token_file: /apps/prometheus/k8s.tokenrelabel_configs:     - source_labels: [__address__]# 10250是kubelet端口,即node节点。regex: '(.*):10250' # 转换成exporter端口9100,采集节点信息。replacement: '${1}:9100' target_label: __address__ action: replace- source_labels: [__meta_kubernetes_node_label_failure_domain_beta_kubernetes_io_region]regex: '(.*)' replacement: '${1}' action: replacetarget_label: LOC- source_labels: [__meta_kubernetes_node_label_failure_domain_beta_kubernetes_io_region]regex: '(.*)' replacement: 'NODE' action: replacetarget_label: Type- source_labels: [__meta_kubernetes_node_label_failure_domain_beta_kubernetes_io_region]regex: '(.*)' replacement: 'K8S-test' action: replacetarget_label: Env- action: labelmapregex: __meta_kubernetes_node_label_(.+)

master也有kubelet,所以集群有6个节点:



Namespace Pod发现

在通用配置文件prometheus.yml,末尾添加Namespace Pod发现:

#指定namespace的pod- job_name: 'kubernetes-namespace-pod' kubernetes_sd_configs: - role: podapi_server: https://192.168.100.193:6443tls_config:insecure_skip_verify: truebearer_token_file: /apps/prometheus/k8s.token# 选择命名空间为monitoringnamespaces:names: - monitoringrelabel_configs: # 保留这些标签和值- action: labelmapregex: __meta_kubernetes_pod_label_(.+) # 更换标签- source_labels: [__meta_kubernetes_namespace]action: replacetarget_label: kubernetes_namespace- source_labels: [__meta_kubernetes_pod_name]action: replacetarget_label: kubernetes_pod_name

可以发现7个实例有6个可采集,有1个pod是down因为没有安装cadvisor。

在这里插入图片描述

自定义Pod发现

要发现自定义Pod,首先创建Pod时要添加annotation_prometheus_io_scrape,值为true:

apiVersion: apps/v1
kind: Deployment
...
spec:template:metadata:annotations:prometheus.io/scrape: 'true'
...    

然后在通用配置文件prometheus.yml,末尾添加自定义Pod发现:

# 自定义Pod发现- job_name: 'kubernetes-condition-pod' kubernetes_sd_configs: - role: podapi_server: https://192.168.100.191:6443tls_config:insecure_skip_verify: truebearer_token_file: /apps/prometheus/k8s.tokenrelabel_configs: # 开启scrape的Pod才保留监控- source_labels: [__meta_kubernetes_pod_annotation_prometheus_io_scrape]action: keepregex: true- source_labels: [__meta_kubernetes_pod_annotation_prometheus_io_path]action: replacetarget_label: __metrics_path__regex: (.+) - source_labels: [__address__, __meta_kubernetes_pod_annotation_prometheus_io_port]action: replaceregex: ([^:]+)(?::\d+)?;(\d+)replacement: $1:$2target_label: __address__- action: labelmap# 保留以下开头的标签和值regex: __meta_kubernetes_pod_label_(.+) - source_labels: [__meta_kubernetes_namespace]action: replacetarget_label: kubernetes_namespace- source_labels: [__meta_kubernetes_pod_name]# 修改标签action: replacetarget_label: kubernetes_pod_name- source_labels: [__meta_kubernetes_pod_label_pod_template_hash]regex: '(.*)' replacement: 'K8S-test' action: replacetarget_label: Env

Prometheus已经收集符合条件的6个pod,但状态都是down。还需要在pod安装Prometheus插件,监控才能正常显示。



相关内容

热门资讯

广东高考作文评分细则及(推荐... 广东高考作文评分细则及 篇一广东高考作文评分细则及 提高写作水平的方法作文是高考中的重要一环,它不仅...
高考志愿感谢信范文(精彩6篇... 高考志愿感谢信范文 篇一亲爱的老师/学长学姐:您好!我是您的学生/学弟学妹XXX。在即将迎来高考志愿...
高考满分议论文【精选6篇】 高考满分议论文 篇一高考满分,是每一个考生都梦寐以求的目标。然而,对于这个问题,社会上存在着两种不同...
高考优秀作文:怀想天空【优选... 高考优秀作文:怀想天空 篇一怀想天空每当我仰望蔚蓝的天空,心中总会涌起一股莫名的情感。那是一种对自由...
我爸是李刚高考作文【精彩3篇... 我爸是李刚高考作文 篇一我的爸爸是一位普通的工人,名叫李刚。他从小就告诉我,只有通过努力学习才能改变...
历年四川高考零分作文【精选3... 历年四川高考零分作文 篇一:一封给未来自己的信亲爱的未来的我:你好!我是现在的你,写这封信是希望能够...
浙江高考作文真题:长大【优选... 浙江高考作文真题:长大 篇一第一篇内容:回忆童年的快乐时光长大是每个人都必须经历的过程,它意味着离开...
海南异地高考(最新6篇) 海南异地高考 篇一海南异地高考是指海南省内的高中毕业生可以选择到国内其他省市参加高考。这一政策的出台...
高考满分作文:浅阅读与深阅读... 高考满分作文:浅阅读与深阅读 篇一浅阅读与深阅读:开启阅读的不同维度在当今信息爆炸的时代,人们对于阅...
江苏高考满分作文赏析:于无声... 江苏高考满分作文赏析:于无声处听惊雷 篇一江苏高考满分作文《于无声处听惊雷》以一个小故事为引子,讲述...
高考议论文经典作文素材【通用... 高考议论文经典作文素材 篇一标题:高考加分政策的利与弊高考作为一项重要的选拔性考试,对于每个考生来说...
高考后的自我感想作文【通用6... 高考后的自我感想作文 篇一高考是人生中一个重要的转折点,它不仅仅是一场考试,更是对自己的一个全面评价...
北京西城夜查大排档扰民 为高... 北京西城夜查大排档扰民 为高考保驾护航 篇一近年来,随着社会经济的快速发展,大排档经营现象在北京市西...
高考作文真题:坐在路边鼓掌的... 高考作文真题:坐在路边鼓掌的人 篇一当我们走在拥挤繁忙的城市街道上,常常可以看到一些人坐在路边鼓掌。...
高考英语高级词汇作文范文(优... 高考英语高级词汇作文范文 篇一Artificial Intelligence: Boon or Ba...
热点高考作文素材(最新6篇) 热点高考作文素材 篇一标题:网络教育的影响与挑战随着互联网的普及和技术的进步,网络教育作为一种新型的...
高考优秀作文(优质6篇) 高考优秀作文 篇一:《成长的烦恼与收获》近年来,高考成绩的重要性越来越被人们所关注,而高考也成为了学...
高考语文作文题目(实用3篇) 高考语文作文题目 篇一:文化传承与发展文化是一个国家和民族的精神财富,是一个民族的灵魂和根基。文化的...
高考作文范文感恩之情【优质6... 高考作文范文感恩之情 篇一感恩之情在高考中的重要性高考作为中国教育系统中的重要一环,是每一个学生都不...
优秀高考满分作文【优选6篇】 优秀高考满分作文 篇一:人工智能对人类社会的影响随着科技的不断发展,人工智能逐渐走进我们的生活,对人...