Kubernetes技术分析之监控

Kubernetes技术分析之监控

作者:吴龙辉 2015-08-10 14:41:39

云计算 监控是运维的根基,是非常重要的一环,对此Kubernete提供了平台本身以及应用的监控,本文介绍 Kubernetes中2个主要的监控模块cAdvisor 和Heapster 。

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 一条记录,可以看到统计的监控数据范围:

 

  1.         "timestamp""2015-08-06T16:26:14.407749377+08:00"
  2.         "cpu": { 
  3.             "usage": { 
  4.                 "total": 9868208554, 
  5.                 "per_cpu_usage": [9868208554], 
  6.                 "user": 1850000000, 
  7.                 "system": 280000000 
  8.             }, 
  9.             "load_average": 0 
  10.         }, 
  11.         "diskio": { 
  12.             "io_service_bytes": [{ 
  13.                 "major": 253, 
  14.                 "minor": 7, 
  15.                 "stats": { 
  16.                     "Async": 13946880, 
  17.                     "Read": 13946880, 
  18.                     "Sync": 0, 
  19.                     "Total": 13946880, 
  20.                     "Write": 0 
  21.                 } 
  22.             }], 
  23.             "io_serviced": [{ 
  24.                 "major": 253, 
  25.                 "minor": 7, 
  26.                 "stats": { 
  27.                     "Async": 369, 
  28.                     "Read": 369, 
  29.                     "Sync": 0, 
  30.                     "Total": 369, 
  31.                     "Write": 0 
  32.                 } 
  33.             }] 
  34.         }, 
  35.         "memory": { 
  36.             "usage": 8548352, 
  37.             "working_set": 4067328, 
  38.             "container_data": { 
  39.                 "pgfault": 6462, 
  40.                 "pgmajfault": 132 
  41.             }, 
  42.             "hierarchical_data": { 
  43.                 "pgfault": 6462, 
  44.                 "pgmajfault": 132 
  45.             } 
  46.         }, 
  47.         "network": { 
  48.             "name"""
  49.             "rx_bytes": 0, 
  50.             "rx_packets": 0, 
  51.             "rx_errors": 0, 
  52.             "rx_dropped": 0, 
  53.             "tx_bytes": 0, 
  54.             "tx_packets": 0, 
  55.             "tx_errors": 0, 
  56.             "tx_dropped": 0 
  57.         }, 
  58.         "task_stats": { 
  59.             "nr_sleeping": 0, 
  60.             "nr_running": 0, 
  61.             "nr_stopped": 0, 
  62.             "nr_uninterruptible": 0, 
  63.             "nr_io_wait": 0 
  64.         } 
  65.     }, 

 

Heapster

Heapster 收集所有Kubernetes Node,然后汇总数据,然后可以导到第三方工具(如Influxdb)。

Heapster 可以以Pod的方式运行在Kubernetes平台里,也可以单独运行以standalone的方式。

使用Pod方式部署的话问题比较多,本文采用standalone方式部署。

 

  1. $ docker run  -p 8082:8082 \ 
  2. --add-host=node1:192.168.3.147 --add-host=node2:192.168.3.148 --add-host=node3:192.168.3.149 \ 
  3. kubernetes/heapster:v0.15.0 \ 
  4. --source=kubernetes:http://192.168.3.146:8080?inClusterConfig=false&useServiceAccount=false \ 
  5. --sink=influxdb:http://10.254.209.104:8086  

 

source用于配置监控来源,它支持的参数:

  • inClusterConfig – Use kube config in service accounts associated with heapster’s namesapce. (default: true)
  • kubeletPort – kubelet port to use (default: 10255)
  • kubeletHttps – whether to use https to connect to kubelets (default: false)
  • apiVersion – API version to use to talk to Kubernetes. Defaults to the version in kubeConfig.
  • insecure – whether to trust kubernetes certificates (default: false)
  • auth – client auth file to use. Set auth if the service accounts are not usable.
  • useServiceAccount – whether to use the service account token if one is mounted at/var/run/secrets/kubernetes.io/serviceaccount/token (default: false)

注意:–add-host主要是因为Heapster 会根据hostname去查询node的IP,参考:

https://github.com/GoogleCloud … 62998

Heapster 运行后,可以在influxdb查询到数据,说明监控数据已经上报:

 

原文链接:http://www.dockone.io/article/569

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/292800.html<

(0)
运维的头像运维
上一篇2025-05-20 07:56
下一篇 2025-05-20 07:57

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注