本文整理匯總了Python中troposphere.FindInMap方法的典型用法代碼示例。如果您正苦於以下問題:Python troposphere.FindInMap方法的具體用法?Python troposphere.FindInMap怎麽用?Python troposphere.FindInMap使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類troposphere
的用法示例。
在下文中一共展示了troposphere.FindInMap方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: create_autoscaling_group
# 需要導入模塊: import troposphere [as 別名]
# 或者: from troposphere import FindInMap [as 別名]
def create_autoscaling_group(self):
t = self.template
t.add_resource(
autoscaling.LaunchConfiguration(
"EmpireMinionLaunchConfig",
IamInstanceProfile=GetAtt("EmpireMinionProfile", "Arn"),
ImageId=FindInMap(
"AmiMap",
Ref("AWS::Region"),
Ref("ImageName")),
BlockDeviceMappings=self.build_block_device(),
InstanceType=Ref("InstanceType"),
KeyName=Ref("SshKeyName"),
UserData=self.generate_user_data(),
SecurityGroups=[Ref("DefaultSG"), Ref(CLUSTER_SG_NAME)]))
t.add_resource(
autoscaling.AutoScalingGroup(
"EmpireMinionAutoscalingGroup",
AvailabilityZones=Ref("AvailabilityZones"),
LaunchConfigurationName=Ref("EmpireMinionLaunchConfig"),
MinSize=Ref("MinHosts"),
MaxSize=Ref("MaxHosts"),
VPCZoneIdentifier=Ref("PrivateSubnets"),
Tags=[ASTag("Name", "empire_minion", True)]))
示例2: create_autoscaling_group
# 需要導入模塊: import troposphere [as 別名]
# 或者: from troposphere import FindInMap [as 別名]
def create_autoscaling_group(self):
t = self.template
t.add_resource(
autoscaling.LaunchConfiguration(
'BastionLaunchConfig',
AssociatePublicIpAddress=True,
ImageId=FindInMap(
'AmiMap', Ref("AWS::Region"), Ref("ImageName")),
InstanceType=Ref("InstanceType"),
KeyName=Ref("SshKeyName"),
UserData=self.generate_user_data(),
SecurityGroups=[Ref("DefaultSG"), Ref(CLUSTER_SG_NAME)]))
t.add_resource(
autoscaling.AutoScalingGroup(
'BastionAutoscalingGroup',
AvailabilityZones=Ref("AvailabilityZones"),
LaunchConfigurationName=Ref("BastionLaunchConfig"),
MinSize=Ref("MinSize"),
MaxSize=Ref("MaxSize"),
VPCZoneIdentifier=Ref("PublicSubnets"),
Tags=[ASTag('Name', 'bastion', True)]))
示例3: construct_network
# 需要導入模塊: import troposphere [as 別名]
# 或者: from troposphere import FindInMap [as 別名]
def construct_network(self):
"""
Main function to construct VPC, subnets, security groups, NAT instances, etc
"""
network_config = self.network_config
nat_config = self.nat_config
az_count = self.az_count
self.add_network_cidr_mapping(network_config=network_config)
self._prepare_subnets(self._subnet_configs)
self.create_network_components(network_config=network_config, nat_config=nat_config)
self._common_security_group = self.add_resource(ec2.SecurityGroup('commonSecurityGroup',
GroupDescription='Security Group allows ingress and egress for common usage patterns throughout this deployed infrastructure.',
VpcId=self.vpc_id,
SecurityGroupEgress=[ec2.SecurityGroupRule(
FromPort='80',
ToPort='80',
IpProtocol='tcp',
CidrIp='0.0.0.0/0'),
ec2.SecurityGroupRule(
FromPort='443',
ToPort='443',
IpProtocol='tcp',
CidrIp='0.0.0.0/0'),
ec2.SecurityGroupRule(
FromPort='123',
ToPort='123',
IpProtocol='udp',
CidrIp='0.0.0.0/0')],
SecurityGroupIngress=[
ec2.SecurityGroupRule(
FromPort='22',
ToPort='22',
IpProtocol='tcp',
CidrIp=FindInMap('networkAddresses', 'vpcBase', 'cidr'))]))
self.add_output(Output('commonSecurityGroup', Value=self.common_security_group))
示例4: add_nat_asg
# 需要導入模塊: import troposphere [as 別名]
# 或者: from troposphere import FindInMap [as 別名]
def add_nat_asg(self):
user_data = [resources.get_resource('nat_takeover.sh')]
if self.enable_ntp:
user_data.append(resources.get_resource('ntp_takeover.sh'))
if self.extra_user_data:
user_data.append(open(self.extra_user_data).read())
nat_asg_name = "Nat%sASG" % str(self.subnet_index)
user_data.extend([
"\n",
"cfn-signal -s true",
" --resource ", nat_asg_name,
" --stack ", {"Ref": "AWS::StackName"},
" --region ", {"Ref": "AWS::Region"}
])
nat_launch_config = self.add_resource(LaunchConfiguration(
"Nat%sLaunchConfig" % str(self.subnet_index),
UserData=Base64(Join('', user_data)),
ImageId=FindInMap('RegionMap', Ref('AWS::Region'), 'natAmiId'),
KeyName=Ref('ec2Key'),
SecurityGroups=[Ref(self.sg)],
EbsOptimized=False,
IamInstanceProfile=Ref(self.instance_profile),
InstanceType=self.instance_type,
AssociatePublicIpAddress=True
))
# Create the NAT in a public subnet
subnet_layer = self._subnets['public'].keys()[0]
nat_asg = self.add_resource(AutoScalingGroup(
nat_asg_name,
DesiredCapacity=1,
Tags=[
Tag("Name", Join("-", ["NAT", self.subnet_index,]), True),
Tag("isNat", "true", True)
],
MinSize=1,
MaxSize=1,
Cooldown="30",
LaunchConfigurationName=Ref(nat_launch_config),
HealthCheckGracePeriod=30,
HealthCheckType="EC2",
VPCZoneIdentifier=[self._subnets['public'][subnet_layer][self.subnet_index]],
CreationPolicy=CreationPolicy(
ResourceSignal=ResourceSignal(
Count=1,
Timeout='PT15M'
)
)
))
return nat_asg