Heapster是容器集群监控和性能分析工具,天然的支持Kubernetes和CoreOS。
Kubernetes有个出名的监控agent—cAdvisor。在每个kubernetes Node上都会运行cAdvisor,它会收集本机以及容器的监控数据(cpu,memory,filesystem,network,uptime)。
在较新的版本中,K8S已经将cAdvisor功能集成到kubelet组件中。每个Node节点可以直接进行web访问。
1、镜像下载
[root@k8s_master ~]# docker pull ist0ne/heapster-grafana-amd64
[root@k8s_master ~]# docker pull ist0ne/heapster-amd64
[root@k8s_master ~]# docker pull ist0ne/heapster-influxdb-amd64:v1.1.1
2、下载Heapster,最新版本1.3.0
wget https://github.com/kubernetes/heapster/archive/v1.3.0.tar.gz
tar zxf v1.3.0.tar.gz
3、进入heapster-1.3.0/deploy/kube-config/influxdb/目录
[[root@k8s_master heapster-1.3.0]# ls -latr deploy/kube-config/influxdb/
total 24
-rw-rw-r-- 1 root root 477 Mar 17 2017 influxdb-service.yaml
-rw-rw-r-- 1 root root 493 Mar 17 2017 influxdb-deployment.yaml
-rw-rw-r-- 1 root root 453 Mar 17 2017 heapster-service.yaml
-rw-rw-r-- 1 root root 521 Mar 17 2017 heapster-deployment.yaml
-rw-rw-r-- 1 root root 695 Mar 17 2017 grafana-service.yaml
-rw-rw-r-- 1 root root 1417 Mar 17 2017 grafana-deployment.yaml
4、修改配置文件对应的image:
grafana-deployment.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: monitoring-grafana
namespace: kube-system
spec:
replicas: 1
template:
metadata:
labels:
task: monitoring
k8s-app: grafana
spec:
containers:
- name: grafana
image: docker.io/ist0ne/heapster-grafana-amd64:latest
ports:
- containerPort: 3000
protocol: TCP
volumeMounts:
- mountPath: /var
name: grafana-storage
env:
- name: INFLUXDB_HOST
value: monitoring-influxdb
- name: GRAFANA_PORT
value: "3000"
# The following env variables are required to make Grafana accessible via
# the kubernetes api-server proxy. On production clusters, we recommend
# removing these env variables, setup auth for grafana, and expose the grafana
# service using a LoadBalancer or a public IP.
- 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
# If you're only using the API Server proxy, set this value instead:
# value: /api/v1/proxy/namespaces/kube-system/services/monitoring-grafana/
value: /
volumes:
- name: grafana-storage
emptyDir: {}
heapster-deployment.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: heapster
namespace: kube-system
spec:
replicas: 1
template:
metadata:
labels:
task: monitoring
k8s-app: heapster
spec:
containers:
- name: heapster
image: docker.io/ist0ne/heapster-amd64:latest
imagePullPolicy: IfNotPresent
command:
- /heapster
- --source=kubernetes:http://192.168.3.216:8080?inClusterConfig=false
- --sink=influxdb:http://monitoring-influxdb:8086
influxdb-deployment.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: monitoring-influxdb
namespace: kube-system
spec:
replicas: 1
template:
metadata:
labels:
task: monitoring
k8s-app: influxdb
spec:
containers:
- name: influxdb
image: docker.io/ist0ne/heapster-influxdb-amd64:v1.1.1
volumeMounts:
- mountPath: /data
name: influxdb-storage
volumes:
- name: influxdb-storage
emptyDir: {}
启动服务
[root@k8s_master heapster-1.3.0]# kubectl create -f deploy/kube-config/influxdb/
删除服务
[root@k8s_master heapster-1.3.0]# kubectl delete -f deploy/kube-config/influxdb/
查看pod
[root@k8s_master ~]# kubectl get pods --all-namespaces
NAMESPACE NAME READY STATUS RESTARTS AGE
default busybox 1/1 Running 93 3d
kube-system heapster-4127054459-wzppn 1/1 Running 0 3d
kube-system kube-dns-2074712928-dxv2q 4/4 Running 4 3d
kube-system kubernetes-dashboard-3665076642-9z0jc 1/1 Running 0 3d
kube-system monitoring-grafana-597639858-tqpf2 1/1 Running 0 3d
kube-system monitoring-influxdb-3575671003-9rpkh 1/1 Running 0 3d
web nginx-491251965-dp4xz 1/1 Running 2 4d
web nginx-491251965-rjhhp 1/1 Running 2 4d
打开浏览器http://192.168.3.216:8080/ui
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com