强烈推荐使用 GitHub 上的 monitoringartist/grafana-aws-cloudwatch-dashboards 仪表板。该 repo 有一系列 AWS 资源的仪表板,包括但不限于:
并且质量上乘,设计十分精良。
本文以其 AWS EC2 Dashboard (ID: 617) 为例说明。
📝Notes:
前提是你的 IAM Role 或 User 有对应的权限,即 上文 提到的:
"ec2:DescribeTags", "ec2:DescribeInstances", "ec2:DescribeRegions"
和"tag:GetResources"
的相关 Policy.
否则会出现类似Error updating options: Query data error
这样的报错。
相比 AWS Cloudwatch 数据源自带的仪表板,该仪表板优秀的地方在于使用了 ec2_instance_attribute
来查询获取变量。具体如下章介绍。
AWS 最常用的变量:region.
regions()
效果如下:
通过 ec2_instance_attribute 的查询,我们可以获取到更具有实际意义的 EC2 分组和 hostname, 而不是自带仪表板的一长串的非人记忆的 i-xxxxxxxx
EC2 id.
包括:
ec2_instance_attribute($region, Tags.Name, {})
*
如果需要复用 instancename, 可以通过如下方式复用:
ec2_instance_attribute($region, InstanceId, {"tag:Name": ["$instancename"]})
之后,可以根据 instanceid 查询获取 EC2 的 instance type, 以及 vlume 信息。
ec2_instance_attribute($region,InstanceType, {"instance-id": ["$instanceid"]})
ebs_volume_ids($region, $instanceid)
最终效果如下:
而关于详细完整的 ec2_instance_attribute
用法,可以参考这篇文档: