写点什么

Collectd 的 Amazon CloudWatch 插件

  • 2019-11-12
  • 本文字数:3554 字

    阅读完需:约 12 分钟

Collectd的Amazon CloudWatch插件

原文:https://aws.amazon.com/blogs/aws/new-cloudwatch-plugin-for-collectd/


作者:Jeff Barr




我在 2011 年已介绍过 Cloud Watch 的特性,“您可以在 Cloud Watch 中查看图表、设置告警、并根据这些指标启动自动化操作,所使用的这些 AWS 资源指标会被存储于 Cloud Watch 中 。”您目前已有能力在Amazon Cloud Watch中存储一段时间范围内的业务、应用及系统的指标数据(参阅“Amazon Cloud Watch定制新指标”了解更多信息)。


今天我们将简化系统统计信息的采集过程,使用一个新的 CloudWatch plug for colletd将采集数据发送至 CloudWatch 中 。并通过collectd 多种类型信息的统计采集能力与 cloudwatch 存储、展示、警报和告警的功能的整合,您可以更好地获取 EC2 实例、本地硬件以及运行于其上应用程序的运行状态及其性能信息。该插件已经作为一个开源项目发布,我们期待您的反馈。


Collectd 守护进程采用 C 语言编写,具有高性能和可移植性。它支持上百个插件 ,允许您收集有关ApacheNginx Web 服务器性能统计数据、memory usage uptime等信息。

安装与配置

为了演示这些功能,我在 EC2 实例上安装并配置了 Collectd 服务及新 Cloudwatch 插件。


首先我创建了一条 IAM 策略,它具备将指标数据写入 CloudWatch 的权限:



然后我创建了一个 IAM 角色,允许 EC2(运行 collectd 程序的实例)使用上述所建的策略:



如果我计划使用 Collectd 插件从本地服务器或运行中的 EC2 实例收集统计信息,那请跳过这些步骤,采用创建一个具有适当权限的 IAM 用户作为替代方法。在我完成上述工作后,会将该用户的证书放在本地服务器或 EC2 实例中。


在策略和角色配置完毕后,选择该角色来启动一个 EC2 实例



登录并安装 Collectd :


Bash


$ sudo yum -y install collectd
复制代码


然后获取插件和安装脚本,设置脚本为可执行,并运行该脚本:


Bash


$ chmod a+x setup.py
$ sudo ./setup.py
复制代码


回答一些交互问题确认安装过程无误,在完成配置之后就可启动 Collectd :


Bash


Installing dependencies ... OK
Installing python dependencies ... OK
Copying plugin tar file ... OK
Extracting plugin ... OK
Moving to collectd plugins directory ... OK
Copying CloudWatch plugin include file ... OK
Choose AWS region for published metrics:
1. Automatic [us-east-1]
2. Custom
Enter choice [1]: 1
Choose hostname for published metrics:
1. EC2 instance id [i-057d2ed2260c3e251]
2. Custom
Enter choice [1]: 1
Choose authentication method:
1. IAM Role [Collectd_PutMetricData]
2. IAM User
Enter choice [1]: 1
Choose how to install CloudWatch plugin in collectd:
1. Do not modify existing collectd configuration
2. Add plugin to the existing configuration
Enter choice [2]: 2
Plugin configuration written successfully.
Stopping collectd process ... NOT OK
Starting collectd process ... OK
$
复制代码


在 Collectd 运行并且插件安装配置完成后,下一步是确定感兴趣的统计信息,并配置插件将它们发布至 CloudWatch 中(每个指标的采集成本也是一个需考虑因素)。


文件/opt/collectd-plugins/cloudwatch/config/blocked_metrics 包含已收集但尚未发布到 CloudWatch 的指标列表:


Bash


$ cat /opt/collectd-plugins/cloudwatch/config/blocked_metrics
# This file is automatically generated - do not modify this file.
# Use this file to find metrics to be added to the whitelist file instead.
cpu-0-cpu-user
cpu-0-cpu-nice
cpu-0-cpu-system
cpu-0-cpu-idle
cpu-0-cpu-wait
cpu-0-cpu-interrupt
cpu-0-cpu-softirq
cpu-0-cpu-steal
interface-lo-if_octets-
interface-lo-if_packets-
interface-lo-if_errors-
interface-eth0-if_octets-
interface-eth0-if_packets-
interface-eth0-if_errors-
memory--memory-used
load--load-
memory--memory-buffered
memory--memory-cached
复制代码


如您对内存消耗关注,可添加了一行到


/opt/collectd-plugins/cloudwatch/config/whitelist.conf


Bash


memory--memory-.*
复制代码


Collectd 配置文件(/etc/collectd.conf)中包含 Collectd 附加设置及插件设置。不需要做任何修改。


重新启动 Collectd,以便所做的调整生效:


Bash


$ sudo service collectd restart
复制代码


为了模拟内存消耗,可执行了一些消耗内存的程序,然后打开 CloudWatch Console 来查找并显示自定义指标:



该截图包括了对 CloudWatch 控制台即将推出增强功能的预览;如果看起来不一致也不必担心(请关注获取更多信息)。


如果监控一个生产实例,您还可以安装更多 Collectd 插件。以下是 Amazon Linux AMI 可用插件列表:


Bash


$ sudo yum list | grep collectdcollectd.x86_64                        5.4.1-1.11.amzn1               @amzn-main
collectd-amqp.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-apache.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-bind.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-curl.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-curl_xml.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-dbi.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-dns.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-email.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-generic-jmx.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-gmond.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-ipmi.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-iptables.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-ipvs.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-java.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-lvm.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-memcachec.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-mysql.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-netlink.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-nginx.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-notify_email.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-postgresql.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-rrdcached.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-rrdtool.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-snmp.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-varnish.x86_64 5.4.1-1.11.amzn1 amzn-main
collectd-web.x86_64 5.4.1-1.11.amzn1 amzn-main
复制代码

需了解事项

如果您使用的是 5.5 或更新版本的 Collectd ,则会在默认情况下发布四个指标:


  • df-root-percent_bytes-used – disk utilization

  • memory–percent-used – memory utilization

  • swap–percent-used – swap utilization

  • cpu–percent-active – cpu utilization


如果您不希望发布它们,您可以从 whitelist.conf 文件中删除这些指标。


在 Amazon Linux AMI,Ubuntu,RHEL 和 CentOS 的软件仓库中,目前提供了较旧版本的 Collectd; 如果从源代码或自定义 repo 进行构建安装,请注意默认行为的变化。

更多

除了本次所展示的内容外, 您可以安装更多的插件,然后配置 whitelist.conf 来向 CloudWatch 发布更多的指标。同时您可以创建CloudWatch警报 ,自定义仪表盘等。


要开始使用,请访问AWS Lab on GitHub,并下载collectd plugin for CloudWatch


译者介绍



倪晓峻,AWS 专业服务顾问,负责基于 AWS 云计算项目的咨询和设计,具有超过十五年以上企业客户服务经验,致力于 AWS 服务在国内和全球的项目实施。在企业级解决方案,混合云架构,运营集成等领域有着广泛的设计与实践经验。在加入 AWS 之前曾任职 VMware;HPE 专业服务顾问,从事云计算/虚拟化架构设计及运维咨询工作,两次获得省部级科技进步奖励,参与 OGC ITIL V3 中文版的审定工作 。


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/new-cloudwatch-plugin-for-collectd/


2019-11-12 08:00712

评论

发布
暂无评论
发现更多内容

Vite + Vue3 + OpenLayers 同步两个地图基础操作

德育处主任

大前端 Web 地图 vite openlayers

redis--数据库实现

en

直播报名 | 超低延时直播架构解析

百度开发者中心

最佳实践 方法论 活动 直播

我的9年开源之路:395 Patch、20+Feature,背后只有努力与热爱

腾源会

腾讯云 开源 虚拟化 Linux内核 kvm

与顶级互联网公司技术大佬面对面聊聊RocketMQ吧!

阿里巴巴中间件

阿里云 开源 RocketMQ 云原生 中间件

一朵云、一张网、一体化 ——GRTN 打造最佳流媒体场景实践

阿里云CloudImagine

云计算 阿里云 边缘计算 视频云 流媒体传输

大众汽车迟到的软件优先思维

SOA开发者

丧心病狂!阿里内部Spring Cloud高薪笔记流失,GitHub夜获星百万

Java 程序员 面试 计算机 阿里巴巴‘

2021下半年全新京东商城亿级并发架构设计,不学习你就OUT了!!

Java 程序员 面试 计算机 京东

残疾人大学生就业难?「低代码」应用,让就业更简单!

优秀

低代码

云信小课堂 | 聊天室内容审核很头疼?3步解决!

网易云信

人工智能 AI 视频

T-BOX专业分享

SOA开发者

Alibaba竟流出全套的Java核心技术手册,看过的人都说好!

Java 程序员 架构 面试 计算机

Webrtc ICE 框架

webrtc developer

WebRTC p2p ICE

数字化的田亩里,华为正写一首陶渊明的诗

脑极体

Nebula Graph 源码解读系列 | Vol.01 Nebula Graph Overview

NebulaGraph

从技术到商业:2021 DEMO CHINA创新中国峰会正式开启

创业邦

阿里独家!GitHub上点击量超百万的「操作系统和计算机网络」PDF震撼开源

Java 程序员 面试 计算机 Alibaba

如何用时序数据库 CTSDB 与 TARS 结合,解决海量监控数据难题

腾源会

数据库 大数据 开源 TARS CTSDB

首个RISC-V计算机芯片现身欧洲处理器计划

BeeWorks

这本Alibaba“绝密”SpringBoot精髓到底厉害在哪里

Java 程序员 面试 springboot 计算机

被 Docker 日志坑惨了

AlwaysBeta

Docker 容器 运维

工业互联网的两种极端想法和两点反思

iNeuOS工业互联网操作系统

大数据 物联网 智能制造 iNeuOS工业互联网

【重磅】Apache InLong(incubating) 发布 0.10.0 版本

腾源会

Apache 开源 InLong

Micro Focus 发布年度安全运营报告,洞察后疫情时代企业安全运营新趋势

如何高效掌控K8s资源变化?K8s Informer实现机制浅析

腾源会

云原生 k8s

DPDK分析学习之全网唯一的DPDK教学课程丨虚拟化高性能专家之路

Linux服务器开发

网络协议 虚拟化 Linux服务器开发 DPDK 高性能网络

中小企业自媒体为何难做:定位不准期望值过高

石头IT视角

如何做竞品分析?

石云升

产品经理 产品思维 9月日更 产品分析

自建开源Cassandra与GaussDB(for Cassandra)性能对比测试报告

华为云数据库小助手

性能分析 GaussDB 华为云数据库 GaussDB(for Cassandra) 开源Cassandra

支持 10 亿日流量的基础设施:当 Apahce APISIX 遇上腾讯

腾源会

腾讯云 开源 APISIX OTeam

Collectd的Amazon CloudWatch插件_其他_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章