Kubernetes集群监控
来源:互联网 发布:淘宝领取的优酷会员 编辑:程序博客网 时间:2024/06/05 20:07
1. 概述
1.1. cAdvisor
cAdvisor对Node机器上的资源及容器进行实时监控和性能数据采集,包括CPU使用情况、内存使用情况、网络吞吐量及文件系统使用情况,cAdvisor集成在Kubelet中,当kubelet启动时会自动启动cAdvisor,即一个cAdvisor仅对一台Node机器进行监控。kubelet的启动参数–cadvisor-port可以定义cAdvisor对外提供服务的端口,默认为4194。可以通过浏览器访问。项目主页:http://github.com/google/cadvisor。
更多可参考:http://blog.csdn.net/huwh_/article/details/77918507
1.2. Heapster
是对集群中的各个Node、Pod的资源使用数据进行采集,通过访问每个Node上Kubelet的API,再通过Kubelet调用cAdvisor的API来采集该节点上所有容器的性能数据。由Heapster进行数据汇聚,保存到后端存储系统中,例如InfluxDB,Google Cloud Logging等。项目主页为:https://github.com/kubernetes/heapster。
更多可参考:http://blog.csdn.net/huwh_/article/details/77899229
1.3. InfluxDB
是分布式时序数据库(每条记录带有时间戳属性),主要用于实时数据采集、事件跟踪记录、存储时间图表、原始数据等。提供REST API用于数据的存储和查询。项目主页为http://InfluxDB.com。
更多可参考:http://blog.csdn.net/huwh_/article/details/77899197
1.4. Grafana
通过Dashboard将InfluxDB的时序数据展现成图表形式,便于查看集群运行状态。项目主页为http://Grafana.org。
1.5. 总体架构图
其中当前Kubernetes中,Heapster、InfluxDB、Grafana均以Pod的形式启动和运行。Heapster与Master需配置安全连接。
2. 部署与使用
2.1. cAdvisor
kubelet的启动参数–cadvisor-port可以定义cAdvisor对外提供服务的端口,默认为4194。可以通过浏览器访问。也提供了REST API供客户端远程调用,API返回的格式为JSON,可以采用URL访问:http://:/api///
例如:http://14.152.49.100:4194/api/v1.3/machine 获取主机信息。
2.2. Service
2.2.1. heapster-service
heapster-service.yaml
apiVersion:v1kind:Servicemetadata: label: kubenetes.io/cluster-service:"true" kubernetes.io/name:Heapster name:heapster namespace:kube-systemspec: ports: - port:80 targetPort:8082 selector: k8s-app:heapster
2.2.2. influxdb-service
influxdb-service.yaml
apiVersion:v1kind:Servicemetadata: label:null name:monitoring-InfluxDB namespace:kube-systemspec: type:Nodeport ports: - name:http port:80 targetPort:8083 - name:api port:8086 targetPort:8086 Nodeport:8086 selector: name:influxGrafana
2.2.3. grafana-service
grafana-service.yaml
apiVersion:v1kind:Servicemetadata: label: kubenetes.io/cluster-service:"true" kubernetes.io/name:monitoring-Grafana name:monitoring-Grafana namespace:kube-systemspec: type:Nodeport ports: port:80 targetPort:8080 Nodeport:8085 selector: name:influxGrafana
使用type=NodePort将InfluxDB和Grafana暴露在Node的端口上,以便通过浏览器进行访问。
2.2.4. 创建service
kubectl create -f heapster-service.yamlkubectl create -f InfluxDB-service.yamlkubectl create -f Grafana-service.yaml
2.3. ReplicationController
2.3.1. influxdb-grafana-controller
influxdb-grafana-controller-v3.yaml
apiVersion:v1kind:ReplicationControllermetadata: name:monitoring-influxdb-grafana-v3 namespace:kube-system labels: k8s-app:influxGrafana version:v3 kubernetes.io/cluster-service:"truespec: replicas:1 selector: k8s-app:influxGrafana version:v3 template: metadata: labels: k8s-app:influxGrafana version:v3 kubernetes.io/cluster-service:"true spec: containers: - image:gcr.io/google_containers/heapster_influxdb:v0.5 name:influxdb resources: limits: cpu:100m memory:500Mi requests: cpu:100m memory:500Mi ports: - containerPort:8083 - containerPort:8086 volumeMounts: -name:influxdb-persistent-storage mountPath:/data - image:grc.io/google_containers/heapster_grafana:v2.6.0-2 name:grafana resources: limits: cpu:100m memory:100Mi requests: cpu:100m memory:100Mi env: - name:INFLUXDB_SERVICE_URL value:http://monitoring-influxdb:8086 - name:GF_AUTH_BASIC_ENABLED value:"false" - name:GF_AUTH_ANONYMOUS_ENABLED value:"true" - name:GF_AUTH_ANONYMOUS_ORG_ROLE value:Admin - name:GF_SERVER_ROOT_URL value:/api/v1/proxy/namespace/kube-system/services/monitoring-grafana/ volumeMounts: - name:grafana-persistent-storage mountPath:/var volumes: - name:influxdb-persistent-storage emptyDir{} - name:grafana-persistent-storage emptyDir{}
2.3.2. heapster-controller
heapster-controller.yaml
apiVersion:v1kind:ReplicationControllermetadata: labels: k8s-app:heapster name:heapster version:v6 name:heapster namespace:kube-systemspec: replicas:1 selector: name:heapster k8s-app:heapster version:v6 template: metadata: labels: k8s-app:heapster version:v6 spec: containers: - image:gcr.io/google_containers/heapster:v0.17.0 name:heapster command: - /heapster - --source=kubernetes:http://192.168.1.128:8080?inClusterConfig=flase&kubeletHttps=true&useServiceAccount=true&auth= - --sink=InfluxDB:http://monitoring-InfluxDB:8086
Heapster设置启动参数说明:
1、–source
配置监控来源,本例中表示从k8s-Master获取各个Node的信息。在URL的参数部分,修改kubeletHttps、inClusterConfig、useServiceAccount的值。
2、–sink
配置后端的存储系统,本例中使用InfluxDB。URL中主机名的地址是InfluxDB的Service名字,需要DNS服务正常工作,如果没有配置DNS服务可使用Service的ClusterIP地址。
2.3.3. 创建ReplicationController
kubelet create -f InfluxDB-Grafana-controller.yamlkubelet create -f heapster-controller.yaml
3. 查看界面及数据
3.1. InfluxDB
访问任意一台Node机器的30083端口。
3.2. Grafana
访问任意一台Node机器的30080端口。
4. 容器化部署
4.1. 拉取镜像
docker pull registry.wae.haplat.net/test/influxdb:1.0.0docker pull registry.wae.haplat.net/test/cadvisor:latestdocker pull registry.wae.haplat.net/test/grafana:latestdocker pull registry.wae.haplat.net/test/heapster:latest
4.2. 运行容器
4.2.1. influxdb
#influxdbdocker run -d -p 8083:8083 -p 8086:8086 --expose 8090 --expose 8099 --volume=/opt/data/influxdb:/data --name influxsrv registry.wae.haplat.net/test/influxdb:1.0.0
4.2.2. cadvisor
#cadvisordocker run --volume=/:/rootfs:ro --volume=/var/run:/var/run:rw --volume=/sys:/sys:ro --volume=/var/lib/docker/:/var/lib/docker:ro --publish=8080:8080 --detach=true --link influxsrv:influxsrv --name=cadvisor registry.wae.haplat.net/test/cadvisor:latest -storage_driver=influxdb -storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086
4.2.3. grafana
#grafanadocker run -d -p 3000:3000 -e INFLUXDB_HOST=influxsrv -e INFLUXDB_PORT=8086 -e INFLUXDB_NAME=cadvisor -e INFLUXDB_USER=root -e INFLUXDB_PASS=root --link influxsrv:influxsrv --name grafana registry.wae.haplat.net/test/grafana:latest
4.2.4. heapster
#heapsterdocker run -d -p 8082:8082 --net=host heapster:canary --source=kubernetes:http://<k8s-server-ip>:8080?inClusterConfig=false\&useServiceAccount=false --sink=influxdb:http://<influxdb-ip>:8086
4.3. 访问
在浏览器输入 IP:PORT
- Kubernetes集群监控
- 用 Prometheus 来监控你的 Kubernetes 集群
- kubernetes集群
- kubernetes学习记录(10)——建立Heapster+Influxdb+Grafana集群性能监控平台
- kubernetes 资源监控
- kubernetes监控--Prometheus
- kubernetes集群部署
- kubernetes-ubuntu集群部署
- 搭建kubernetes集群
- kubeadm 搭建 kubernetes 集群
- 部署kubernetes集群
- kubernetes 1.5 集群安装
- kubernetes 1.4 集群
- kubeadm 搭建 kubernetes 集群
- Kubernetes集群中的网络
- Centos7部署Kubernetes集群
- Kubernetes 集群安装指南
- kubernetes集群问题排查
- 第7章 Vue.js常用插件
- 克隆VMware虚拟机
- 最近项目用到Dubbo框架,临时抱佛脚分享一下共探讨
- 安卓ExpandableListView的简单使用
- 京东秋招笔试题汇总
- Kubernetes集群监控
- Semaphore Kernel Mode
- 用 JSON 来避免中文乱码问题
- 个人,eclipse配置备用
- 使用maven插件Tomcat7 启动成功但是404的问题
- JavaScript toLocaleString() 方法
- zigbee(题型整理1)
- iOS-图片拼接和图片旋转问题
- java基础学习之——子类重写(覆盖)父类的方法必须满足的条件