You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
165 lines
5.5 KiB
165 lines
5.5 KiB
{ |
|
"AWSTemplateFormatVersion" : "2010-09-09", |
|
|
|
"Description" : "A Database instance running a local MySQL server", |
|
|
|
"Parameters" : { |
|
|
|
"KeyName" : { |
|
"Description" : "Name of an existing EC2 KeyPair to enable SSH access to the instances", |
|
"Type" : "String" |
|
}, |
|
|
|
"InstanceType" : { |
|
"Description" : "Database server EC2 instance type", |
|
"Type" : "String", |
|
"AllowedValues" : [ "t1.micro", "m1.small", "m1.large", "m1.xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "c1.medium", "c1.xlarge", "cc1.4xlarge" ], |
|
"ConstraintDescription" : "must be a valid EC2 instance type." |
|
}, |
|
|
|
"DBName": { |
|
"Description" : "The database name", |
|
"Type": "String", |
|
"MinLength": "1", |
|
"MaxLength": "64", |
|
"AllowedPattern" : "[a-zA-Z][a-zA-Z0-9]*", |
|
"ConstraintDescription" : "must begin with a letter and contain only alphanumeric characters." |
|
}, |
|
|
|
"DBUsername": { |
|
"NoEcho": "true", |
|
"Description" : "The database admin account username", |
|
"Type": "String", |
|
"MinLength": "1", |
|
"MaxLength": "16", |
|
"AllowedPattern" : "[a-zA-Z][a-zA-Z0-9]*", |
|
"ConstraintDescription" : "must begin with a letter and contain only alphanumeric characters." |
|
}, |
|
|
|
"DBPassword": { |
|
"NoEcho": "true", |
|
"Description" : "The database admin account password", |
|
"Type": "String", |
|
"MinLength": "1", |
|
"MaxLength": "41", |
|
"AllowedPattern" : "[a-zA-Z0-9]*", |
|
"ConstraintDescription" : "must contain only alphanumeric characters." |
|
}, |
|
|
|
"DBRootPassword": { |
|
"NoEcho": "true", |
|
"Description" : "Root password for MySQL", |
|
"Type": "String", |
|
"MinLength": "1", |
|
"MaxLength": "41", |
|
"AllowedPattern" : "[a-zA-Z0-9]*", |
|
"ConstraintDescription" : "must contain only alphanumeric characters." |
|
}, |
|
"LinuxDistribution": { |
|
"Description" : "Distribution of choice", |
|
"Type": "String", |
|
"AllowedValues" : [ "F16", "F17", "U10", "RHEL-6.1", "RHEL-6.2", "RHEL-6.3" ] |
|
} |
|
}, |
|
|
|
"Mappings" : { |
|
"AWSInstanceType2Arch" : { |
|
"t1.micro" : { "Arch" : "32" }, |
|
"m1.small" : { "Arch" : "32" }, |
|
"m1.large" : { "Arch" : "64" }, |
|
"m1.xlarge" : { "Arch" : "64" }, |
|
"m2.xlarge" : { "Arch" : "64" }, |
|
"m2.2xlarge" : { "Arch" : "64" }, |
|
"m2.4xlarge" : { "Arch" : "64" }, |
|
"c1.medium" : { "Arch" : "32" }, |
|
"c1.xlarge" : { "Arch" : "64" }, |
|
"cc1.4xlarge" : { "Arch" : "64" } |
|
}, |
|
"DistroArch2AMI": { |
|
"F16" : { "32" : "F16-i386-cfntools", "64" : "F16-x86_64-cfntools" }, |
|
"F17" : { "32" : "F17-i386-cfntools", "64" : "F17-x86_64-cfntools" }, |
|
"U10" : { "32" : "U10-i386-cfntools", "64" : "U10-x86_64-cfntools" }, |
|
"RHEL-6.1" : { "32" : "rhel61-i386-cfntools", "64" : "rhel61-x86_64-cfntools" }, |
|
"RHEL-6.2" : { "32" : "rhel62-i386-cfntools", "64" : "rhel62-x86_64-cfntools" }, |
|
"RHEL-6.3" : { "32" : "rhel63-i386-cfntools", "64" : "rhel63-x86_64-cfntools" } |
|
} |
|
}, |
|
|
|
"Resources" : { |
|
"MySqlDatabaseServer": { |
|
"Type": "AWS::EC2::Instance", |
|
"Metadata" : { |
|
"AWS::CloudFormation::Init" : { |
|
"config" : { |
|
"packages" : { |
|
"yum" : { |
|
"mysql" : [], |
|
"mysql-server" : [] |
|
} |
|
}, |
|
"services" : { |
|
"systemd" : { |
|
"mysqld" : { "enabled" : "true", "ensureRunning" : "true" } |
|
} |
|
} |
|
} |
|
} |
|
}, |
|
"Properties": { |
|
"ImageId" : { "Fn::FindInMap" : [ "DistroArch2AMI", { "Ref" : "LinuxDistribution" }, |
|
{ "Fn::FindInMap" : [ "AWSInstanceType2Arch", { "Ref" : "InstanceType" }, "Arch" ] } ] }, |
|
"InstanceType" : { "Ref" : "InstanceType" }, |
|
"KeyName" : { "Ref" : "KeyName" }, |
|
"UserData" : { "Fn::Base64" : { "Fn::Join" : ["", [ |
|
"#!/bin/bash -v\n", |
|
|
|
"# Helper function\n", |
|
"function error_exit\n", |
|
"{\n", |
|
" /opt/aws/bin/cfn-signal -e 1 -r \"$1\" '", { "Ref" : "MySqlWaitHandle" }, "'\n", |
|
" exit 1\n", |
|
"}\n", |
|
|
|
"/opt/aws/bin/cfn-init -s ", { "Ref" : "AWS::StackName" }, |
|
" -r MySqlDatabaseServer ", |
|
" --region ", { "Ref" : "AWS::Region" }, |
|
" || error_exit 'Failed to run cfn-init'\n", |
|
|
|
"# Setup MySQL root password and create a user\n", |
|
"mysqladmin -u root password '", { "Ref" : "DBRootPassword" }, "'\n", |
|
"cat << EOF | mysql -u root --password='", { "Ref" : "DBRootPassword" }, "'\n", |
|
"CREATE DATABASE ", { "Ref" : "DBName" }, ";\n", |
|
"GRANT ALL PRIVILEGES ON ", { "Ref" : "DBName" }, ".* TO \"", { "Ref" : "DBUsername" }, "\"@\"%\"\n", |
|
"IDENTIFIED BY \"", { "Ref" : "DBPassword" }, "\";\n", |
|
"FLUSH PRIVILEGES;\n", |
|
"EXIT\n", |
|
"EOF\n", |
|
"# All is well so signal success\n", |
|
"/opt/aws/bin/cfn-signal -e 0 -r \"MySQL Database setup complete\" '", |
|
{ "Ref" : "MySqlWaitHandle" }, "'\n" |
|
]]}} |
|
} |
|
}, |
|
|
|
"MySqlWaitHandle" : { |
|
"Type" : "AWS::CloudFormation::WaitConditionHandle" |
|
}, |
|
|
|
"MySqlWaitCondition" : { |
|
"Type" : "AWS::CloudFormation::WaitCondition", |
|
"DependsOn" : "MySqlDatabaseServer", |
|
"Properties" : { |
|
"Handle" : {"Ref" : "MySqlWaitHandle"}, |
|
"Timeout" : "600" |
|
} |
|
} |
|
|
|
}, |
|
|
|
"Outputs" : { |
|
"PublicIp": { |
|
"Value": { "Fn::GetAtt" : [ "MySqlDatabaseServer", "PublicIp" ] }, |
|
"Description": "Database server IP" |
|
} |
|
} |
|
}
|
|
|