Создание экземпляра EC2 для VPC не разрешено

Можно ли определить VPCId для шаблона экземпляра EC2 как свойство?

Я пытаюсь сделать что-то вроде

"Resources" : {
"Ec2Instance" : {
  "Type" : "AWS::EC2::Instance",
  "Properties" : { 
    "SecurityGroups": [ { "Ref": "AWSSecurityGroups" } ],     
    "KeyName" : { "Ref" : "KeyName" },
    "InstanceType" : { "Ref" : "InstanceType" },
    "Tags" : [ { "Key" : "Name", "Value" : "Softnas-CF" }],
    "ImageId" : { "Fn::FindInMap" : [ "RegionMap", { "Ref" : "AWS::Region" }, "AMI" ]},
    "VpcId" :  { "Ref" : "VPCId" },     
   .....some other stuff...
},

В своих параметрах я определяю VPCId,

"Parameters" : {
....
"VPCId": {
   "Description": "Name of an existing VPC ID",
   "Type": "AWS::EC2::VPC::Id",
   "ConstraintDescription": "must be the name of an existing VPC Id."
},  
...

},

Но когда я создаю стек (через .net api), он откатывается с ошибкой

Обнаружено неподдерживаемое свойство VpcId

Разве это не разрешено, я не смог найти никакой документации для этого. Делаю это в качестве эксперимента. Всегда ли экземпляр EC2 создается в облаке VPC по умолчанию, если он создан с использованием шаблонов?


person Dhanuka777    schedule 06.04.2016    source источник


Ответы (2)


VpcId не поддерживается в Ec2Instance:Properties

Используйте SubnetId.

"Ec2Instance" : {
  "Type" : "AWS::EC2::Instance",
  "Properties" : {
    "SecurityGroupIds" : [ { "Ref" : "xxxxx" } ],
    "Tags" : [ { "Key" : "Name", "Value" : "xxx" } ],
    "ImageId" : { "Fn::FindInMap" : [ "RegionMap", { "Ref" : "AWS::Region" }, "AMI" ]},
    "SubnetId" : { "Ref" : "VpcSubnet" },
    "InstanceType"   : { "Ref" : "InstanceType" },
    ....

"VpcSubnet": {
  "Description" : "Enter the VPC subnet",
  "Type" : "AWS::EC2::Subnet::Id",
  "Default" : ""
},
person helloV    schedule 06.04.2016
comment
Для собственности? Я уже пробовал это и обновил вопрос. - person Dhanuka777; 06.04.2016

Вы не можете указать VPCId в качестве параметра, вместо этого вы можете назначить SubnetId (в VPC вам нужно, чтобы экземпляр EC2 был).

person Dhanuka777    schedule 06.04.2016
comment
Вот что говорит мой ответ. - person helloV; 06.04.2016