aws(学习笔记第三课) AWS CloudFormation

aws(学习笔记第三课)

  • 使用AWS CloudFormation

学习内容:

  • AWS CloudFormation的模板解析
  • 使用AWS CloudFormation启动ec2 server

1. AWS CloudFormation 的模版解析

  1. CloudFormation模板结构
    CloudFormationAWS的配置管理工具,属于Infrastructure as Code, IaC。基础设施即代码(Infrastructure as Code, IaC)是一种管理和配置计算机基础设施(如服务器、网络、存储等)的方法,通过编写代码来自动化这些过程,而不是手动进行配置。IaC 使得基础设施管理更为自动化、可重复、可靠和高效。

    json 复制代码
    {
        "AWSTemplateFormatVersion":"2010-09-09",
        "Description":"CloudFormation template structure",
        "Parameters":{
            [...]
        },
        "Resources":{
            [...]
        },
        "Outputs":{
            [...]
        }
    }

    大体分为,

    • 版本 "2010-09-09"是目前的唯一合法版本
    • 描述 这个模板是关于什么的
    • 参数 参数使用值用来定义模板。例如,域名,客户ID和数据库密码等。
    • 资源 资源是用户能描述的AWS最小组件,例如,虚拟服务器,负载均衡器或者弹性IP地址。
    • 输出 输出和参数有点像,输出从模板返回的信息。

2. CloudFormation参数类型

类型 描述
String CommaDelimitedList 一个字符串或有都好分割的字符串列表
Number List<Number> 一个整数或浮点数或整数列表或浮点数列表
AWS::EC2::Instance::Id List<AWS::EC2::Instance::Id> 一个EC2实例ID或列表
AWS::EC2::Image::Id List<AWS::EC2::Image::Id> 一个AMI ID或列表
AWS::EC2::KeyPair::KeyName 一个Amazon EC2密钥对名
AWS::EC2::SecurityGroup::Id <List>AWS::EC2::SecurityGroup::Id 一个安全组ID或列表

3. CloudFormation的具体实例

  1. 实例代码

    json 复制代码
    {
    	"AWSTemplateFormatVersion": "2010-09-09",
    	"Description": "AWS cloudformation practice",
    	"Parameters": {
    		"KeyName": {
    			"Description": "Key Pair name",
    			"Type": "AWS::EC2::KeyPair::KeyName",
    			"Default": "my-cli-key"
    		},
    		"VPC": {
    			"Description": "Just select the one and only default VPC",
    			"Type": "AWS::EC2::VPC::Id"
    		},
    		"Subnet": {
    			"Description": "Just select one of the available subnets",
    			"Type": "AWS::EC2::Subnet::Id"
    		},
    		"InstanceType": {
    			"Description": "Select one of the possible instance types",
    			"Type": "String",
    			"Default": "t2.micro",
    			"AllowedValues": ["t2.micro", "t2.small", "t2.medium"]
    		}
    	},
    	"Mappings": {
    		"EC2RegionMap": {
    			"ap-northeast-1": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-cbf90ecb"},
    			"ap-southeast-1": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-68d8e93a"},
    			"ap-southeast-2": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-fd9cecc7"},
    			"eu-central-1": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-a8221fb5"},
    			"eu-west-1": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-a10897d6"},
    			"sa-east-1": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-b52890a8"},
    			"us-east-1": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-1ecae776"},
    			"us-west-1": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-d114f295"},
    			"us-west-2": {"AmazonLinuxAMIHVMEBSBacked64bit": "ami-e7527ed7"}
    		}
    	},
    	"Resources": {
    		"SecurityGroup": {
    			"Type": "AWS::EC2::SecurityGroup",
    			"Properties": {
    				"GroupDescription": "My security group",
    				"VpcId": {"Ref": "VPC"},
    				"SecurityGroupIngress": [{
    					"CidrIp": "0.0.0.0/0",
    					"FromPort": 22,
    					"IpProtocol": "tcp",
    					"ToPort": 22
    				}]
    			}
    		},
    		"Server": {
    			"Type": "AWS::EC2::Instance",
    			"Properties": {
    				"ImageId": {"Fn::FindInMap": ["EC2RegionMap", {"Ref": "AWS::Region"}, "AmazonLinuxAMIHVMEBSBacked64bit"]},
    				"InstanceType": {"Ref": "InstanceType"},
    				"KeyName": {"Ref": "KeyName"},
    				"SecurityGroupIds": [{"Ref": "SecurityGroup"}],
    				"SubnetId": {"Ref": "Subnet"}
    			}
    		}
    	},
    	"Outputs": {
    		"PublicName": {
    			"Value": {"Fn::GetAtt": ["Server", "PublicDnsName"]},
    			"Description": "Public name (connect via SSH as user ec2-user)"
    		}
    	}
    }
  2. 为堆栈执行创建role

    • step1
    • step2
    • step3
      权限策略选择AdministratorAccess
    • step4
  3. 建立堆栈执行CloudFormation

    • step1
    • step2
    • step3
    • step4
    • step5
      最后点击提交
  4. 查看CloudFormation执行结果

    • 执行结果如下
      成功的话,会出现``CREATE_COMPLETE。
    • 查看ec2 server
    • 查看CloudFormationOutputs
    • 登录CloudFormation创建的ec2 server
  5. CloudFormation执行结果清理
    CloudFormation属于整体执行,执行清理,如果不想使用该stack,那么删除这个stack,这个stack创建的所有resources将全部被删除。

相关推荐
xiaobai17818 小时前
测试工程师入门AI技术 - 前序:跨越焦虑,从优势出发开启学习之旅
人工智能·学习
北岛寒沫18 小时前
北京大学国家发展研究院 经济学原理课程笔记(第二十一课 金融学基础)
经验分享·笔记·学习
扑火的小飞蛾18 小时前
网络安全小白学习路线图 (基于提供文档库)
学习·安全·web安全
优雅的潮叭18 小时前
c++ 学习笔记之 malloc
c++·笔记·学习
薛不痒20 小时前
深度学习之优化模型(数据预处理,数据增强,调整学习率)
深度学习·学习
昵称已被吞噬~‘(*@﹏@*)’~20 小时前
【RL+空战】学习记录03:基于JSBSim构造简易空空导弹模型,并结合python接口调用测试
开发语言·人工智能·python·学习·深度强化学习·jsbsim·空战
我想我不够好。21 小时前
学到的知识点 1.8
学习
李派森21 小时前
软考高项(信息系统项目管理师)—第4章 信息系统管理全解析
笔记·计算机网络
旖旎夜光21 小时前
Linux(9)
linux·学习
浩瀚地学1 天前
【Java】常用API(二)
java·开发语言·经验分享·笔记·学习