187 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			187 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from __future__ import unicode_literals
 | 
						|
 | 
						|
template = {
 | 
						|
  "AWSTemplateFormatVersion": "2010-09-09",
 | 
						|
  "Parameters" : {
 | 
						|
    "DatabaseName" : {
 | 
						|
      "Description" : "The name of the first database to be created when the cluster is created",
 | 
						|
      "Type" : "String",
 | 
						|
      "Default" : "dev",
 | 
						|
      "AllowedPattern" : "([a-z]|[0-9])+"
 | 
						|
    },
 | 
						|
    "ClusterType" : {
 | 
						|
      "Description" : "The type of cluster",
 | 
						|
      "Type" : "String",
 | 
						|
      "Default" : "single-node",
 | 
						|
      "AllowedValues" : [ "single-node", "multi-node" ]
 | 
						|
    },
 | 
						|
    "NumberOfNodes" : {
 | 
						|
      "Description" : "The number of compute nodes in the cluster. For multi-node clusters, the NumberOfNodes parameter must be greater than 1",
 | 
						|
      "Type" : "Number",
 | 
						|
      "Default" : "1"
 | 
						|
    },
 | 
						|
    "NodeType" : {
 | 
						|
      "Description" : "The type of node to be provisioned",
 | 
						|
      "Type" : "String",
 | 
						|
      "Default" : "dw1.xlarge",
 | 
						|
      "AllowedValues" : [ "dw1.xlarge", "dw1.8xlarge", "dw2.large", "dw2.8xlarge" ]
 | 
						|
    },
 | 
						|
    "MasterUsername" : {
 | 
						|
      "Description" : "The user name that is associated with the master user account for the cluster that is being created",
 | 
						|
      "Type" : "String",
 | 
						|
      "Default" : "defaultuser",
 | 
						|
      "AllowedPattern" : "([a-z])([a-z]|[0-9])*"
 | 
						|
    },
 | 
						|
    "MasterUserPassword" :  {
 | 
						|
      "Description" : "The password that is associated with the master user account for the cluster that is being created.",
 | 
						|
      "Type" : "String",
 | 
						|
      "NoEcho" : "true"
 | 
						|
    },
 | 
						|
    "InboundTraffic" : {
 | 
						|
      "Description" : "Allow inbound traffic to the cluster from this CIDR range.",
 | 
						|
      "Type" : "String",
 | 
						|
      "MinLength": "9",
 | 
						|
      "MaxLength": "18",
 | 
						|
      "Default" : "0.0.0.0/0",
 | 
						|
      "AllowedPattern" : "(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})\\.(\\d{1,3})/(\\d{1,2})",
 | 
						|
      "ConstraintDescription" : "must be a valid CIDR range of the form x.x.x.x/x."
 | 
						|
    },
 | 
						|
    "PortNumber" : {
 | 
						|
      "Description" : "The port number on which the cluster accepts incoming connections.",
 | 
						|
      "Type" : "Number",
 | 
						|
      "Default" : "5439"
 | 
						|
    }
 | 
						|
  },
 | 
						|
  "Conditions" : {
 | 
						|
    "IsMultiNodeCluster" : {
 | 
						|
      "Fn::Equals" : [{ "Ref" : "ClusterType" }, "multi-node" ]
 | 
						|
    }
 | 
						|
  },
 | 
						|
  "Resources" : {
 | 
						|
    "RedshiftCluster" : {
 | 
						|
      "Type" : "AWS::Redshift::Cluster",
 | 
						|
      "DependsOn" : "AttachGateway",
 | 
						|
      "Properties" : {
 | 
						|
        "ClusterType" : { "Ref" : "ClusterType" },
 | 
						|
        "NumberOfNodes" : { "Fn::If" : [ "IsMultiNodeCluster",  { "Ref" : "NumberOfNodes" }, { "Ref" : "AWS::NoValue" }]},
 | 
						|
        "NodeType" : { "Ref" : "NodeType" },
 | 
						|
        "DBName" : { "Ref" : "DatabaseName" },
 | 
						|
        "MasterUsername" : { "Ref" : "MasterUsername" },
 | 
						|
        "MasterUserPassword" : { "Ref" : "MasterUserPassword" },
 | 
						|
        "ClusterParameterGroupName" : { "Ref" : "RedshiftClusterParameterGroup" },
 | 
						|
        "VpcSecurityGroupIds" : [ { "Ref" : "SecurityGroup" } ],
 | 
						|
        "ClusterSubnetGroupName" : { "Ref" : "RedshiftClusterSubnetGroup" },
 | 
						|
        "PubliclyAccessible" : "true",
 | 
						|
        "Port" : { "Ref" : "PortNumber" }
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "RedshiftClusterParameterGroup" : {
 | 
						|
      "Type" : "AWS::Redshift::ClusterParameterGroup",
 | 
						|
      "Properties" : {
 | 
						|
        "Description" : "Cluster parameter group",
 | 
						|
        "ParameterGroupFamily" : "redshift-1.0",
 | 
						|
        "Parameters" : [{
 | 
						|
          "ParameterName" : "enable_user_activity_logging",
 | 
						|
          "ParameterValue" : "true"
 | 
						|
        }]
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "RedshiftClusterSubnetGroup" : {
 | 
						|
      "Type" : "AWS::Redshift::ClusterSubnetGroup",
 | 
						|
      "Properties" : {
 | 
						|
        "Description" : "Cluster subnet group",
 | 
						|
        "SubnetIds" : [ { "Ref" : "PublicSubnet" } ]
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "VPC" : {
 | 
						|
      "Type" : "AWS::EC2::VPC",
 | 
						|
      "Properties" : {
 | 
						|
        "CidrBlock" : "10.0.0.0/16"
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "PublicSubnet" : {
 | 
						|
      "Type" : "AWS::EC2::Subnet",
 | 
						|
      "Properties" : {
 | 
						|
        "CidrBlock" : "10.0.0.0/24",
 | 
						|
        "VpcId" : { "Ref" : "VPC" }
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "SecurityGroup" : {
 | 
						|
      "Type" : "AWS::EC2::SecurityGroup",
 | 
						|
      "Properties" : {
 | 
						|
        "GroupDescription" : "Security group",
 | 
						|
        "SecurityGroupIngress" : [ {
 | 
						|
          "CidrIp" : { "Ref": "InboundTraffic" },
 | 
						|
          "FromPort" : { "Ref" : "PortNumber" },
 | 
						|
          "ToPort" : { "Ref" : "PortNumber" },
 | 
						|
          "IpProtocol" : "tcp"
 | 
						|
        } ],
 | 
						|
        "VpcId" : { "Ref" : "VPC" }
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "myInternetGateway" : {
 | 
						|
      "Type" : "AWS::EC2::InternetGateway"
 | 
						|
    },
 | 
						|
    "AttachGateway" : {
 | 
						|
      "Type" : "AWS::EC2::VPCGatewayAttachment",
 | 
						|
      "Properties" : {
 | 
						|
        "VpcId" : { "Ref" : "VPC" },
 | 
						|
        "InternetGatewayId" : { "Ref" : "myInternetGateway" }
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "PublicRouteTable" : {
 | 
						|
      "Type" : "AWS::EC2::RouteTable",
 | 
						|
      "Properties" : {
 | 
						|
        "VpcId" : {
 | 
						|
          "Ref" : "VPC"
 | 
						|
        }
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "PublicRoute" : {
 | 
						|
      "Type" : "AWS::EC2::Route",
 | 
						|
      "DependsOn" : "AttachGateway",
 | 
						|
      "Properties"  : {
 | 
						|
        "RouteTableId" : {
 | 
						|
          "Ref" : "PublicRouteTable"
 | 
						|
        },
 | 
						|
        "DestinationCidrBlock" : "0.0.0.0/0",
 | 
						|
        "GatewayId" : {
 | 
						|
          "Ref" : "myInternetGateway"
 | 
						|
        }
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "PublicSubnetRouteTableAssociation" : {
 | 
						|
      "Type" : "AWS::EC2::SubnetRouteTableAssociation",
 | 
						|
      "Properties" : {
 | 
						|
        "SubnetId" : {
 | 
						|
          "Ref" : "PublicSubnet"
 | 
						|
        },
 | 
						|
        "RouteTableId" : {
 | 
						|
          "Ref" : "PublicRouteTable"
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
  },
 | 
						|
  "Outputs" : {
 | 
						|
    "ClusterEndpoint" : {
 | 
						|
      "Description" : "Cluster endpoint",
 | 
						|
      "Value" : { "Fn::Join" : [ ":", [ { "Fn::GetAtt" : [ "RedshiftCluster", "Endpoint.Address" ] }, { "Fn::GetAtt" : [ "RedshiftCluster", "Endpoint.Port" ] } ] ] }
 | 
						|
    },
 | 
						|
    "ClusterName" : {
 | 
						|
      "Description" : "Name of cluster",
 | 
						|
      "Value" : { "Ref" : "RedshiftCluster" }
 | 
						|
    },
 | 
						|
    "ParameterGroupName" : {
 | 
						|
      "Description" : "Name of parameter group",
 | 
						|
      "Value" : { "Ref" : "RedshiftClusterParameterGroup" }
 | 
						|
    },
 | 
						|
    "RedshiftClusterSubnetGroupName" : {
 | 
						|
      "Description" : "Name of cluster subnet group",
 | 
						|
      "Value" : { "Ref" : "RedshiftClusterSubnetGroup" }
 | 
						|
    },
 | 
						|
    "RedshiftClusterSecurityGroupName" : {
 | 
						|
      "Description" : "Name of cluster security group",
 | 
						|
      "Value" : { "Ref" : "SecurityGroup" }
 | 
						|
    }
 | 
						|
  }
 | 
						|
} |