作者:吴龙辉 2015-08-10 14:41:39
云计算 监控是运维的根基,是非常重要的一环,对此Kubernete提供了平台本身以及应用的监控,本文介绍 Kubernetes中2个主要的监控模块cAdvisor 和Heapster 。

创新互联从2013年开始,是专业互联网技术服务公司,拥有项目网站制作、成都网站制作网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元荥经做网站,已为上家服务,为荥经各地企业和个人服务,联系电话:18982081108
Docker的流行激活了一直不温不火的PaaS,随着而来的是各类Micro-PaaS的出现,Kubernetes是其中***代表性的一员,它是Google多年大规模容器管理技术的开源版本。本系列文章将逐一分析Kubernetes,本文介绍 Kubernetes中2个主要的监控模块cAdvisor 和Heapster 。
Kubernetes监控
监控是运维的根基,是非常重要的一环,对此Kubernete提供了平台本身以及应用的监控,下图是Kubernete中监控的逻辑设计图:
cAdvisor
监控agent, 在每个Kubernetes Node上都会运行cAdvisor 。cadvisor 会收集本机以及容器的监控数据(CPU, memory, filesystem, and network usage statistics)。
在较新的Kubernetes版本里,cadvior功能已经被集成到了kubelet组件中。在Node节点上可以直接访问cadvisor 的界面:
也可以调用cadvisor 的API接口,参考:
https://github.com/google/cadv ... pi.md
下面是cadvisor 一条记录,可以看到统计的监控数据范围:
- {
 - "timestamp": "2015-08-06T16:26:14.407749377+08:00",
 - "cpu": {
 - "usage": {
 - "total": 9868208554,
 - "per_cpu_usage": [9868208554],
 - "user": 1850000000,
 - "system": 280000000
 - },
 - "load_average": 0
 - },
 - "diskio": {
 - "io_service_bytes": [{
 - "major": 253,
 - "minor": 7,
 - "stats": {
 - "Async": 13946880,
 - "Read": 13946880,
 - "Sync": 0,
 - "Total": 13946880,
 - "Write": 0
 - }
 - }],
 - "io_serviced": [{
 - "major": 253,
 - "minor": 7,
 - "stats": {
 - "Async": 369,
 - "Read": 369,
 - "Sync": 0,
 - "Total": 369,
 - "Write": 0
 - }
 - }]
 - },
 - "memory": {
 - "usage": 8548352,
 - "working_set": 4067328,
 - "container_data": {
 - "pgfault": 6462,
 - "pgmajfault": 132
 - },
 - "hierarchical_data": {
 - "pgfault": 6462,
 - "pgmajfault": 132
 - }
 - },
 - "network": {
 - "name": "",
 - "rx_bytes": 0,
 - "rx_packets": 0,
 - "rx_errors": 0,
 - "rx_dropped": 0,
 - "tx_bytes": 0,
 - "tx_packets": 0,
 - "tx_errors": 0,
 - "tx_dropped": 0
 - },
 - "task_stats": {
 - "nr_sleeping": 0,
 - "nr_running": 0,
 - "nr_stopped": 0,
 - "nr_uninterruptible": 0,
 - "nr_io_wait": 0
 - }
 - },
 
Heapster
Heapster 收集所有Kubernetes Node,然后汇总数据,然后可以导到第三方工具(如Influxdb)。
Heapster 可以以Pod的方式运行在Kubernetes平台里,也可以单独运行以standalone的方式。
使用Pod方式部署的话问题比较多,本文采用standalone方式部署。
- $ docker run -p 8082:8082 \
 - --add-host=node1:192.168.3.147 --add-host=node2:192.168.3.148 --add-host=node3:192.168.3.149 \
 - kubernetes/heapster:v0.15.0 \
 - --source=kubernetes:http://192.168.3.146:8080?inClusterConfig=false&useServiceAccount=false \
 - --sink=influxdb:http://10.254.209.104:8086
 
source用于配置监控来源,它支持的参数:
注意:--add-host主要是因为Heapster 会根据hostname去查询node的IP,参考:
https://github.com/GoogleCloud ... 62998
Heapster 运行后,可以在influxdb查询到数据,说明监控数据已经上报:
                本文名称:Kubernetes技术分析之监控
                
                标题网址:http://www.csdahua.cn/qtweb/news41/296091.html
            
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网