builder/amazon/ebs: support launching in VPC
adds `vpc_id` and `subnet_id` to builder config depends on https://github.com/mitchellh/goamz/pull/4
This commit is contained in:
parent
38ae1a0ba9
commit
282554b2b0
|
@ -33,6 +33,8 @@ type config struct {
|
||||||
SSHUsername string `mapstructure:"ssh_username"`
|
SSHUsername string `mapstructure:"ssh_username"`
|
||||||
SSHPort int `mapstructure:"ssh_port"`
|
SSHPort int `mapstructure:"ssh_port"`
|
||||||
SecurityGroupId string `mapstructure:"security_group_id"`
|
SecurityGroupId string `mapstructure:"security_group_id"`
|
||||||
|
VpcId string `mapstructure:"vpc_id"`
|
||||||
|
SubnetId string `mapstructure:"subnet_id"`
|
||||||
|
|
||||||
// Configuration of the resulting AMI
|
// Configuration of the resulting AMI
|
||||||
AMIName string `mapstructure:"ami_name"`
|
AMIName string `mapstructure:"ami_name"`
|
||||||
|
|
|
@ -10,7 +10,11 @@ import (
|
||||||
func sshAddress(state map[string]interface{}) (string, error) {
|
func sshAddress(state map[string]interface{}) (string, error) {
|
||||||
config := state["config"].(config)
|
config := state["config"].(config)
|
||||||
instance := state["instance"].(*ec2.Instance)
|
instance := state["instance"].(*ec2.Instance)
|
||||||
return fmt.Sprintf("%s:%d", instance.DNSName, config.SSHPort), nil
|
if config.VpcId == "" {
|
||||||
|
return fmt.Sprintf("%s:%d", instance.DNSName, config.SSHPort), nil
|
||||||
|
} else {
|
||||||
|
return fmt.Sprintf("%s:%d", instance.PrivateIpAddress, config.SSHPort), nil
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func sshConfig(state map[string]interface{}) (*gossh.ClientConfig, error) {
|
func sshConfig(state map[string]interface{}) (*gossh.ClientConfig, error) {
|
||||||
|
|
|
@ -26,6 +26,7 @@ func (s *stepRunSourceInstance) Run(state map[string]interface{}) multistep.Step
|
||||||
MinCount: 0,
|
MinCount: 0,
|
||||||
MaxCount: 0,
|
MaxCount: 0,
|
||||||
SecurityGroups: []ec2.SecurityGroup{ec2.SecurityGroup{Id: securityGroupId}},
|
SecurityGroups: []ec2.SecurityGroup{ec2.SecurityGroup{Id: securityGroupId}},
|
||||||
|
SubnetId: config.SubnetId,
|
||||||
}
|
}
|
||||||
|
|
||||||
ui.Say("Launching a source AWS instance...")
|
ui.Say("Launching a source AWS instance...")
|
||||||
|
|
|
@ -29,7 +29,7 @@ func (s *stepSecurityGroup) Run(state map[string]interface{}) multistep.StepActi
|
||||||
ui.Say("Creating temporary security group for this instance...")
|
ui.Say("Creating temporary security group for this instance...")
|
||||||
groupName := fmt.Sprintf("packer %s", hex.EncodeToString(identifier.NewUUID().Raw()))
|
groupName := fmt.Sprintf("packer %s", hex.EncodeToString(identifier.NewUUID().Raw()))
|
||||||
log.Printf("Temporary group name: %s", groupName)
|
log.Printf("Temporary group name: %s", groupName)
|
||||||
groupResp, err := ec2conn.CreateSecurityGroup(groupName, "Temporary group for Packer")
|
groupResp, err := ec2conn.CreateSecurityGroup(ec2.SecurityGroup{Name: groupName, Description: "Temporary group for Packer", VpcId: config.VpcId})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ui.Error(err.Error())
|
ui.Error(err.Error())
|
||||||
return multistep.ActionHalt
|
return multistep.ActionHalt
|
||||||
|
|
|
@ -76,6 +76,12 @@ Optional:
|
||||||
before timing out. The format of this value is a duration such as "5s"
|
before timing out. The format of this value is a duration such as "5s"
|
||||||
or "5m". The default SSH timeout is "1m", or one minute.
|
or "5m". The default SSH timeout is "1m", or one minute.
|
||||||
|
|
||||||
|
* `subnet_id` (string) - If using VPC, the ID of the subnet, such as
|
||||||
|
"subnet-12345def", where Packer will launch the EC2 instance.
|
||||||
|
|
||||||
|
* `vpc_id` (string) - If launching into a VPC subnet, Packer needs the
|
||||||
|
VPC ID in order to create a temporary security group within the VPC.
|
||||||
|
|
||||||
## Basic Example
|
## Basic Example
|
||||||
|
|
||||||
Here is a basic example. It is completely valid except for the access keys:
|
Here is a basic example. It is completely valid except for the access keys:
|
||||||
|
|
Loading…
Reference in New Issue