Skip to content

nserban/zabbix-cloudwatch

 
 

Repository files navigation

zabbix-cloudwatch

Amazon CloudWatch is a monitoring service for AWS cloud resources and the applications you run on AWS, which can be accessed from AWS console. We have now integrated CloudWatch monitoring data into Zabbix monitoring system.

AmazonCloudWatch Developer Guide - http://docs.aws.amazon.com/AmazonCloudWatch/latest/DeveloperGuide/supported_services.html

AWS SDK in Python Boto - https://github.com/boto/boto

Installation

  1. Install boto on zabbix server via pip.

    • pip install boto
  2. Create cloudwatch directory in "/opt/zabbix/cloudwatch" and do a git pull from this repository.

  3. Add AWS account credential to the configuration file "conf/awscred".

  4. Find the metrics from AmazonCloudWatch Developer Guide and add metrics to the configuration file "conf/aws_services_metrics.conf".

  5. Create a zabbix template for an AWS service, then create items with metrics key by using zabbix trapper type.

    Sample templates can be found in "templates" folder.

    AWS Metric Zabbix Trapper Item Key Format without Discovery.

    Key: <aws_service>.<metric>.<statistics>

    AWS Metric Zabbix Trapper Item Key Format with Discovery.

    Key: <aws_service>.<metric>.<statistics>["<aws_account>","<aws_region>","<discovery_item_value>"]

    DynamoDB Item Key Format is different from the standard setup, due to combinations of different dimensions and metrics.

    operations_all = ['GetItem', 'PutItem', 'Query', 'Scan', 'UpdateItem', 'DeleteItem', 'BatchGetItem', 'BatchWriteItem']

    operations_metrics = ['SuccessfulRequestLatency', 'SystemErrors', 'ThrottledRequests]

    DynamoDB Item Key1: DynamoDB.<operations_all>.<operations_metrics>.<statistics>["<aws_account>","<aws_region>","<table_name>"]

    operations_returned_item = ['Query', 'Scan']

    DynamoDB Item Key2: DynamoDB.<operations_returned_item>.ReturnedItemCount.<statistics>["<aws_account>","<aws_region>","<table_name>"]

    DynamoDB Other Keys: DynamoDB.<metric>.<statistics>["<aws_account>","<aws_region>","<table_name>"]

  6. Create a new host and linked with the template.

  7. Create a cloudwatch bash wrapper script for cron job.

    Sample cron jobs can be found in "cron.d" folder.

  8. Create a new cron job to send the cloudwatch metrics to the host.

    Sample crontab can be found in "cron.d" folder.


About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 82.2%
  • Shell 17.8%