Merge pull request #6872 from aspectcapital/disable-ena-support
Add support to explicitly disable ENA support
This commit is contained in:
commit
9573013d3a
|
@ -14,7 +14,7 @@ import (
|
||||||
// StepRegisterAMI creates the AMI.
|
// StepRegisterAMI creates the AMI.
|
||||||
type StepRegisterAMI struct {
|
type StepRegisterAMI struct {
|
||||||
RootVolumeSize int64
|
RootVolumeSize int64
|
||||||
EnableAMIENASupport bool
|
EnableAMIENASupport *bool
|
||||||
EnableAMISriovNetSupport bool
|
EnableAMISriovNetSupport bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ func (s *StepRegisterAMI) Run(ctx context.Context, state multistep.StateBag) mul
|
||||||
// As of February 2017, this applies to C3, C4, D2, I2, R3, and M4 (excluding m4.16xlarge)
|
// As of February 2017, this applies to C3, C4, D2, I2, R3, and M4 (excluding m4.16xlarge)
|
||||||
registerOpts.SriovNetSupport = aws.String("simple")
|
registerOpts.SriovNetSupport = aws.String("simple")
|
||||||
}
|
}
|
||||||
if s.EnableAMIENASupport {
|
if s.EnableAMIENASupport != nil && *s.EnableAMIENASupport {
|
||||||
// Set EnaSupport to true
|
// Set EnaSupport to true
|
||||||
// As of February 2017, this applies to C5, I3, P2, R4, X1, and m4.16xlarge
|
// As of February 2017, this applies to C5, I3, P2, R4, X1, and m4.16xlarge
|
||||||
registerOpts.EnaSupport = aws.Bool(true)
|
registerOpts.EnaSupport = aws.Bool(true)
|
||||||
|
|
|
@ -19,7 +19,7 @@ type AMIConfig struct {
|
||||||
AMIRegions []string `mapstructure:"ami_regions"`
|
AMIRegions []string `mapstructure:"ami_regions"`
|
||||||
AMISkipRegionValidation bool `mapstructure:"skip_region_validation"`
|
AMISkipRegionValidation bool `mapstructure:"skip_region_validation"`
|
||||||
AMITags TagMap `mapstructure:"tags"`
|
AMITags TagMap `mapstructure:"tags"`
|
||||||
AMIENASupport bool `mapstructure:"ena_support"`
|
AMIENASupport *bool `mapstructure:"ena_support"`
|
||||||
AMISriovNetSupport bool `mapstructure:"sriov_support"`
|
AMISriovNetSupport bool `mapstructure:"sriov_support"`
|
||||||
AMIForceDeregister bool `mapstructure:"force_deregister"`
|
AMIForceDeregister bool `mapstructure:"force_deregister"`
|
||||||
AMIForceDeleteSnapshot bool `mapstructure:"force_delete_snapshot"`
|
AMIForceDeleteSnapshot bool `mapstructure:"force_delete_snapshot"`
|
||||||
|
|
|
@ -3,6 +3,7 @@ package common
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go/aws"
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
"github.com/aws/aws-sdk-go/service/ec2"
|
"github.com/aws/aws-sdk-go/service/ec2"
|
||||||
|
@ -11,7 +12,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type StepModifyEBSBackedInstance struct {
|
type StepModifyEBSBackedInstance struct {
|
||||||
EnableAMIENASupport bool
|
EnableAMIENASupport *bool
|
||||||
EnableAMISriovNetSupport bool
|
EnableAMISriovNetSupport bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,16 +38,22 @@ func (s *StepModifyEBSBackedInstance) Run(_ context.Context, state multistep.Sta
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set EnaSupport to true.
|
// Handle EnaSupport flag.
|
||||||
// As of February 2017, this applies to C5, I3, P2, R4, X1, and m4.16xlarge
|
// As of February 2017, this applies to C5, I3, P2, R4, X1, and m4.16xlarge
|
||||||
if s.EnableAMIENASupport {
|
if s.EnableAMIENASupport != nil {
|
||||||
ui.Say("Enabling Enhanced Networking (ENA)...")
|
var prefix string
|
||||||
|
if *s.EnableAMIENASupport {
|
||||||
|
prefix = "En"
|
||||||
|
} else {
|
||||||
|
prefix = "Dis"
|
||||||
|
}
|
||||||
|
ui.Say(fmt.Sprintf("%sabling Enhanced Networking (ENA)...", prefix))
|
||||||
_, err := ec2conn.ModifyInstanceAttribute(&ec2.ModifyInstanceAttributeInput{
|
_, err := ec2conn.ModifyInstanceAttribute(&ec2.ModifyInstanceAttributeInput{
|
||||||
InstanceId: instance.InstanceId,
|
InstanceId: instance.InstanceId,
|
||||||
EnaSupport: &ec2.AttributeBooleanValue{Value: aws.Bool(true)},
|
EnaSupport: &ec2.AttributeBooleanValue{Value: aws.Bool(*s.EnableAMIENASupport)},
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
err := fmt.Errorf("Error enabling Enhanced Networking (ENA) on %s: %s", *instance.InstanceId, err)
|
err := fmt.Errorf("Error %sabling Enhanced Networking (ENA) on %s: %s", strings.ToLower(prefix), *instance.InstanceId, err)
|
||||||
state.Put("error", err)
|
state.Put("error", err)
|
||||||
ui.Error(err.Error())
|
ui.Error(err.Error())
|
||||||
return multistep.ActionHalt
|
return multistep.ActionHalt
|
||||||
|
|
|
@ -20,7 +20,7 @@ import (
|
||||||
type StepSourceAMIInfo struct {
|
type StepSourceAMIInfo struct {
|
||||||
SourceAmi string
|
SourceAmi string
|
||||||
EnableAMISriovNetSupport bool
|
EnableAMISriovNetSupport bool
|
||||||
EnableAMIENASupport bool
|
EnableAMIENASupport *bool
|
||||||
AMIVirtType string
|
AMIVirtType string
|
||||||
AmiFilters AmiFilterOptions
|
AmiFilters AmiFilterOptions
|
||||||
}
|
}
|
||||||
|
@ -94,7 +94,7 @@ func (s *StepSourceAMIInfo) Run(_ context.Context, state multistep.StateBag) mul
|
||||||
|
|
||||||
// Enhanced Networking can only be enabled on HVM AMIs.
|
// Enhanced Networking can only be enabled on HVM AMIs.
|
||||||
// See http://goo.gl/icuXh5
|
// See http://goo.gl/icuXh5
|
||||||
if s.EnableAMIENASupport || s.EnableAMISriovNetSupport {
|
if (s.EnableAMIENASupport != nil && *s.EnableAMIENASupport) || s.EnableAMISriovNetSupport {
|
||||||
err = s.canEnableEnhancedNetworking(image)
|
err = s.canEnableEnhancedNetworking(image)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
state.Put("error", err)
|
state.Put("error", err)
|
||||||
|
|
|
@ -70,7 +70,7 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
|
||||||
errs = packer.MultiErrorAppend(errs, b.config.BlockDevices.Prepare(&b.config.ctx)...)
|
errs = packer.MultiErrorAppend(errs, b.config.BlockDevices.Prepare(&b.config.ctx)...)
|
||||||
errs = packer.MultiErrorAppend(errs, b.config.RunConfig.Prepare(&b.config.ctx)...)
|
errs = packer.MultiErrorAppend(errs, b.config.RunConfig.Prepare(&b.config.ctx)...)
|
||||||
|
|
||||||
if b.config.IsSpotInstance() && (b.config.AMIENASupport || b.config.AMISriovNetSupport) {
|
if b.config.IsSpotInstance() && ((b.config.AMIENASupport != nil && *b.config.AMIENASupport) || b.config.AMISriovNetSupport) {
|
||||||
errs = packer.MultiErrorAppend(errs,
|
errs = packer.MultiErrorAppend(errs,
|
||||||
fmt.Errorf("Spot instances do not support modification, which is required "+
|
fmt.Errorf("Spot instances do not support modification, which is required "+
|
||||||
"when either `ena_support` or `sriov_support` are set. Please ensure "+
|
"when either `ena_support` or `sriov_support` are set. Please ensure "+
|
||||||
|
|
|
@ -85,7 +85,7 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
|
||||||
errs = packer.MultiErrorAppend(errs, fmt.Errorf("no volume with name '%s' is found", b.config.RootDevice.SourceDeviceName))
|
errs = packer.MultiErrorAppend(errs, fmt.Errorf("no volume with name '%s' is found", b.config.RootDevice.SourceDeviceName))
|
||||||
}
|
}
|
||||||
|
|
||||||
if b.config.IsSpotInstance() && (b.config.AMIENASupport || b.config.AMISriovNetSupport) {
|
if b.config.IsSpotInstance() && ((b.config.AMIENASupport != nil && *b.config.AMIENASupport) || b.config.AMISriovNetSupport) {
|
||||||
errs = packer.MultiErrorAppend(errs,
|
errs = packer.MultiErrorAppend(errs,
|
||||||
fmt.Errorf("Spot instances do not support modification, which is required "+
|
fmt.Errorf("Spot instances do not support modification, which is required "+
|
||||||
"when either `ena_support` or `sriov_support` are set. Please ensure "+
|
"when either `ena_support` or `sriov_support` are set. Please ensure "+
|
||||||
|
|
|
@ -16,7 +16,7 @@ type StepRegisterAMI struct {
|
||||||
RootDevice RootBlockDevice
|
RootDevice RootBlockDevice
|
||||||
AMIDevices []*ec2.BlockDeviceMapping
|
AMIDevices []*ec2.BlockDeviceMapping
|
||||||
LaunchDevices []*ec2.BlockDeviceMapping
|
LaunchDevices []*ec2.BlockDeviceMapping
|
||||||
EnableAMIENASupport bool
|
EnableAMIENASupport *bool
|
||||||
EnableAMISriovNetSupport bool
|
EnableAMISriovNetSupport bool
|
||||||
image *ec2.Image
|
image *ec2.Image
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,7 @@ func (s *StepRegisterAMI) Run(ctx context.Context, state multistep.StateBag) mul
|
||||||
// As of February 2017, this applies to C3, C4, D2, I2, R3, and M4 (excluding m4.16xlarge)
|
// As of February 2017, this applies to C3, C4, D2, I2, R3, and M4 (excluding m4.16xlarge)
|
||||||
registerOpts.SriovNetSupport = aws.String("simple")
|
registerOpts.SriovNetSupport = aws.String("simple")
|
||||||
}
|
}
|
||||||
if s.EnableAMIENASupport {
|
if s.EnableAMIENASupport != nil && *s.EnableAMIENASupport {
|
||||||
// Set EnaSupport to true
|
// Set EnaSupport to true
|
||||||
// As of February 2017, this applies to C5, I3, P2, R4, X1, and m4.16xlarge
|
// As of February 2017, this applies to C5, I3, P2, R4, X1, and m4.16xlarge
|
||||||
registerOpts.EnaSupport = aws.Bool(true)
|
registerOpts.EnaSupport = aws.Bool(true)
|
||||||
|
|
|
@ -24,7 +24,7 @@ type Config struct {
|
||||||
awscommon.RunConfig `mapstructure:",squash"`
|
awscommon.RunConfig `mapstructure:",squash"`
|
||||||
|
|
||||||
VolumeMappings []BlockDevice `mapstructure:"ebs_volumes"`
|
VolumeMappings []BlockDevice `mapstructure:"ebs_volumes"`
|
||||||
AMIENASupport bool `mapstructure:"ena_support"`
|
AMIENASupport *bool `mapstructure:"ena_support"`
|
||||||
AMISriovNetSupport bool `mapstructure:"sriov_support"`
|
AMISriovNetSupport bool `mapstructure:"sriov_support"`
|
||||||
|
|
||||||
launchBlockDevices awscommon.BlockDevices
|
launchBlockDevices awscommon.BlockDevices
|
||||||
|
@ -70,7 +70,7 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
|
||||||
errs = packer.MultiErrorAppend(errs, err)
|
errs = packer.MultiErrorAppend(errs, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if b.config.IsSpotInstance() && (b.config.AMIENASupport || b.config.AMISriovNetSupport) {
|
if b.config.IsSpotInstance() && ((b.config.AMIENASupport != nil && *b.config.AMIENASupport) || b.config.AMISriovNetSupport) {
|
||||||
errs = packer.MultiErrorAppend(errs,
|
errs = packer.MultiErrorAppend(errs,
|
||||||
fmt.Errorf("Spot instances do not support modification, which is required "+
|
fmt.Errorf("Spot instances do not support modification, which is required "+
|
||||||
"when either `ena_support` or `sriov_support` are set. Please ensure "+
|
"when either `ena_support` or `sriov_support` are set. Please ensure "+
|
||||||
|
|
|
@ -156,7 +156,7 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
|
||||||
errs, fmt.Errorf("x509_key_path points to bad file: %s", err))
|
errs, fmt.Errorf("x509_key_path points to bad file: %s", err))
|
||||||
}
|
}
|
||||||
|
|
||||||
if b.config.IsSpotInstance() && (b.config.AMIENASupport || b.config.AMISriovNetSupport) {
|
if b.config.IsSpotInstance() && ((b.config.AMIENASupport != nil && *b.config.AMIENASupport) || b.config.AMISriovNetSupport) {
|
||||||
errs = packer.MultiErrorAppend(errs,
|
errs = packer.MultiErrorAppend(errs,
|
||||||
fmt.Errorf("Spot instances do not support modification, which is required "+
|
fmt.Errorf("Spot instances do not support modification, which is required "+
|
||||||
"when either `ena_support` or `sriov_support` are set. Please ensure "+
|
"when either `ena_support` or `sriov_support` are set. Please ensure "+
|
||||||
|
|
|
@ -12,7 +12,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type StepRegisterAMI struct {
|
type StepRegisterAMI struct {
|
||||||
EnableAMIENASupport bool
|
EnableAMIENASupport *bool
|
||||||
EnableAMISriovNetSupport bool
|
EnableAMISriovNetSupport bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ func (s *StepRegisterAMI) Run(ctx context.Context, state multistep.StateBag) mul
|
||||||
// As of February 2017, this applies to C3, C4, D2, I2, R3, and M4 (excluding m4.16xlarge)
|
// As of February 2017, this applies to C3, C4, D2, I2, R3, and M4 (excluding m4.16xlarge)
|
||||||
registerOpts.SriovNetSupport = aws.String("simple")
|
registerOpts.SriovNetSupport = aws.String("simple")
|
||||||
}
|
}
|
||||||
if s.EnableAMIENASupport {
|
if s.EnableAMIENASupport != nil && *s.EnableAMIENASupport {
|
||||||
// Set EnaSupport to true
|
// Set EnaSupport to true
|
||||||
// As of February 2017, this applies to C5, I3, P2, R4, X1, and m4.16xlarge
|
// As of February 2017, this applies to C5, I3, P2, R4, X1, and m4.16xlarge
|
||||||
registerOpts.EnaSupport = aws.Bool(true)
|
registerOpts.EnaSupport = aws.Bool(true)
|
||||||
|
|
|
@ -131,9 +131,11 @@ each category, the available configuration keys are alphabetized.
|
||||||
forces Packer to find an open device automatically.
|
forces Packer to find an open device automatically.
|
||||||
|
|
||||||
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
||||||
on HVM-compatible AMIs. If true, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
on HVM-compatible AMIs. If set, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
||||||
Note: you must make sure enhanced networking is enabled on your instance. See [Amazon's
|
If false, this will disable enhanced networking in the final AMI as opposed to passing
|
||||||
documentation on enabling enhanced networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking). Default `false`.
|
the setting through unchanged from the source. Note: you must make sure enhanced
|
||||||
|
networking is enabled on your instance. See [Amazon's documentation on enabling enhanced
|
||||||
|
networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking).
|
||||||
|
|
||||||
- `force_deregister` (boolean) - Force Packer to first deregister an existing
|
- `force_deregister` (boolean) - Force Packer to first deregister an existing
|
||||||
AMI if one with the same name already exists. Default `false`.
|
AMI if one with the same name already exists. Default `false`.
|
||||||
|
|
|
@ -183,9 +183,11 @@ builder.
|
||||||
Default `false`.
|
Default `false`.
|
||||||
|
|
||||||
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
||||||
on HVM-compatible AMIs. If true, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
on HVM-compatible AMIs. If set, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
||||||
Note: you must make sure enhanced networking is enabled on your instance. See [Amazon's
|
If false, this will disable enhanced networking in the final AMI as opposed to passing
|
||||||
documentation on enabling enhanced networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking). Default `false`.
|
the setting through unchanged from the source. Note: you must make sure enhanced
|
||||||
|
networking is enabled on your instance. See [Amazon's documentation on enabling enhanced
|
||||||
|
networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking).
|
||||||
|
|
||||||
- `enable_t2_unlimited` (boolean) - Enabling T2 Unlimited allows the source
|
- `enable_t2_unlimited` (boolean) - Enabling T2 Unlimited allows the source
|
||||||
instance to burst additional CPU beyond its available [CPU Credits]
|
instance to burst additional CPU beyond its available [CPU Credits]
|
||||||
|
|
|
@ -176,9 +176,11 @@ builder.
|
||||||
Default `false`.
|
Default `false`.
|
||||||
|
|
||||||
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
||||||
on HVM-compatible AMIs. If true, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
on HVM-compatible AMIs. If set, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
||||||
Note: you must make sure enhanced networking is enabled on your instance. See [Amazon's
|
If false, this will disable enhanced networking in the final AMI as opposed to passing
|
||||||
documentation on enabling enhanced networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking). Default `false`.
|
the setting through unchanged from the source. Note: you must make sure enhanced
|
||||||
|
networking is enabled on your instance. See [Amazon's documentation on enabling enhanced
|
||||||
|
networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking).
|
||||||
|
|
||||||
- `enable_t2_unlimited` (boolean) - Enabling T2 Unlimited allows the source
|
- `enable_t2_unlimited` (boolean) - Enabling T2 Unlimited allows the source
|
||||||
instance to burst additional CPU beyond its available [CPU Credits]
|
instance to burst additional CPU beyond its available [CPU Credits]
|
||||||
|
|
|
@ -148,9 +148,11 @@ builder.
|
||||||
Default `false`.
|
Default `false`.
|
||||||
|
|
||||||
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
||||||
on HVM-compatible AMIs. If true, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
on HVM-compatible AMIs. If set, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
||||||
Note: you must make sure enhanced networking is enabled on your instance. See [Amazon's
|
If false, this will disable enhanced networking in the final AMI as opposed to passing
|
||||||
documentation on enabling enhanced networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking). Default `false`.
|
the setting through unchanged from the source. Note: you must make sure enhanced
|
||||||
|
networking is enabled on your instance. See [Amazon's documentation on enabling enhanced
|
||||||
|
networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking).
|
||||||
|
|
||||||
- `enable_t2_unlimited` (boolean) - Enabling T2 Unlimited allows the source
|
- `enable_t2_unlimited` (boolean) - Enabling T2 Unlimited allows the source
|
||||||
instance to burst additional CPU beyond its available [CPU Credits]
|
instance to burst additional CPU beyond its available [CPU Credits]
|
||||||
|
|
|
@ -200,9 +200,11 @@ builder.
|
||||||
Default `false`.
|
Default `false`.
|
||||||
|
|
||||||
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
- `ena_support` (boolean) - Enable enhanced networking (ENA but not SriovNetSupport)
|
||||||
on HVM-compatible AMIs. If true, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
on HVM-compatible AMIs. If set, add `ec2:ModifyInstanceAttribute` to your AWS IAM policy.
|
||||||
Note: you must make sure enhanced networking is enabled on your instance. See [Amazon's
|
If false, this will disable enhanced networking in the final AMI as opposed to passing
|
||||||
documentation on enabling enhanced networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking). Default `false`.
|
the setting through unchanged from the source. Note: you must make sure enhanced
|
||||||
|
networking is enabled on your instance. See [Amazon's documentation on enabling enhanced
|
||||||
|
networking](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/enhanced-networking.html#enabling_enhanced_networking).
|
||||||
|
|
||||||
- `enable_t2_unlimited` (boolean) - Enabling T2 Unlimited allows the source
|
- `enable_t2_unlimited` (boolean) - Enabling T2 Unlimited allows the source
|
||||||
instance to burst additional CPU beyond its available [CPU Credits]
|
instance to burst additional CPU beyond its available [CPU Credits]
|
||||||
|
|
Loading…
Reference in New Issue