Coder Social home page Coder Social logo

aws-check-tools's Introduction

aws-check-tools

概要

AWS環境の設定内容を確認する簡単なツールです。 コマンド実行後、OK/NGの数をカンマ区切りで出力します。

  • コマンド実行例
$ コマンド
OKカウント数,NGカウント数
$

この実行結果をMackerelのサービスメトリックに投稿し、可視化/監視するような利用方法を想定しています。(=Mackerelに投げつけるため、ビルドしたコマンドをbash等でラップする想定)

Check-CLB-RegisteredInstances

ELB(CLB)にEC2が紐付けられていればOKにカウント、1台もEC2が紐付けられていない場合はNGにカウント。

Check-Cloudwatch-EC2Alarm

引数に指定したEC2メトリックのCloudwatchアラームのステータスをOKの場合はOKにカウント、ALARMの場合はNGにカウント。

Check-EBS-AvailableVolume

availableのEBSボリュームをNGにカウント。available以外はOKにカウント。

Check-EBS-SnapshotAmi

AMI作成時に取得したSnapshotで、基となるAMIが存在しない場合はNGにカウント。 AMIが存在する場合はOKにカウント。

Check-EBS-SnapshotTag

引数に指定したタグがSnapshotに設定されていたらOKにカウント。設定されてなければNGにカウント。

Check-EBS-VolumeDeleteFlag

EBSボリュームの「Delete on Terminate」が設定されてなかったらNGにカウント。 設定されていればOKにカウント。

Check-EBS-VolumeTag

引数に指定したタグがEBSボリュームに設定されていたらOKにカウント。設定されてなければNGにカウント。

Check-EC2-LaunchTime

EC2のLaunchTimeが引数に指定した時刻より古ければNGにカウント。若ければOKにカウント。

Check-EC2-Tag

引数に指定したタグがEC2に設定されていたらOKにカウント。設定されてなければNGにカウント。

Check-EIP-Association

関連付けされていないEIPをNGにカウント。関連済みはOKにカウント。

ビルド

$ go get github.com/suzukiyuzs/aws-check-tools
$ cd $GOPATH/src/github.com/suzukiyuzs/aws-check-tools
$ cd << サブディレクトリ >>
$ go build .

※Check-EBS-SnapshotAmi/main.go, Check-EBS-SnapshotTag/main.goはビルド前にAWSアカウントIDの修正が必要。 ※リージョンをハードコーディングしているので「ap-northeast-1」以外の場合はregionの値も変更が必要です。

IAMポリシー

以下IAMポリシーをコマンド実行前に作成し、コマンド実行時のIAMユーザーに適用、またはインスタンスプロファイルに設定します。

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Effect": "Allow",
            "Action": [
                "ec2:DescribeImages",
                "elasticloadbalancing:DescribeLoadBalancers",
                "ec2:DescribeInstances",
                "ec2:DescribeAddresses",
                "ec2:DescribeVolumes",
                "cloudwatch:DescribeAlarms",
                "ec2:DescribeSnapshots"
            ],
            "Resource": "*"
        }
    ]
}

実行例

以下は、AWSのAccess Key、Secret Access Keyは「aws configure」で設定済みの環境を想定した実行例です。

Check-CLB-RegisteredInstances

$ ./Check-CLB-RegisteredInstances
20,4
$

Check-Cloudwatch-EC2Alarm

$ ./Check-Cloudwatch-EC2Alarm CPUUtilization
10,1
$

Check-EBS-AvailableVolume

$ ./Check-EBS-AvailableVolume
91,15
$

Check-EBS-SnapshotAmi

$ ./Check-EBS-SnapshotAmi
120,88
$

Check-EBS-SnapshotTag

./Check-EBS-SnapshotTag Name
6,210
$

Check-EBS-VolumeDeleteFlag

$ Check-EBS-VolumeDeleteFlag
90,1
$

Check-EBS-VolumeTag

./Check-EBS-VolumeTag Name
39,67
$

Check-EC2-LaunchTime

$ ./Check-EC2-LaunchTime 2018-12-01T00:00:00
63,18
$

Check-EC2-Tag

$ ./Check-EC2-Tag Stack
54,27
$

Check-EIP-Association

$ ./Check-EIP-Association
55,1
$

aws-check-tools's People

Contributors

suzukiyuzs avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.