awsx.ecs.FargateService
Explore with Pulumi AI
Create an ECS Service resource for Fargate with the given unique name, arguments, and options.
Creates Task definition if taskDefinitionArgs
is specified.
Create FargateService Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new FargateService(name: string, args?: FargateServiceArgs, opts?: CustomResourceOptions);
@overload
def FargateService(resource_name: str,
args: Optional[FargateServiceArgs] = None,
opts: Optional[ResourceOptions] = None)
@overload
def FargateService(resource_name: str,
opts: Optional[ResourceOptions] = None,
alarms: Optional[pulumi_aws.ecs.ServiceAlarmsArgs] = None,
assign_public_ip: Optional[bool] = None,
cluster: Optional[str] = None,
continue_before_steady_state: Optional[bool] = None,
deployment_circuit_breaker: Optional[pulumi_aws.ecs.ServiceDeploymentCircuitBreakerArgs] = None,
deployment_controller: Optional[pulumi_aws.ecs.ServiceDeploymentControllerArgs] = None,
deployment_maximum_percent: Optional[int] = None,
deployment_minimum_healthy_percent: Optional[int] = None,
desired_count: Optional[int] = None,
enable_ecs_managed_tags: Optional[bool] = None,
enable_execute_command: Optional[bool] = None,
force_new_deployment: Optional[bool] = None,
health_check_grace_period_seconds: Optional[int] = None,
iam_role: Optional[str] = None,
load_balancers: Optional[Sequence[pulumi_aws.ecs.ServiceLoadBalancerArgs]] = None,
name: Optional[str] = None,
network_configuration: Optional[pulumi_aws.ecs.ServiceNetworkConfigurationArgs] = None,
placement_constraints: Optional[Sequence[pulumi_aws.ecs.ServicePlacementConstraintArgs]] = None,
platform_version: Optional[str] = None,
propagate_tags: Optional[str] = None,
scheduling_strategy: Optional[str] = None,
service_connect_configuration: Optional[pulumi_aws.ecs.ServiceServiceConnectConfigurationArgs] = None,
service_registries: Optional[pulumi_aws.ecs.ServiceServiceRegistriesArgs] = None,
tags: Optional[Mapping[str, str]] = None,
task_definition: Optional[str] = None,
task_definition_args: Optional[FargateServiceTaskDefinitionArgs] = None,
triggers: Optional[Mapping[str, str]] = None,
volume_configuration: Optional[pulumi_aws.ecs.ServiceVolumeConfigurationArgs] = None)
func NewFargateService(ctx *Context, name string, args *FargateServiceArgs, opts ...ResourceOption) (*FargateService, error)
public FargateService(string name, FargateServiceArgs? args = null, CustomResourceOptions? opts = null)
public FargateService(String name, FargateServiceArgs args)
public FargateService(String name, FargateServiceArgs args, CustomResourceOptions options)
type: awsx:ecs:FargateService
properties: # The arguments to resource properties.
options: # Bag of options to control resource's behavior.
Parameters
- name string
- The unique name of the resource.
- args FargateServiceArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- resource_name str
- The unique name of the resource.
- args FargateServiceArgs
- The arguments to resource properties.
- opts ResourceOptions
- Bag of options to control resource's behavior.
- ctx Context
- Context object for the current deployment.
- name string
- The unique name of the resource.
- args FargateServiceArgs
- The arguments to resource properties.
- opts ResourceOption
- Bag of options to control resource's behavior.
- name string
- The unique name of the resource.
- args FargateServiceArgs
- The arguments to resource properties.
- opts CustomResourceOptions
- Bag of options to control resource's behavior.
- name String
- The unique name of the resource.
- args FargateServiceArgs
- The arguments to resource properties.
- options CustomResourceOptions
- Bag of options to control resource's behavior.
Constructor example
The following reference example uses placeholder values for all input properties.
var fargateServiceResource = new Awsx.Ecs.FargateService("fargateServiceResource", new()
{
Alarms = new Aws.Ecs.Inputs.ServiceAlarmsArgs
{
AlarmNames = new[]
{
"string",
},
Enable = false,
Rollback = false,
},
AssignPublicIp = false,
Cluster = "string",
ContinueBeforeSteadyState = false,
DeploymentCircuitBreaker = new Aws.Ecs.Inputs.ServiceDeploymentCircuitBreakerArgs
{
Enable = false,
Rollback = false,
},
DeploymentController = new Aws.Ecs.Inputs.ServiceDeploymentControllerArgs
{
Type = "string",
},
DeploymentMaximumPercent = 0,
DeploymentMinimumHealthyPercent = 0,
DesiredCount = 0,
EnableEcsManagedTags = false,
EnableExecuteCommand = false,
ForceNewDeployment = false,
HealthCheckGracePeriodSeconds = 0,
IamRole = "string",
LoadBalancers = new[]
{
new Aws.Ecs.Inputs.ServiceLoadBalancerArgs
{
ContainerName = "string",
ContainerPort = 0,
ElbName = "string",
TargetGroupArn = "string",
},
},
Name = "string",
NetworkConfiguration = new Aws.Ecs.Inputs.ServiceNetworkConfigurationArgs
{
Subnets = new[]
{
"string",
},
AssignPublicIp = false,
SecurityGroups = new[]
{
"string",
},
},
PlacementConstraints = new[]
{
new Aws.Ecs.Inputs.ServicePlacementConstraintArgs
{
Type = "string",
Expression = "string",
},
},
PlatformVersion = "string",
PropagateTags = "string",
SchedulingStrategy = "string",
ServiceConnectConfiguration = new Aws.Ecs.Inputs.ServiceServiceConnectConfigurationArgs
{
Enabled = false,
LogConfiguration = new Aws.Ecs.Inputs.ServiceServiceConnectConfigurationLogConfigurationArgs
{
LogDriver = "string",
Options =
{
{ "string", "string" },
},
SecretOptions = new[]
{
new Aws.Ecs.Inputs.ServiceServiceConnectConfigurationLogConfigurationSecretOptionArgs
{
Name = "string",
ValueFrom = "string",
},
},
},
Namespace = "string",
Services = new[]
{
new Aws.Ecs.Inputs.ServiceServiceConnectConfigurationServiceArgs
{
PortName = "string",
ClientAlias = new[]
{
new Aws.Ecs.Inputs.ServiceServiceConnectConfigurationServiceClientAliasArgs
{
Port = 0,
DnsName = "string",
},
},
DiscoveryName = "string",
IngressPortOverride = 0,
Timeout = new Aws.Ecs.Inputs.ServiceServiceConnectConfigurationServiceTimeoutArgs
{
IdleTimeoutSeconds = 0,
PerRequestTimeoutSeconds = 0,
},
Tls = new Aws.Ecs.Inputs.ServiceServiceConnectConfigurationServiceTlsArgs
{
IssuerCertAuthority = new Aws.Ecs.Inputs.ServiceServiceConnectConfigurationServiceTlsIssuerCertAuthorityArgs
{
AwsPcaAuthorityArn = "string",
},
KmsKey = "string",
RoleArn = "string",
},
},
},
},
ServiceRegistries = new Aws.Ecs.Inputs.ServiceServiceRegistriesArgs
{
RegistryArn = "string",
ContainerName = "string",
ContainerPort = 0,
Port = 0,
},
Tags =
{
{ "string", "string" },
},
TaskDefinition = "string",
TaskDefinitionArgs = new Awsx.Ecs.Inputs.FargateServiceTaskDefinitionArgs
{
Container = new Awsx.Ecs.Inputs.TaskDefinitionContainerDefinitionArgs
{
Image = "string",
Name = "string",
Links = new()
{
"string",
},
VolumesFrom = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionVolumeFromArgs
{
ReadOnly = false,
SourceContainer = "string",
},
},
DnsSearchDomains = new()
{
"string",
},
LogConfiguration = new Awsx.Ecs.Inputs.TaskDefinitionLogConfigurationArgs
{
LogDriver = "string",
Options = "any",
SecretOptions = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionSecretArgs
{
Name = "string",
ValueFrom = "string",
},
},
},
DockerLabels = "any",
DockerSecurityOptions = new()
{
"string",
},
EntryPoint = new()
{
"string",
},
Environment = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionKeyValuePairArgs
{
Name = "string",
Value = "string",
},
},
EnvironmentFiles = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionEnvironmentFileArgs
{
Type = "string",
Value = "string",
},
},
Essential = false,
ExtraHosts = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionHostEntryArgs
{
Hostname = "string",
IpAddress = "string",
},
},
FirelensConfiguration = new Awsx.Ecs.Inputs.TaskDefinitionFirelensConfigurationArgs
{
Options = "any",
Type = "string",
},
HealthCheck = new Awsx.Ecs.Inputs.TaskDefinitionHealthCheckArgs
{
Command = new()
{
"string",
},
Interval = 0,
Retries = 0,
StartPeriod = 0,
Timeout = 0,
},
Hostname = "string",
DependsOn = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionContainerDependencyArgs
{
Condition = "string",
ContainerName = "string",
},
},
Interactive = false,
Command = new()
{
"string",
},
LinuxParameters = new Awsx.Ecs.Inputs.TaskDefinitionLinuxParametersArgs
{
Capabilities = new Awsx.Ecs.Inputs.TaskDefinitionKernelCapabilitiesArgs
{
Add = new()
{
"string",
},
Drop = new()
{
"string",
},
},
Devices = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionDeviceArgs
{
ContainerPath = "string",
HostPath = "string",
Permissions = new()
{
"string",
},
},
},
InitProcessEnabled = false,
MaxSwap = 0,
SharedMemorySize = 0,
Swappiness = 0,
Tmpfs = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionTmpfsArgs
{
Size = 0,
ContainerPath = "string",
MountOptions = new()
{
"string",
},
},
},
},
DnsServers = new()
{
"string",
},
DisableNetworking = false,
MountPoints = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionMountPointArgs
{
ContainerPath = "string",
ReadOnly = false,
SourceVolume = "string",
},
},
MemoryReservation = 0,
Cpu = 0,
PortMappings = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionPortMappingArgs
{
AppProtocol = Awsx.Ecs.TaskDefinitionPortMappingAppProtocol.Http,
ContainerPort = 0,
ContainerPortRange = "string",
HostPort = 0,
Name = "string",
Protocol = "string",
TargetGroup = targetGroup,
},
},
Privileged = false,
PseudoTerminal = false,
ReadonlyRootFilesystem = false,
RepositoryCredentials = new Awsx.Ecs.Inputs.TaskDefinitionRepositoryCredentialsArgs
{
CredentialsParameter = "string",
},
ResourceRequirements = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionResourceRequirementArgs
{
Type = "string",
Value = "string",
},
},
Secrets = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionSecretArgs
{
Name = "string",
ValueFrom = "string",
},
},
StartTimeout = 0,
StopTimeout = 0,
SystemControls = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionSystemControlArgs
{
Namespace = "string",
Value = "string",
},
},
Ulimits = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionUlimitArgs
{
HardLimit = 0,
Name = "string",
SoftLimit = 0,
},
},
User = "string",
Memory = 0,
WorkingDirectory = "string",
},
Containers =
{
{ "string", new Awsx.Ecs.Inputs.TaskDefinitionContainerDefinitionArgs
{
Image = "string",
Name = "string",
Links = new()
{
"string",
},
VolumesFrom = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionVolumeFromArgs
{
ReadOnly = false,
SourceContainer = "string",
},
},
DnsSearchDomains = new()
{
"string",
},
LogConfiguration = new Awsx.Ecs.Inputs.TaskDefinitionLogConfigurationArgs
{
LogDriver = "string",
Options = "any",
SecretOptions = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionSecretArgs
{
Name = "string",
ValueFrom = "string",
},
},
},
DockerLabels = "any",
DockerSecurityOptions = new()
{
"string",
},
EntryPoint = new()
{
"string",
},
Environment = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionKeyValuePairArgs
{
Name = "string",
Value = "string",
},
},
EnvironmentFiles = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionEnvironmentFileArgs
{
Type = "string",
Value = "string",
},
},
Essential = false,
ExtraHosts = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionHostEntryArgs
{
Hostname = "string",
IpAddress = "string",
},
},
FirelensConfiguration = new Awsx.Ecs.Inputs.TaskDefinitionFirelensConfigurationArgs
{
Options = "any",
Type = "string",
},
HealthCheck = new Awsx.Ecs.Inputs.TaskDefinitionHealthCheckArgs
{
Command = new()
{
"string",
},
Interval = 0,
Retries = 0,
StartPeriod = 0,
Timeout = 0,
},
Hostname = "string",
DependsOn = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionContainerDependencyArgs
{
Condition = "string",
ContainerName = "string",
},
},
Interactive = false,
Command = new()
{
"string",
},
LinuxParameters = new Awsx.Ecs.Inputs.TaskDefinitionLinuxParametersArgs
{
Capabilities = new Awsx.Ecs.Inputs.TaskDefinitionKernelCapabilitiesArgs
{
Add = new()
{
"string",
},
Drop = new()
{
"string",
},
},
Devices = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionDeviceArgs
{
ContainerPath = "string",
HostPath = "string",
Permissions = new()
{
"string",
},
},
},
InitProcessEnabled = false,
MaxSwap = 0,
SharedMemorySize = 0,
Swappiness = 0,
Tmpfs = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionTmpfsArgs
{
Size = 0,
ContainerPath = "string",
MountOptions = new()
{
"string",
},
},
},
},
DnsServers = new()
{
"string",
},
DisableNetworking = false,
MountPoints = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionMountPointArgs
{
ContainerPath = "string",
ReadOnly = false,
SourceVolume = "string",
},
},
MemoryReservation = 0,
Cpu = 0,
PortMappings = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionPortMappingArgs
{
AppProtocol = Awsx.Ecs.TaskDefinitionPortMappingAppProtocol.Http,
ContainerPort = 0,
ContainerPortRange = "string",
HostPort = 0,
Name = "string",
Protocol = "string",
TargetGroup = targetGroup,
},
},
Privileged = false,
PseudoTerminal = false,
ReadonlyRootFilesystem = false,
RepositoryCredentials = new Awsx.Ecs.Inputs.TaskDefinitionRepositoryCredentialsArgs
{
CredentialsParameter = "string",
},
ResourceRequirements = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionResourceRequirementArgs
{
Type = "string",
Value = "string",
},
},
Secrets = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionSecretArgs
{
Name = "string",
ValueFrom = "string",
},
},
StartTimeout = 0,
StopTimeout = 0,
SystemControls = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionSystemControlArgs
{
Namespace = "string",
Value = "string",
},
},
Ulimits = new()
{
new Awsx.Ecs.Inputs.TaskDefinitionUlimitArgs
{
HardLimit = 0,
Name = "string",
SoftLimit = 0,
},
},
User = "string",
Memory = 0,
WorkingDirectory = "string",
} },
},
Cpu = "string",
EphemeralStorage = new Aws.Ecs.Inputs.TaskDefinitionEphemeralStorageArgs
{
SizeInGib = 0,
},
ExecutionRole = new Awsx.Awsx.Inputs.DefaultRoleWithPolicyArgs
{
Args = new Awsx.Awsx.Inputs.RoleWithPolicyArgs
{
Description = "string",
ForceDetachPolicies = false,
InlinePolicies = new()
{
new Aws.Iam.Inputs.RoleInlinePolicyArgs
{
Name = "string",
Policy = "string",
},
},
ManagedPolicyArns = new()
{
"string",
},
MaxSessionDuration = 0,
Name = "string",
NamePrefix = "string",
Path = "string",
PermissionsBoundary = "string",
PolicyArns = new()
{
"string",
},
Tags =
{
{ "string", "string" },
},
},
RoleArn = "string",
Skip = false,
},
Family = "string",
InferenceAccelerators = new()
{
new Aws.Ecs.Inputs.TaskDefinitionInferenceAcceleratorArgs
{
DeviceName = "string",
DeviceType = "string",
},
},
IpcMode = "string",
LogGroup = new Awsx.Awsx.Inputs.DefaultLogGroupArgs
{
Args = new Awsx.Awsx.Inputs.LogGroupArgs
{
KmsKeyId = "string",
LogGroupClass = "string",
Name = "string",
NamePrefix = "string",
RetentionInDays = 0,
SkipDestroy = false,
Tags =
{
{ "string", "string" },
},
},
Existing = new Awsx.Awsx.Inputs.ExistingLogGroupArgs
{
Arn = "string",
Name = "string",
Region = "string",
},
Skip = false,
},
Memory = "string",
PidMode = "string",
PlacementConstraints = new()
{
new Aws.Ecs.Inputs.TaskDefinitionPlacementConstraintArgs
{
Type = "string",
Expression = "string",
},
},
ProxyConfiguration = new Aws.Ecs.Inputs.TaskDefinitionProxyConfigurationArgs
{
ContainerName = "string",
Properties =
{
{ "string", "string" },
},
Type = "string",
},
RuntimePlatform = new Aws.Ecs.Inputs.TaskDefinitionRuntimePlatformArgs
{
CpuArchitecture = "string",
OperatingSystemFamily = "string",
},
SkipDestroy = false,
Tags =
{
{ "string", "string" },
},
TaskRole = new Awsx.Awsx.Inputs.DefaultRoleWithPolicyArgs
{
Args = new Awsx.Awsx.Inputs.RoleWithPolicyArgs
{
Description = "string",
ForceDetachPolicies = false,
InlinePolicies = new()
{
new Aws.Iam.Inputs.RoleInlinePolicyArgs
{
Name = "string",
Policy = "string",
},
},
ManagedPolicyArns = new()
{
"string",
},
MaxSessionDuration = 0,
Name = "string",
NamePrefix = "string",
Path = "string",
PermissionsBoundary = "string",
PolicyArns = new()
{
"string",
},
Tags =
{
{ "string", "string" },
},
},
RoleArn = "string",
Skip = false,
},
TrackLatest = false,
Volumes = new()
{
new Aws.Ecs.Inputs.TaskDefinitionVolumeArgs
{
Name = "string",
ConfigureAtLaunch = false,
DockerVolumeConfiguration = new Aws.Ecs.Inputs.TaskDefinitionVolumeDockerVolumeConfigurationArgs
{
Autoprovision = false,
Driver = "string",
DriverOpts =
{
{ "string", "string" },
},
Labels =
{
{ "string", "string" },
},
Scope = "string",
},
EfsVolumeConfiguration = new Aws.Ecs.Inputs.TaskDefinitionVolumeEfsVolumeConfigurationArgs
{
FileSystemId = "string",
AuthorizationConfig = new Aws.Ecs.Inputs.TaskDefinitionVolumeEfsVolumeConfigurationAuthorizationConfigArgs
{
AccessPointId = "string",
Iam = "string",
},
RootDirectory = "string",
TransitEncryption = "string",
TransitEncryptionPort = 0,
},
FsxWindowsFileServerVolumeConfiguration = new Aws.Ecs.Inputs.TaskDefinitionVolumeFsxWindowsFileServerVolumeConfigurationArgs
{
AuthorizationConfig = new Aws.Ecs.Inputs.TaskDefinitionVolumeFsxWindowsFileServerVolumeConfigurationAuthorizationConfigArgs
{
CredentialsParameter = "string",
Domain = "string",
},
FileSystemId = "string",
RootDirectory = "string",
},
HostPath = "string",
},
},
},
Triggers =
{
{ "string", "string" },
},
VolumeConfiguration = new Aws.Ecs.Inputs.ServiceVolumeConfigurationArgs
{
ManagedEbsVolume = new Aws.Ecs.Inputs.ServiceVolumeConfigurationManagedEbsVolumeArgs
{
RoleArn = "string",
Encrypted = false,
FileSystemType = "string",
Iops = 0,
KmsKeyId = "string",
SizeInGb = 0,
SnapshotId = "string",
Throughput = 0,
VolumeType = "string",
},
Name = "string",
},
});
example, err := ecs.NewFargateService(ctx, "fargateServiceResource", &ecs.FargateServiceArgs{
Alarms: &ecs.ServiceAlarmsArgs{
AlarmNames: pulumi.StringArray{
pulumi.String("string"),
},
Enable: pulumi.Bool(false),
Rollback: pulumi.Bool(false),
},
AssignPublicIp: pulumi.Bool(false),
Cluster: pulumi.String("string"),
ContinueBeforeSteadyState: pulumi.Bool(false),
DeploymentCircuitBreaker: &ecs.ServiceDeploymentCircuitBreakerArgs{
Enable: pulumi.Bool(false),
Rollback: pulumi.Bool(false),
},
DeploymentController: &ecs.ServiceDeploymentControllerArgs{
Type: pulumi.String("string"),
},
DeploymentMaximumPercent: pulumi.Int(0),
DeploymentMinimumHealthyPercent: pulumi.Int(0),
DesiredCount: pulumi.Int(0),
EnableEcsManagedTags: pulumi.Bool(false),
EnableExecuteCommand: pulumi.Bool(false),
ForceNewDeployment: pulumi.Bool(false),
HealthCheckGracePeriodSeconds: pulumi.Int(0),
IamRole: pulumi.String("string"),
LoadBalancers: ecs.ServiceLoadBalancerArray{
&ecs.ServiceLoadBalancerArgs{
ContainerName: pulumi.String("string"),
ContainerPort: pulumi.Int(0),
ElbName: pulumi.String("string"),
TargetGroupArn: pulumi.String("string"),
},
},
Name: pulumi.String("string"),
NetworkConfiguration: &ecs.ServiceNetworkConfigurationArgs{
Subnets: pulumi.StringArray{
pulumi.String("string"),
},
AssignPublicIp: pulumi.Bool(false),
SecurityGroups: pulumi.StringArray{
pulumi.String("string"),
},
},
PlacementConstraints: ecs.ServicePlacementConstraintArray{
&ecs.ServicePlacementConstraintArgs{
Type: pulumi.String("string"),
Expression: pulumi.String("string"),
},
},
PlatformVersion: pulumi.String("string"),
PropagateTags: pulumi.String("string"),
SchedulingStrategy: pulumi.String("string"),
ServiceConnectConfiguration: &ecs.ServiceServiceConnectConfigurationArgs{
Enabled: pulumi.Bool(false),
LogConfiguration: &ecs.ServiceServiceConnectConfigurationLogConfigurationArgs{
LogDriver: pulumi.String("string"),
Options: pulumi.StringMap{
"string": pulumi.String("string"),
},
SecretOptions: ecs.ServiceServiceConnectConfigurationLogConfigurationSecretOptionArray{
&ecs.ServiceServiceConnectConfigurationLogConfigurationSecretOptionArgs{
Name: pulumi.String("string"),
ValueFrom: pulumi.String("string"),
},
},
},
Namespace: pulumi.String("string"),
Services: ecs.ServiceServiceConnectConfigurationServiceArray{
&ecs.ServiceServiceConnectConfigurationServiceArgs{
PortName: pulumi.String("string"),
ClientAlias: ecs.ServiceServiceConnectConfigurationServiceClientAliasArray{
&ecs.ServiceServiceConnectConfigurationServiceClientAliasArgs{
Port: pulumi.Int(0),
DnsName: pulumi.String("string"),
},
},
DiscoveryName: pulumi.String("string"),
IngressPortOverride: pulumi.Int(0),
Timeout: &ecs.ServiceServiceConnectConfigurationServiceTimeoutArgs{
IdleTimeoutSeconds: pulumi.Int(0),
PerRequestTimeoutSeconds: pulumi.Int(0),
},
Tls: &ecs.ServiceServiceConnectConfigurationServiceTlsArgs{
IssuerCertAuthority: &ecs.ServiceServiceConnectConfigurationServiceTlsIssuerCertAuthorityArgs{
AwsPcaAuthorityArn: pulumi.String("string"),
},
KmsKey: pulumi.String("string"),
RoleArn: pulumi.String("string"),
},
},
},
},
ServiceRegistries: &ecs.ServiceServiceRegistriesArgs{
RegistryArn: pulumi.String("string"),
ContainerName: pulumi.String("string"),
ContainerPort: pulumi.Int(0),
Port: pulumi.Int(0),
},
Tags: pulumi.StringMap{
"string": pulumi.String("string"),
},
TaskDefinition: pulumi.String("string"),
TaskDefinitionArgs: &ecs.FargateServiceTaskDefinitionArgs{
Container: &ecs.TaskDefinitionContainerDefinitionArgs{
Image: pulumi.String("string"),
Name: pulumi.String("string"),
Links: pulumi.StringArray{
pulumi.String("string"),
},
VolumesFrom: ecs.TaskDefinitionVolumeFromArray{
&ecs.TaskDefinitionVolumeFromArgs{
ReadOnly: pulumi.Bool(false),
SourceContainer: pulumi.String("string"),
},
},
DnsSearchDomains: pulumi.StringArray{
pulumi.String("string"),
},
LogConfiguration: &ecs.TaskDefinitionLogConfigurationArgs{
LogDriver: pulumi.String("string"),
Options: pulumi.Any("any"),
SecretOptions: ecs.TaskDefinitionSecretArray{
&ecs.TaskDefinitionSecretArgs{
Name: pulumi.String("string"),
ValueFrom: pulumi.String("string"),
},
},
},
DockerLabels: pulumi.Any("any"),
DockerSecurityOptions: pulumi.StringArray{
pulumi.String("string"),
},
EntryPoint: pulumi.StringArray{
pulumi.String("string"),
},
Environment: ecs.TaskDefinitionKeyValuePairArray{
&ecs.TaskDefinitionKeyValuePairArgs{
Name: pulumi.String("string"),
Value: pulumi.String("string"),
},
},
EnvironmentFiles: ecs.TaskDefinitionEnvironmentFileArray{
&ecs.TaskDefinitionEnvironmentFileArgs{
Type: pulumi.String("string"),
Value: pulumi.String("string"),
},
},
Essential: pulumi.Bool(false),
ExtraHosts: ecs.TaskDefinitionHostEntryArray{
&ecs.TaskDefinitionHostEntryArgs{
Hostname: pulumi.String("string"),
IpAddress: pulumi.String("string"),
},
},
FirelensConfiguration: &ecs.TaskDefinitionFirelensConfigurationArgs{
Options: pulumi.Any("any"),
Type: pulumi.String("string"),
},
HealthCheck: &ecs.TaskDefinitionHealthCheckArgs{
Command: pulumi.StringArray{
pulumi.String("string"),
},
Interval: pulumi.Int(0),
Retries: pulumi.Int(0),
StartPeriod: pulumi.Int(0),
Timeout: pulumi.Int(0),
},
Hostname: pulumi.String("string"),
DependsOn: ecs.TaskDefinitionContainerDependencyArray{
&ecs.TaskDefinitionContainerDependencyArgs{
Condition: pulumi.String("string"),
ContainerName: pulumi.String("string"),
},
},
Interactive: pulumi.Bool(false),
Command: pulumi.StringArray{
pulumi.String("string"),
},
LinuxParameters: &ecs.TaskDefinitionLinuxParametersArgs{
Capabilities: &ecs.TaskDefinitionKernelCapabilitiesArgs{
Add: pulumi.StringArray{
pulumi.String("string"),
},
Drop: pulumi.StringArray{
pulumi.String("string"),
},
},
Devices: ecs.TaskDefinitionDeviceArray{
&ecs.TaskDefinitionDeviceArgs{
ContainerPath: pulumi.String("string"),
HostPath: pulumi.String("string"),
Permissions: pulumi.StringArray{
pulumi.String("string"),
},
},
},
InitProcessEnabled: pulumi.Bool(false),
MaxSwap: pulumi.Int(0),
SharedMemorySize: pulumi.Int(0),
Swappiness: pulumi.Int(0),
Tmpfs: ecs.TaskDefinitionTmpfsArray{
&ecs.TaskDefinitionTmpfsArgs{
Size: pulumi.Int(0),
ContainerPath: pulumi.String("string"),
MountOptions: pulumi.StringArray{
pulumi.String("string"),
},
},
},
},
DnsServers: pulumi.StringArray{
pulumi.String("string"),
},
DisableNetworking: pulumi.Bool(false),
MountPoints: ecs.TaskDefinitionMountPointArray{
&ecs.TaskDefinitionMountPointArgs{
ContainerPath: pulumi.String("string"),
ReadOnly: pulumi.Bool(false),
SourceVolume: pulumi.String("string"),
},
},
MemoryReservation: pulumi.Int(0),
Cpu: pulumi.Int(0),
PortMappings: ecs.TaskDefinitionPortMappingArray{
&ecs.TaskDefinitionPortMappingArgs{
AppProtocol: ecs.TaskDefinitionPortMappingAppProtocolHttp,
ContainerPort: pulumi.Int(0),
ContainerPortRange: pulumi.String("string"),
HostPort: pulumi.Int(0),
Name: pulumi.String("string"),
Protocol: pulumi.String("string"),
TargetGroup: pulumi.Any(targetGroup),
},
},
Privileged: pulumi.Bool(false),
PseudoTerminal: pulumi.Bool(false),
ReadonlyRootFilesystem: pulumi.Bool(false),
RepositoryCredentials: &ecs.TaskDefinitionRepositoryCredentialsArgs{
CredentialsParameter: pulumi.String("string"),
},
ResourceRequirements: ecs.TaskDefinitionResourceRequirementArray{
&ecs.TaskDefinitionResourceRequirementArgs{
Type: pulumi.String("string"),
Value: pulumi.String("string"),
},
},
Secrets: ecs.TaskDefinitionSecretArray{
&ecs.TaskDefinitionSecretArgs{
Name: pulumi.String("string"),
ValueFrom: pulumi.String("string"),
},
},
StartTimeout: pulumi.Int(0),
StopTimeout: pulumi.Int(0),
SystemControls: ecs.TaskDefinitionSystemControlArray{
&ecs.TaskDefinitionSystemControlArgs{
Namespace: pulumi.String("string"),
Value: pulumi.String("string"),
},
},
Ulimits: ecs.TaskDefinitionUlimitArray{
&ecs.TaskDefinitionUlimitArgs{
HardLimit: pulumi.Int(0),
Name: pulumi.String("string"),
SoftLimit: pulumi.Int(0),
},
},
User: pulumi.String("string"),
Memory: pulumi.Int(0),
WorkingDirectory: pulumi.String("string"),
},
Containers: map[string]ecs.TaskDefinitionContainerDefinitionArgs{
"string": &ecs.TaskDefinitionContainerDefinitionArgs{
Image: pulumi.String("string"),
Name: pulumi.String("string"),
Links: pulumi.StringArray{
pulumi.String("string"),
},
VolumesFrom: ecs.TaskDefinitionVolumeFromArray{
&ecs.TaskDefinitionVolumeFromArgs{
ReadOnly: pulumi.Bool(false),
SourceContainer: pulumi.String("string"),
},
},
DnsSearchDomains: pulumi.StringArray{
pulumi.String("string"),
},
LogConfiguration: &ecs.TaskDefinitionLogConfigurationArgs{
LogDriver: pulumi.String("string"),
Options: pulumi.Any("any"),
SecretOptions: ecs.TaskDefinitionSecretArray{
&ecs.TaskDefinitionSecretArgs{
Name: pulumi.String("string"),
ValueFrom: pulumi.String("string"),
},
},
},
DockerLabels: pulumi.Any("any"),
DockerSecurityOptions: pulumi.StringArray{
pulumi.String("string"),
},
EntryPoint: pulumi.StringArray{
pulumi.String("string"),
},
Environment: ecs.TaskDefinitionKeyValuePairArray{
&ecs.TaskDefinitionKeyValuePairArgs{
Name: pulumi.String("string"),
Value: pulumi.String("string"),
},
},
EnvironmentFiles: ecs.TaskDefinitionEnvironmentFileArray{
&ecs.TaskDefinitionEnvironmentFileArgs{
Type: pulumi.String("string"),
Value: pulumi.String("string"),
},
},
Essential: pulumi.Bool(false),
ExtraHosts: ecs.TaskDefinitionHostEntryArray{
&ecs.TaskDefinitionHostEntryArgs{
Hostname: pulumi.String("string"),
IpAddress: pulumi.String("string"),
},
},
FirelensConfiguration: &ecs.TaskDefinitionFirelensConfigurationArgs{
Options: pulumi.Any("any"),
Type: pulumi.String("string"),
},
HealthCheck: &ecs.TaskDefinitionHealthCheckArgs{
Command: pulumi.StringArray{
pulumi.String("string"),
},
Interval: pulumi.Int(0),
Retries: pulumi.Int(0),
StartPeriod: pulumi.Int(0),
Timeout: pulumi.Int(0),
},
Hostname: pulumi.String("string"),
DependsOn: ecs.TaskDefinitionContainerDependencyArray{
&ecs.TaskDefinitionContainerDependencyArgs{
Condition: pulumi.String("string"),
ContainerName: pulumi.String("string"),
},
},
Interactive: pulumi.Bool(false),
Command: pulumi.StringArray{
pulumi.String("string"),
},
LinuxParameters: &ecs.TaskDefinitionLinuxParametersArgs{
Capabilities: &ecs.TaskDefinitionKernelCapabilitiesArgs{
Add: pulumi.StringArray{
pulumi.String("string"),
},
Drop: pulumi.StringArray{
pulumi.String("string"),
},
},
Devices: ecs.TaskDefinitionDeviceArray{
&ecs.TaskDefinitionDeviceArgs{
ContainerPath: pulumi.String("string"),
HostPath: pulumi.String("string"),
Permissions: pulumi.StringArray{
pulumi.String("string"),
},
},
},
InitProcessEnabled: pulumi.Bool(false),
MaxSwap: pulumi.Int(0),
SharedMemorySize: pulumi.Int(0),
Swappiness: pulumi.Int(0),
Tmpfs: ecs.TaskDefinitionTmpfsArray{
&ecs.TaskDefinitionTmpfsArgs{
Size: pulumi.Int(0),
ContainerPath: pulumi.String("string"),
MountOptions: pulumi.StringArray{
pulumi.String("string"),
},
},
},
},
DnsServers: pulumi.StringArray{
pulumi.String("string"),
},
DisableNetworking: pulumi.Bool(false),
MountPoints: ecs.TaskDefinitionMountPointArray{
&ecs.TaskDefinitionMountPointArgs{
ContainerPath: pulumi.String("string"),
ReadOnly: pulumi.Bool(false),
SourceVolume: pulumi.String("string"),
},
},
MemoryReservation: pulumi.Int(0),
Cpu: pulumi.Int(0),
PortMappings: ecs.TaskDefinitionPortMappingArray{
&ecs.TaskDefinitionPortMappingArgs{
AppProtocol: ecs.TaskDefinitionPortMappingAppProtocolHttp,
ContainerPort: pulumi.Int(0),
ContainerPortRange: pulumi.String("string"),
HostPort: pulumi.Int(0),
Name: pulumi.String("string"),
Protocol: pulumi.String("string"),
TargetGroup: pulumi.Any(targetGroup),
},
},
Privileged: pulumi.Bool(false),
PseudoTerminal: pulumi.Bool(false),
ReadonlyRootFilesystem: pulumi.Bool(false),
RepositoryCredentials: &ecs.TaskDefinitionRepositoryCredentialsArgs{
CredentialsParameter: pulumi.String("string"),
},
ResourceRequirements: ecs.TaskDefinitionResourceRequirementArray{
&ecs.TaskDefinitionResourceRequirementArgs{
Type: pulumi.String("string"),
Value: pulumi.String("string"),
},
},
Secrets: ecs.TaskDefinitionSecretArray{
&ecs.TaskDefinitionSecretArgs{
Name: pulumi.String("string"),
ValueFrom: pulumi.String("string"),
},
},
StartTimeout: pulumi.Int(0),
StopTimeout: pulumi.Int(0),
SystemControls: ecs.TaskDefinitionSystemControlArray{
&ecs.TaskDefinitionSystemControlArgs{
Namespace: pulumi.String("string"),
Value: pulumi.String("string"),
},
},
Ulimits: ecs.TaskDefinitionUlimitArray{
&ecs.TaskDefinitionUlimitArgs{
HardLimit: pulumi.Int(0),
Name: pulumi.String("string"),
SoftLimit: pulumi.Int(0),
},
},
User: pulumi.String("string"),
Memory: pulumi.Int(0),
WorkingDirectory: pulumi.String("string"),
},
},
Cpu: pulumi.String("string"),
EphemeralStorage: &ecs.TaskDefinitionEphemeralStorageArgs{
SizeInGib: pulumi.Int(0),
},
ExecutionRole: &awsx.DefaultRoleWithPolicyArgs{
Args: &awsx.RoleWithPolicyArgs{
Description: pulumi.String("string"),
ForceDetachPolicies: pulumi.Bool(false),
InlinePolicies: iam.RoleInlinePolicyArray{
&iam.RoleInlinePolicyArgs{
Name: pulumi.String("string"),
Policy: pulumi.String("string"),
},
},
ManagedPolicyArns: pulumi.StringArray{
pulumi.String("string"),
},
MaxSessionDuration: pulumi.Int(0),
Name: pulumi.String("string"),
NamePrefix: pulumi.String("string"),
Path: pulumi.String("string"),
PermissionsBoundary: pulumi.String("string"),
PolicyArns: []string{
"string",
},
Tags: pulumi.StringMap{
"string": pulumi.String("string"),
},
},
RoleArn: pulumi.String("string"),
Skip: false,
},
Family: pulumi.String("string"),
InferenceAccelerators: ecs.TaskDefinitionInferenceAcceleratorArray{
&ecs.TaskDefinitionInferenceAcceleratorArgs{
DeviceName: pulumi.String("string"),
DeviceType: pulumi.String("string"),
},
},
IpcMode: pulumi.String("string"),
LogGroup: &awsx.DefaultLogGroupArgs{
Args: &awsx.LogGroupArgs{
KmsKeyId: pulumi.String("string"),
LogGroupClass: pulumi.String("string"),
Name: pulumi.String("string"),
NamePrefix: pulumi.String("string"),
RetentionInDays: pulumi.Int(0),
SkipDestroy: pulumi.Bool(false),
Tags: pulumi.StringMap{
"string": pulumi.String("string"),
},
},
Existing: &awsx.ExistingLogGroupArgs{
Arn: pulumi.String("string"),
Name: pulumi.String("string"),
Region: pulumi.String("string"),
},
Skip: false,
},
Memory: pulumi.String("string"),
PidMode: pulumi.String("string"),
PlacementConstraints: ecs.TaskDefinitionPlacementConstraintArray{
&ecs.TaskDefinitionPlacementConstraintArgs{
Type: pulumi.String("string"),
Expression: pulumi.String("string"),
},
},
ProxyConfiguration: &ecs.TaskDefinitionProxyConfigurationArgs{
ContainerName: pulumi.String("string"),
Properties: pulumi.StringMap{
"string": pulumi.String("string"),
},
Type: pulumi.String("string"),
},
RuntimePlatform: &ecs.TaskDefinitionRuntimePlatformArgs{
CpuArchitecture: pulumi.String("string"),
OperatingSystemFamily: pulumi.String("string"),
},
SkipDestroy: pulumi.Bool(false),
Tags: pulumi.StringMap{
"string": pulumi.String("string"),
},
TaskRole: &awsx.DefaultRoleWithPolicyArgs{
Args: &awsx.RoleWithPolicyArgs{
Description: pulumi.String("string"),
ForceDetachPolicies: pulumi.Bool(false),
InlinePolicies: iam.RoleInlinePolicyArray{
&iam.RoleInlinePolicyArgs{
Name: pulumi.String("string"),
Policy: pulumi.String("string"),
},
},
ManagedPolicyArns: pulumi.StringArray{
pulumi.String("string"),
},
MaxSessionDuration: pulumi.Int(0),
Name: pulumi.String("string"),
NamePrefix: pulumi.String("string"),
Path: pulumi.String("string"),
PermissionsBoundary: pulumi.String("string"),
PolicyArns: []string{
"string",
},
Tags: pulumi.StringMap{
"string": pulumi.String("string"),
},
},
RoleArn: pulumi.String("string"),
Skip: false,
},
TrackLatest: pulumi.Bool(false),
Volumes: ecs.TaskDefinitionVolumeArray{
&ecs.TaskDefinitionVolumeArgs{
Name: pulumi.String("string"),
ConfigureAtLaunch: pulumi.Bool(false),
DockerVolumeConfiguration: &ecs.TaskDefinitionVolumeDockerVolumeConfigurationArgs{
Autoprovision: pulumi.Bool(false),
Driver: pulumi.String("string"),
DriverOpts: pulumi.StringMap{
"string": pulumi.String("string"),
},
Labels: pulumi.StringMap{
"string": pulumi.String("string"),
},
Scope: pulumi.String("string"),
},
EfsVolumeConfiguration: &ecs.TaskDefinitionVolumeEfsVolumeConfigurationArgs{
FileSystemId: pulumi.String("string"),
AuthorizationConfig: &ecs.TaskDefinitionVolumeEfsVolumeConfigurationAuthorizationConfigArgs{
AccessPointId: pulumi.String("string"),
Iam: pulumi.String("string"),
},
RootDirectory: pulumi.String("string"),
TransitEncryption: pulumi.String("string"),
TransitEncryptionPort: pulumi.Int(0),
},
FsxWindowsFileServerVolumeConfiguration: &ecs.TaskDefinitionVolumeFsxWindowsFileServerVolumeConfigurationArgs{
AuthorizationConfig: &ecs.TaskDefinitionVolumeFsxWindowsFileServerVolumeConfigurationAuthorizationConfigArgs{
CredentialsParameter: pulumi.String("string"),
Domain: pulumi.String("string"),
},
FileSystemId: pulumi.String("string"),
RootDirectory: pulumi.String("string"),
},
HostPath: pulumi.String("string"),
},
},
},
Triggers: pulumi.StringMap{
"string": pulumi.String("string"),
},
VolumeConfiguration: &ecs.ServiceVolumeConfigurationArgs{
ManagedEbsVolume: &ecs.ServiceVolumeConfigurationManagedEbsVolumeArgs{
RoleArn: pulumi.String("string"),
Encrypted: pulumi.Bool(false),
FileSystemType: pulumi.String("string"),
Iops: pulumi.Int(0),
KmsKeyId: pulumi.String("string"),
SizeInGb: pulumi.Int(0),
SnapshotId: pulumi.String("string"),
Throughput: pulumi.Int(0),
VolumeType: pulumi.String("string"),
},
Name: pulumi.String("string"),
},
})
var fargateServiceResource = new FargateService("fargateServiceResource", FargateServiceArgs.builder()
.alarms(ServiceAlarmsArgs.builder()
.alarmNames("string")
.enable(false)
.rollback(false)
.build())
.assignPublicIp(false)
.cluster("string")
.continueBeforeSteadyState(false)
.deploymentCircuitBreaker(ServiceDeploymentCircuitBreakerArgs.builder()
.enable(false)
.rollback(false)
.build())
.deploymentController(ServiceDeploymentControllerArgs.builder()
.type("string")
.build())
.deploymentMaximumPercent(0)
.deploymentMinimumHealthyPercent(0)
.desiredCount(0)
.enableEcsManagedTags(false)
.enableExecuteCommand(false)
.forceNewDeployment(false)
.healthCheckGracePeriodSeconds(0)
.iamRole("string")
.loadBalancers(ServiceLoadBalancerArgs.builder()
.containerName("string")
.containerPort(0)
.elbName("string")
.targetGroupArn("string")
.build())
.name("string")
.networkConfiguration(ServiceNetworkConfigurationArgs.builder()
.subnets("string")
.assignPublicIp(false)
.securityGroups("string")
.build())
.placementConstraints(ServicePlacementConstraintArgs.builder()
.type("string")
.expression("string")
.build())
.platformVersion("string")
.propagateTags("string")
.schedulingStrategy("string")
.serviceConnectConfiguration(ServiceServiceConnectConfigurationArgs.builder()
.enabled(false)
.logConfiguration(ServiceServiceConnectConfigurationLogConfigurationArgs.builder()
.logDriver("string")
.options(Map.of("string", "string"))
.secretOptions(ServiceServiceConnectConfigurationLogConfigurationSecretOptionArgs.builder()
.name("string")
.valueFrom("string")
.build())
.build())
.namespace("string")
.services(ServiceServiceConnectConfigurationServiceArgs.builder()
.portName("string")
.clientAlias(ServiceServiceConnectConfigurationServiceClientAliasArgs.builder()
.port(0)
.dnsName("string")
.build())
.discoveryName("string")
.ingressPortOverride(0)
.timeout(ServiceServiceConnectConfigurationServiceTimeoutArgs.builder()
.idleTimeoutSeconds(0)
.perRequestTimeoutSeconds(0)
.build())
.tls(ServiceServiceConnectConfigurationServiceTlsArgs.builder()
.issuerCertAuthority(ServiceServiceConnectConfigurationServiceTlsIssuerCertAuthorityArgs.builder()
.awsPcaAuthorityArn("string")
.build())
.kmsKey("string")
.roleArn("string")
.build())
.build())
.build())
.serviceRegistries(ServiceServiceRegistriesArgs.builder()
.registryArn("string")
.containerName("string")
.containerPort(0)
.port(0)
.build())
.tags(Map.of("string", "string"))
.taskDefinition("string")
.taskDefinitionArgs(FargateServiceTaskDefinitionArgs.builder()
.container(TaskDefinitionContainerDefinitionArgs.builder()
.image("string")
.name("string")
.links("string")
.volumesFrom(TaskDefinitionVolumeFromArgs.builder()
.readOnly(false)
.sourceContainer("string")
.build())
.dnsSearchDomains("string")
.logConfiguration(TaskDefinitionLogConfigurationArgs.builder()
.logDriver("string")
.options("any")
.secretOptions(TaskDefinitionSecretArgs.builder()
.name("string")
.valueFrom("string")
.build())
.build())
.dockerLabels("any")
.dockerSecurityOptions("string")
.entryPoint("string")
.environment(TaskDefinitionKeyValuePairArgs.builder()
.name("string")
.value("string")
.build())
.environmentFiles(TaskDefinitionEnvironmentFileArgs.builder()
.type("string")
.value("string")
.build())
.essential(false)
.extraHosts(TaskDefinitionHostEntryArgs.builder()
.hostname("string")
.ipAddress("string")
.build())
.firelensConfiguration(TaskDefinitionFirelensConfigurationArgs.builder()
.options("any")
.type("string")
.build())
.healthCheck(TaskDefinitionHealthCheckArgs.builder()
.command("string")
.interval(0)
.retries(0)
.startPeriod(0)
.timeout(0)
.build())
.hostname("string")
.dependsOn(TaskDefinitionContainerDependencyArgs.builder()
.condition("string")
.containerName("string")
.build())
.interactive(false)
.command("string")
.linuxParameters(TaskDefinitionLinuxParametersArgs.builder()
.capabilities(TaskDefinitionKernelCapabilitiesArgs.builder()
.add("string")
.drop("string")
.build())
.devices(TaskDefinitionDeviceArgs.builder()
.containerPath("string")
.hostPath("string")
.permissions("string")
.build())
.initProcessEnabled(false)
.maxSwap(0)
.sharedMemorySize(0)
.swappiness(0)
.tmpfs(TaskDefinitionTmpfsArgs.builder()
.size(0)
.containerPath("string")
.mountOptions("string")
.build())
.build())
.dnsServers("string")
.disableNetworking(false)
.mountPoints(TaskDefinitionMountPointArgs.builder()
.containerPath("string")
.readOnly(false)
.sourceVolume("string")
.build())
.memoryReservation(0)
.cpu(0)
.portMappings(TaskDefinitionPortMappingArgs.builder()
.appProtocol("http")
.containerPort(0)
.containerPortRange("string")
.hostPort(0)
.name("string")
.protocol("string")
.targetGroup(targetGroup)
.build())
.privileged(false)
.pseudoTerminal(false)
.readonlyRootFilesystem(false)
.repositoryCredentials(TaskDefinitionRepositoryCredentialsArgs.builder()
.credentialsParameter("string")
.build())
.resourceRequirements(TaskDefinitionResourceRequirementArgs.builder()
.type("string")
.value("string")
.build())
.secrets(TaskDefinitionSecretArgs.builder()
.name("string")
.valueFrom("string")
.build())
.startTimeout(0)
.stopTimeout(0)
.systemControls(TaskDefinitionSystemControlArgs.builder()
.namespace("string")
.value("string")
.build())
.ulimits(TaskDefinitionUlimitArgs.builder()
.hardLimit(0)
.name("string")
.softLimit(0)
.build())
.user("string")
.memory(0)
.workingDirectory("string")
.build())
.containers(Map.of("string", Map.ofEntries(
Map.entry("image", "string"),
Map.entry("name", "string"),
Map.entry("links", "string"),
Map.entry("volumesFrom", Map.ofEntries(
Map.entry("readOnly", false),
Map.entry("sourceContainer", "string")
)),
Map.entry("dnsSearchDomains", "string"),
Map.entry("logConfiguration", Map.ofEntries(
Map.entry("logDriver", "string"),
Map.entry("options", "any"),
Map.entry("secretOptions", Map.ofEntries(
Map.entry("name", "string"),
Map.entry("valueFrom", "string")
))
)),
Map.entry("dockerLabels", "any"),
Map.entry("dockerSecurityOptions", "string"),
Map.entry("entryPoint", "string"),
Map.entry("environment", Map.ofEntries(
Map.entry("name", "string"),
Map.entry("value", "string")
)),
Map.entry("environmentFiles", Map.ofEntries(
Map.entry("type", "string"),
Map.entry("value", "string")
)),
Map.entry("essential", false),
Map.entry("extraHosts", Map.ofEntries(
Map.entry("hostname", "string"),
Map.entry("ipAddress", "string")
)),
Map.entry("firelensConfiguration", Map.ofEntries(
Map.entry("options", "any"),
Map.entry("type", "string")
)),
Map.entry("healthCheck", Map.ofEntries(
Map.entry("command", "string"),
Map.entry("interval", 0),
Map.entry("retries", 0),
Map.entry("startPeriod", 0),
Map.entry("timeout", 0)
)),
Map.entry("hostname", "string"),
Map.entry("dependsOn", Map.ofEntries(
Map.entry("condition", "string"),
Map.entry("containerName", "string")
)),
Map.entry("interactive", false),
Map.entry("command", "string"),
Map.entry("linuxParameters", Map.ofEntries(
Map.entry("capabilities", Map.ofEntries(
Map.entry("add", "string"),
Map.entry("drop", "string")
)),
Map.entry("devices", Map.ofEntries(
Map.entry("containerPath", "string"),
Map.entry("hostPath", "string"),
Map.entry("permissions", "string")
)),
Map.entry("initProcessEnabled", false),
Map.entry("maxSwap", 0),
Map.entry("sharedMemorySize", 0),
Map.entry("swappiness", 0),
Map.entry("tmpfs", Map.ofEntries(
Map.entry("size", 0),
Map.entry("containerPath", "string"),
Map.entry("mountOptions", "string")
))
)),
Map.entry("dnsServers", "string"),
Map.entry("disableNetworking", false),
Map.entry("mountPoints", Map.ofEntries(
Map.entry("containerPath", "string"),
Map.entry("readOnly", false),
Map.entry("sourceVolume", "string")
)),
Map.entry("memoryReservation", 0),
Map.entry("cpu", 0),
Map.entry("portMappings", Map.ofEntries(
Map.entry("appProtocol", "http"),
Map.entry("containerPort", 0),
Map.entry("containerPortRange", "string"),
Map.entry("hostPort", 0),
Map.entry("name", "string"),
Map.entry("protocol", "string"),
Map.entry("targetGroup", targetGroup)
)),
Map.entry("privileged", false),
Map.entry("pseudoTerminal", false),
Map.entry("readonlyRootFilesystem", false),
Map.entry("repositoryCredentials", Map.of("credentialsParameter", "string")),
Map.entry("resourceRequirements", Map.ofEntries(
Map.entry("type", "string"),
Map.entry("value", "string")
)),
Map.entry("secrets", Map.ofEntries(
Map.entry("name", "string"),
Map.entry("valueFrom", "string")
)),
Map.entry("startTimeout", 0),
Map.entry("stopTimeout", 0),
Map.entry("systemControls", Map.ofEntries(
Map.entry("namespace", "string"),
Map.entry("value", "string")
)),
Map.entry("ulimits", Map.ofEntries(
Map.entry("hardLimit", 0),
Map.entry("name", "string"),
Map.entry("softLimit", 0)
)),
Map.entry("user", "string"),
Map.entry("memory", 0),
Map.entry("workingDirectory", "string")
)))
.cpu("string")
.ephemeralStorage(TaskDefinitionEphemeralStorageArgs.builder()
.sizeInGib(0)
.build())
.executionRole(DefaultRoleWithPolicyArgs.builder()
.args(RoleWithPolicyArgs.builder()
.description("string")
.forceDetachPolicies(false)
.inlinePolicies(RoleInlinePolicyArgs.builder()
.name("string")
.policy("string")
.build())
.managedPolicyArns("string")
.maxSessionDuration(0)
.name("string")
.namePrefix("string")
.path("string")
.permissionsBoundary("string")
.policyArns("string")
.tags(Map.of("string", "string"))
.build())
.roleArn("string")
.skip(false)
.build())
.family("string")
.inferenceAccelerators(TaskDefinitionInferenceAcceleratorArgs.builder()
.deviceName("string")
.deviceType("string")
.build())
.ipcMode("string")
.logGroup(DefaultLogGroupArgs.builder()
.args(LogGroupArgs.builder()
.kmsKeyId("string")
.logGroupClass("string")
.name("string")
.namePrefix("string")
.retentionInDays(0)
.skipDestroy(false)
.tags(Map.of("string", "string"))
.build())
.existing(ExistingLogGroupArgs.builder()
.arn("string")
.name("string")
.region("string")
.build())
.skip(false)
.build())
.memory("string")
.pidMode("string")
.placementConstraints(TaskDefinitionPlacementConstraintArgs.builder()
.type("string")
.expression("string")
.build())
.proxyConfiguration(TaskDefinitionProxyConfigurationArgs.builder()
.containerName("string")
.properties(Map.of("string", "string"))
.type("string")
.build())
.runtimePlatform(TaskDefinitionRuntimePlatformArgs.builder()
.cpuArchitecture("string")
.operatingSystemFamily("string")
.build())
.skipDestroy(false)
.tags(Map.of("string", "string"))
.taskRole(DefaultRoleWithPolicyArgs.builder()
.args(RoleWithPolicyArgs.builder()
.description("string")
.forceDetachPolicies(false)
.inlinePolicies(RoleInlinePolicyArgs.builder()
.name("string")
.policy("string")
.build())
.managedPolicyArns("string")
.maxSessionDuration(0)
.name("string")
.namePrefix("string")
.path("string")
.permissionsBoundary("string")
.policyArns("string")
.tags(Map.of("string", "string"))
.build())
.roleArn("string")
.skip(false)
.build())
.trackLatest(false)
.volumes(TaskDefinitionVolumeArgs.builder()
.name("string")
.configureAtLaunch(false)
.dockerVolumeConfiguration(TaskDefinitionVolumeDockerVolumeConfigurationArgs.builder()
.autoprovision(false)
.driver("string")
.driverOpts(Map.of("string", "string"))
.labels(Map.of("string", "string"))
.scope("string")
.build())
.efsVolumeConfiguration(TaskDefinitionVolumeEfsVolumeConfigurationArgs.builder()
.fileSystemId("string")
.authorizationConfig(TaskDefinitionVolumeEfsVolumeConfigurationAuthorizationConfigArgs.builder()
.accessPointId("string")
.iam("string")
.build())
.rootDirectory("string")
.transitEncryption("string")
.transitEncryptionPort(0)
.build())
.fsxWindowsFileServerVolumeConfiguration(TaskDefinitionVolumeFsxWindowsFileServerVolumeConfigurationArgs.builder()
.authorizationConfig(TaskDefinitionVolumeFsxWindowsFileServerVolumeConfigurationAuthorizationConfigArgs.builder()
.credentialsParameter("string")
.domain("string")
.build())
.fileSystemId("string")
.rootDirectory("string")
.build())
.hostPath("string")
.build())
.build())
.triggers(Map.of("string", "string"))
.volumeConfiguration(ServiceVolumeConfigurationArgs.builder()
.managedEbsVolume(ServiceVolumeConfigurationManagedEbsVolumeArgs.builder()
.roleArn("string")
.encrypted(false)
.fileSystemType("string")
.iops(0)
.kmsKeyId("string")
.sizeInGb(0)
.snapshotId("string")
.throughput(0)
.volumeType("string")
.build())
.name("string")
.build())
.build());
fargate_service_resource = awsx.ecs.FargateService("fargateServiceResource",
alarms={
"alarmNames": ["string"],
"enable": False,
"rollback": False,
},
assign_public_ip=False,
cluster="string",
continue_before_steady_state=False,
deployment_circuit_breaker={
"enable": False,
"rollback": False,
},
deployment_controller={
"type": "string",
},
deployment_maximum_percent=0,
deployment_minimum_healthy_percent=0,
desired_count=0,
enable_ecs_managed_tags=False,
enable_execute_command=False,
force_new_deployment=False,
health_check_grace_period_seconds=0,
iam_role="string",
load_balancers=[{
"containerName": "string",
"containerPort": 0,
"elbName": "string",
"targetGroupArn": "string",
}],
name="string",
network_configuration={
"subnets": ["string"],
"assignPublicIp": False,
"securityGroups": ["string"],
},
placement_constraints=[{
"type": "string",
"expression": "string",
}],
platform_version="string",
propagate_tags="string",
scheduling_strategy="string",
service_connect_configuration={
"enabled": False,
"logConfiguration": {
"logDriver": "string",
"options": {
"string": "string",
},
"secretOptions": [{
"name": "string",
"valueFrom": "string",
}],
},
"namespace": "string",
"services": [{
"portName": "string",
"clientAlias": [{
"port": 0,
"dnsName": "string",
}],
"discoveryName": "string",
"ingressPortOverride": 0,
"timeout": {
"idleTimeoutSeconds": 0,
"perRequestTimeoutSeconds": 0,
},
"tls": {
"issuerCertAuthority": {
"awsPcaAuthorityArn": "string",
},
"kmsKey": "string",
"roleArn": "string",
},
}],
},
service_registries={
"registryArn": "string",
"containerName": "string",
"containerPort": 0,
"port": 0,
},
tags={
"string": "string",
},
task_definition="string",
task_definition_args=awsx.ecs.FargateServiceTaskDefinitionArgs(
container=awsx.ecs.TaskDefinitionContainerDefinitionArgs(
image="string",
name="string",
links=["string"],
volumes_from=[awsx.ecs.TaskDefinitionVolumeFromArgs(
read_only=False,
source_container="string",
)],
dns_search_domains=["string"],
log_configuration=awsx.ecs.TaskDefinitionLogConfigurationArgs(
log_driver="string",
options="any",
secret_options=[awsx.ecs.TaskDefinitionSecretArgs(
name="string",
value_from="string",
)],
),
docker_labels="any",
docker_security_options=["string"],
entry_point=["string"],
environment=[awsx.ecs.TaskDefinitionKeyValuePairArgs(
name="string",
value="string",
)],
environment_files=[awsx.ecs.TaskDefinitionEnvironmentFileArgs(
type="string",
value="string",
)],
essential=False,
extra_hosts=[awsx.ecs.TaskDefinitionHostEntryArgs(
hostname="string",
ip_address="string",
)],
firelens_configuration=awsx.ecs.TaskDefinitionFirelensConfigurationArgs(
options="any",
type="string",
),
health_check=awsx.ecs.TaskDefinitionHealthCheckArgs(
command=["string"],
interval=0,
retries=0,
start_period=0,
timeout=0,
),
hostname="string",
depends_on=[awsx.ecs.TaskDefinitionContainerDependencyArgs(
condition="string",
container_name="string",
)],
interactive=False,
command=["string"],
linux_parameters=awsx.ecs.TaskDefinitionLinuxParametersArgs(
capabilities=awsx.ecs.TaskDefinitionKernelCapabilitiesArgs(
add=["string"],
drop=["string"],
),
devices=[awsx.ecs.TaskDefinitionDeviceArgs(
container_path="string",
host_path="string",
permissions=["string"],
)],
init_process_enabled=False,
max_swap=0,
shared_memory_size=0,
swappiness=0,
tmpfs=[awsx.ecs.TaskDefinitionTmpfsArgs(
size=0,
container_path="string",
mount_options=["string"],
)],
),
dns_servers=["string"],
disable_networking=False,
mount_points=[awsx.ecs.TaskDefinitionMountPointArgs(
container_path="string",
read_only=False,
source_volume="string",
)],
memory_reservation=0,
cpu=0,
port_mappings=[awsx.ecs.TaskDefinitionPortMappingArgs(
app_protocol=awsx.ecs.TaskDefinitionPortMappingAppProtocol.HTTP,
container_port=0,
container_port_range="string",
host_port=0,
name="string",
protocol="string",
target_group=target_group,
)],
privileged=False,
pseudo_terminal=False,
readonly_root_filesystem=False,
repository_credentials=awsx.ecs.TaskDefinitionRepositoryCredentialsArgs(
credentials_parameter="string",
),
resource_requirements=[awsx.ecs.TaskDefinitionResourceRequirementArgs(
type="string",
value="string",
)],
secrets=[awsx.ecs.TaskDefinitionSecretArgs(
name="string",
value_from="string",
)],
start_timeout=0,
stop_timeout=0,
system_controls=[awsx.ecs.TaskDefinitionSystemControlArgs(
namespace="string",
value="string",
)],
ulimits=[awsx.ecs.TaskDefinitionUlimitArgs(
hard_limit=0,
name="string",
soft_limit=0,
)],
user="string",
memory=0,
working_directory="string",
),
containers={
"string": awsx.ecs.TaskDefinitionContainerDefinitionArgs(
image="string",
name="string",
links=["string"],
volumes_from=[awsx.ecs.TaskDefinitionVolumeFromArgs(
read_only=False,
source_container="string",
)],
dns_search_domains=["string"],
log_configuration=awsx.ecs.TaskDefinitionLogConfigurationArgs(
log_driver="string",
options="any",
secret_options=[awsx.ecs.TaskDefinitionSecretArgs(
name="string",
value_from="string",
)],
),
docker_labels="any",
docker_security_options=["string"],
entry_point=["string"],
environment=[awsx.ecs.TaskDefinitionKeyValuePairArgs(
name="string",
value="string",
)],
environment_files=[awsx.ecs.TaskDefinitionEnvironmentFileArgs(
type="string",
value="string",
)],
essential=False,
extra_hosts=[awsx.ecs.TaskDefinitionHostEntryArgs(
hostname="string",
ip_address="string",
)],
firelens_configuration=awsx.ecs.TaskDefinitionFirelensConfigurationArgs(
options="any",
type="string",
),
health_check=awsx.ecs.TaskDefinitionHealthCheckArgs(
command=["string"],
interval=0,
retries=0,
start_period=0,
timeout=0,
),
hostname="string",
depends_on=[awsx.ecs.TaskDefinitionContainerDependencyArgs(
condition="string",
container_name="string",
)],
interactive=False,
command=["string"],
linux_parameters=awsx.ecs.TaskDefinitionLinuxParametersArgs(
capabilities=awsx.ecs.TaskDefinitionKernelCapabilitiesArgs(
add=["string"],
drop=["string"],
),
devices=[awsx.ecs.TaskDefinitionDeviceArgs(
container_path="string",
host_path="string",
permissions=["string"],
)],
init_process_enabled=False,
max_swap=0,
shared_memory_size=0,
swappiness=0,
tmpfs=[awsx.ecs.TaskDefinitionTmpfsArgs(
size=0,
container_path="string",
mount_options=["string"],
)],
),
dns_servers=["string"],
disable_networking=False,
mount_points=[awsx.ecs.TaskDefinitionMountPointArgs(
container_path="string",
read_only=False,
source_volume="string",
)],
memory_reservation=0,
cpu=0,
port_mappings=[awsx.ecs.TaskDefinitionPortMappingArgs(
app_protocol=awsx.ecs.TaskDefinitionPortMappingAppProtocol.HTTP,
container_port=0,
container_port_range="string",
host_port=0,
name="string",
protocol="string",
target_group=target_group,
)],
privileged=False,
pseudo_terminal=False,
readonly_root_filesystem=False,
repository_credentials=awsx.ecs.TaskDefinitionRepositoryCredentialsArgs(
credentials_parameter="string",
),
resource_requirements=[awsx.ecs.TaskDefinitionResourceRequirementArgs(
type="string",
value="string",
)],
secrets=[awsx.ecs.TaskDefinitionSecretArgs(
name="string",
value_from="string",
)],
start_timeout=0,
stop_timeout=0,
system_controls=[awsx.ecs.TaskDefinitionSystemControlArgs(
namespace="string",
value="string",
)],
ulimits=[awsx.ecs.TaskDefinitionUlimitArgs(
hard_limit=0,
name="string",
soft_limit=0,
)],
user="string",
memory=0,
working_directory="string",
),
},
cpu="string",
ephemeral_storage={
"sizeInGib": 0,
},
execution_role=awsx.awsx.DefaultRoleWithPolicyArgs(
args=awsx.awsx.RoleWithPolicyArgs(
description="string",
force_detach_policies=False,
inline_policies=[{
"name": "string",
"policy": "string",
}],
managed_policy_arns=["string"],
max_session_duration=0,
name="string",
name_prefix="string",
path="string",
permissions_boundary="string",
policy_arns=["string"],
tags={
"string": "string",
},
),
role_arn="string",
skip=False,
),
family="string",
inference_accelerators=[{
"deviceName": "string",
"deviceType": "string",
}],
ipc_mode="string",
log_group=awsx.awsx.DefaultLogGroupArgs(
args=awsx.awsx.LogGroupArgs(
kms_key_id="string",
log_group_class="string",
name="string",
name_prefix="string",
retention_in_days=0,
skip_destroy=False,
tags={
"string": "string",
},
),
existing=awsx.awsx.ExistingLogGroupArgs(
arn="string",
name="string",
region="string",
),
skip=False,
),
memory="string",
pid_mode="string",
placement_constraints=[{
"type": "string",
"expression": "string",
}],
proxy_configuration={
"containerName": "string",
"properties": {
"string": "string",
},
"type": "string",
},
runtime_platform={
"cpuArchitecture": "string",
"operatingSystemFamily": "string",
},
skip_destroy=False,
tags={
"string": "string",
},
task_role=awsx.awsx.DefaultRoleWithPolicyArgs(
args=awsx.awsx.RoleWithPolicyArgs(
description="string",
force_detach_policies=False,
inline_policies=[{
"name": "string",
"policy": "string",
}],
managed_policy_arns=["string"],
max_session_duration=0,
name="string",
name_prefix="string",
path="string",
permissions_boundary="string",
policy_arns=["string"],
tags={
"string": "string",
},
),
role_arn="string",
skip=False,
),
track_latest=False,
volumes=[{
"name": "string",
"configureAtLaunch": False,
"dockerVolumeConfiguration": {
"autoprovision": False,
"driver": "string",
"driverOpts": {
"string": "string",
},
"labels": {
"string": "string",
},
"scope": "string",
},
"efsVolumeConfiguration": {
"fileSystemId": "string",
"authorizationConfig": {
"accessPointId": "string",
"iam": "string",
},
"rootDirectory": "string",
"transitEncryption": "string",
"transitEncryptionPort": 0,
},
"fsxWindowsFileServerVolumeConfiguration": {
"authorizationConfig": {
"credentialsParameter": "string",
"domain": "string",
},
"fileSystemId": "string",
"rootDirectory": "string",
},
"hostPath": "string",
}],
),
triggers={
"string": "string",
},
volume_configuration={
"managedEbsVolume": {
"roleArn": "string",
"encrypted": False,
"fileSystemType": "string",
"iops": 0,
"kmsKeyId": "string",
"sizeInGb": 0,
"snapshotId": "string",
"throughput": 0,
"volumeType": "string",
},
"name": "string",
})
const fargateServiceResource = new awsx.ecs.FargateService("fargateServiceResource", {
alarms: {
alarmNames: ["string"],
enable: false,
rollback: false,
},
assignPublicIp: false,
cluster: "string",
continueBeforeSteadyState: false,
deploymentCircuitBreaker: {
enable: false,
rollback: false,
},
deploymentController: {
type: "string",
},
deploymentMaximumPercent: 0,
deploymentMinimumHealthyPercent: 0,
desiredCount: 0,
enableEcsManagedTags: false,
enableExecuteCommand: false,
forceNewDeployment: false,
healthCheckGracePeriodSeconds: 0,
iamRole: "string",
loadBalancers: [{
containerName: "string",
containerPort: 0,
elbName: "string",
targetGroupArn: "string",
}],
name: "string",
networkConfiguration: {
subnets: ["string"],
assignPublicIp: false,
securityGroups: ["string"],
},
placementConstraints: [{
type: "string",
expression: "string",
}],
platformVersion: "string",
propagateTags: "string",
schedulingStrategy: "string",
serviceConnectConfiguration: {
enabled: false,
logConfiguration: {
logDriver: "string",
options: {
string: "string",
},
secretOptions: [{
name: "string",
valueFrom: "string",
}],
},
namespace: "string",
services: [{
portName: "string",
clientAlias: [{
port: 0,
dnsName: "string",
}],
discoveryName: "string",
ingressPortOverride: 0,
timeout: {
idleTimeoutSeconds: 0,
perRequestTimeoutSeconds: 0,
},
tls: {
issuerCertAuthority: {
awsPcaAuthorityArn: "string",
},
kmsKey: "string",
roleArn: "string",
},
}],
},
serviceRegistries: {
registryArn: "string",
containerName: "string",
containerPort: 0,
port: 0,
},
tags: {
string: "string",
},
taskDefinition: "string",
taskDefinitionArgs: {
container: {
image: "string",
name: "string",
links: ["string"],
volumesFrom: [{
readOnly: false,
sourceContainer: "string",
}],
dnsSearchDomains: ["string"],
logConfiguration: {
logDriver: "string",
options: "any",
secretOptions: [{
name: "string",
valueFrom: "string",
}],
},
dockerLabels: "any",
dockerSecurityOptions: ["string"],
entryPoint: ["string"],
environment: [{
name: "string",
value: "string",
}],
environmentFiles: [{
type: "string",
value: "string",
}],
essential: false,
extraHosts: [{
hostname: "string",
ipAddress: "string",
}],
firelensConfiguration: {
options: "any",
type: "string",
},
healthCheck: {
command: ["string"],
interval: 0,
retries: 0,
startPeriod: 0,
timeout: 0,
},
hostname: "string",
dependsOn: [{
condition: "string",
containerName: "string",
}],
interactive: false,
command: ["string"],
linuxParameters: {
capabilities: {
add: ["string"],
drop: ["string"],
},
devices: [{
containerPath: "string",
hostPath: "string",
permissions: ["string"],
}],
initProcessEnabled: false,
maxSwap: 0,
sharedMemorySize: 0,
swappiness: 0,
tmpfs: [{
size: 0,
containerPath: "string",
mountOptions: ["string"],
}],
},
dnsServers: ["string"],
disableNetworking: false,
mountPoints: [{
containerPath: "string",
readOnly: false,
sourceVolume: "string",
}],
memoryReservation: 0,
cpu: 0,
portMappings: [{
appProtocol: awsx.ecs.TaskDefinitionPortMappingAppProtocol.Http,
containerPort: 0,
containerPortRange: "string",
hostPort: 0,
name: "string",
protocol: "string",
targetGroup: targetGroup,
}],
privileged: false,
pseudoTerminal: false,
readonlyRootFilesystem: false,
repositoryCredentials: {
credentialsParameter: "string",
},
resourceRequirements: [{
type: "string",
value: "string",
}],
secrets: [{
name: "string",
valueFrom: "string",
}],
startTimeout: 0,
stopTimeout: 0,
systemControls: [{
namespace: "string",
value: "string",
}],
ulimits: [{
hardLimit: 0,
name: "string",
softLimit: 0,
}],
user: "string",
memory: 0,
workingDirectory: "string",
},
containers: {
string: {
image: "string",
name: "string",
links: ["string"],
volumesFrom: [{
readOnly: false,
sourceContainer: "string",
}],
dnsSearchDomains: ["string"],
logConfiguration: {
logDriver: "string",
options: "any",
secretOptions: [{
name: "string",
valueFrom: "string",
}],
},
dockerLabels: "any",
dockerSecurityOptions: ["string"],
entryPoint: ["string"],
environment: [{
name: "string",
value: "string",
}],
environmentFiles: [{
type: "string",
value: "string",
}],
essential: false,
extraHosts: [{
hostname: "string",
ipAddress: "string",
}],
firelensConfiguration: {
options: "any",
type: "string",
},
healthCheck: {
command: ["string"],
interval: 0,
retries: 0,
startPeriod: 0,
timeout: 0,
},
hostname: "string",
dependsOn: [{
condition: "string",
containerName: "string",
}],
interactive: false,
command: ["string"],
linuxParameters: {
capabilities: {
add: ["string"],
drop: ["string"],
},
devices: [{
containerPath: "string",
hostPath: "string",
permissions: ["string"],
}],
initProcessEnabled: false,
maxSwap: 0,
sharedMemorySize: 0,
swappiness: 0,
tmpfs: [{
size: 0,
containerPath: "string",
mountOptions: ["string"],
}],
},
dnsServers: ["string"],
disableNetworking: false,
mountPoints: [{
containerPath: "string",
readOnly: false,
sourceVolume: "string",
}],
memoryReservation: 0,
cpu: 0,
portMappings: [{
appProtocol: awsx.ecs.TaskDefinitionPortMappingAppProtocol.Http,
containerPort: 0,
containerPortRange: "string",
hostPort: 0,
name: "string",
protocol: "string",
targetGroup: targetGroup,
}],
privileged: false,
pseudoTerminal: false,
readonlyRootFilesystem: false,
repositoryCredentials: {
credentialsParameter: "string",
},
resourceRequirements: [{
type: "string",
value: "string",
}],
secrets: [{
name: "string",
valueFrom: "string",
}],
startTimeout: 0,
stopTimeout: 0,
systemControls: [{
namespace: "string",
value: "string",
}],
ulimits: [{
hardLimit: 0,
name: "string",
softLimit: 0,
}],
user: "string",
memory: 0,
workingDirectory: "string",
},
},
cpu: "string",
ephemeralStorage: {
sizeInGib: 0,
},
executionRole: {
args: {
description: "string",
forceDetachPolicies: false,
inlinePolicies: [{
name: "string",
policy: "string",
}],
managedPolicyArns: ["string"],
maxSessionDuration: 0,
name: "string",
namePrefix: "string",
path: "string",
permissionsBoundary: "string",
policyArns: ["string"],
tags: {
string: "string",
},
},
roleArn: "string",
skip: false,
},
family: "string",
inferenceAccelerators: [{
deviceName: "string",
deviceType: "string",
}],
ipcMode: "string",
logGroup: {
args: {
kmsKeyId: "string",
logGroupClass: "string",
name: "string",
namePrefix: "string",
retentionInDays: 0,
skipDestroy: false,
tags: {
string: "string",
},
},
existing: {
arn: "string",
name: "string",
region: "string",
},
skip: false,
},
memory: "string",
pidMode: "string",
placementConstraints: [{
type: "string",
expression: "string",
}],
proxyConfiguration: {
containerName: "string",
properties: {
string: "string",
},
type: "string",
},
runtimePlatform: {
cpuArchitecture: "string",
operatingSystemFamily: "string",
},
skipDestroy: false,
tags: {
string: "string",
},
taskRole: {
args: {
description: "string",
forceDetachPolicies: false,
inlinePolicies: [{
name: "string",
policy: "string",
}],
managedPolicyArns: ["string"],
maxSessionDuration: 0,
name: "string",
namePrefix: "string",
path: "string",
permissionsBoundary: "string",
policyArns: ["string"],
tags: {
string: "string",
},
},
roleArn: "string",
skip: false,
},
trackLatest: false,
volumes: [{
name: "string",
configureAtLaunch: false,
dockerVolumeConfiguration: {
autoprovision: false,
driver: "string",
driverOpts: {
string: "string",
},
labels: {
string: "string",
},
scope: "string",
},
efsVolumeConfiguration: {
fileSystemId: "string",
authorizationConfig: {
accessPointId: "string",
iam: "string",
},
rootDirectory: "string",
transitEncryption: "string",
transitEncryptionPort: 0,
},
fsxWindowsFileServerVolumeConfiguration: {
authorizationConfig: {
credentialsParameter: "string",
domain: "string",
},
fileSystemId: "string",
rootDirectory: "string",
},
hostPath: "string",
}],
},
triggers: {
string: "string",
},
volumeConfiguration: {
managedEbsVolume: {
roleArn: "string",
encrypted: false,
fileSystemType: "string",
iops: 0,
kmsKeyId: "string",
sizeInGb: 0,
snapshotId: "string",
throughput: 0,
volumeType: "string",
},
name: "string",
},
});
type: awsx:ecs:FargateService
properties:
alarms:
alarmNames:
- string
enable: false
rollback: false
assignPublicIp: false
cluster: string
continueBeforeSteadyState: false
deploymentCircuitBreaker:
enable: false
rollback: false
deploymentController:
type: string
deploymentMaximumPercent: 0
deploymentMinimumHealthyPercent: 0
desiredCount: 0
enableEcsManagedTags: false
enableExecuteCommand: false
forceNewDeployment: false
healthCheckGracePeriodSeconds: 0
iamRole: string
loadBalancers:
- containerName: string
containerPort: 0
elbName: string
targetGroupArn: string
name: string
networkConfiguration:
assignPublicIp: false
securityGroups:
- string
subnets:
- string
placementConstraints:
- expression: string
type: string
platformVersion: string
propagateTags: string
schedulingStrategy: string
serviceConnectConfiguration:
enabled: false
logConfiguration:
logDriver: string
options:
string: string
secretOptions:
- name: string
valueFrom: string
namespace: string
services:
- clientAlias:
- dnsName: string
port: 0
discoveryName: string
ingressPortOverride: 0
portName: string
timeout:
idleTimeoutSeconds: 0
perRequestTimeoutSeconds: 0
tls:
issuerCertAuthority:
awsPcaAuthorityArn: string
kmsKey: string
roleArn: string
serviceRegistries:
containerName: string
containerPort: 0
port: 0
registryArn: string
tags:
string: string
taskDefinition: string
taskDefinitionArgs:
container:
command:
- string
cpu: 0
dependsOn:
- condition: string
containerName: string
disableNetworking: false
dnsSearchDomains:
- string
dnsServers:
- string
dockerLabels: any
dockerSecurityOptions:
- string
entryPoint:
- string
environment:
- name: string
value: string
environmentFiles:
- type: string
value: string
essential: false
extraHosts:
- hostname: string
ipAddress: string
firelensConfiguration:
options: any
type: string
healthCheck:
command:
- string
interval: 0
retries: 0
startPeriod: 0
timeout: 0
hostname: string
image: string
interactive: false
links:
- string
linuxParameters:
capabilities:
add:
- string
drop:
- string
devices:
- containerPath: string
hostPath: string
permissions:
- string
initProcessEnabled: false
maxSwap: 0
sharedMemorySize: 0
swappiness: 0
tmpfs:
- containerPath: string
mountOptions:
- string
size: 0
logConfiguration:
logDriver: string
options: any
secretOptions:
- name: string
valueFrom: string
memory: 0
memoryReservation: 0
mountPoints:
- containerPath: string
readOnly: false
sourceVolume: string
name: string
portMappings:
- appProtocol: http
containerPort: 0
containerPortRange: string
hostPort: 0
name: string
protocol: string
targetGroup: ${targetGroup}
privileged: false
pseudoTerminal: false
readonlyRootFilesystem: false
repositoryCredentials:
credentialsParameter: string
resourceRequirements:
- type: string
value: string
secrets:
- name: string
valueFrom: string
startTimeout: 0
stopTimeout: 0
systemControls:
- namespace: string
value: string
ulimits:
- hardLimit: 0
name: string
softLimit: 0
user: string
volumesFrom:
- readOnly: false
sourceContainer: string
workingDirectory: string
containers:
string:
command:
- string
cpu: 0
dependsOn:
- condition: string
containerName: string
disableNetworking: false
dnsSearchDomains:
- string
dnsServers:
- string
dockerLabels: any
dockerSecurityOptions:
- string
entryPoint:
- string
environment:
- name: string
value: string
environmentFiles:
- type: string
value: string
essential: false
extraHosts:
- hostname: string
ipAddress: string
firelensConfiguration:
options: any
type: string
healthCheck:
command:
- string
interval: 0
retries: 0
startPeriod: 0
timeout: 0
hostname: string
image: string
interactive: false
links:
- string
linuxParameters:
capabilities:
add:
- string
drop:
- string
devices:
- containerPath: string
hostPath: string
permissions:
- string
initProcessEnabled: false
maxSwap: 0
sharedMemorySize: 0
swappiness: 0
tmpfs:
- containerPath: string
mountOptions:
- string
size: 0
logConfiguration:
logDriver: string
options: any
secretOptions:
- name: string
valueFrom: string
memory: 0
memoryReservation: 0
mountPoints:
- containerPath: string
readOnly: false
sourceVolume: string
name: string
portMappings:
- appProtocol: http
containerPort: 0
containerPortRange: string
hostPort: 0
name: string
protocol: string
targetGroup: ${targetGroup}
privileged: false
pseudoTerminal: false
readonlyRootFilesystem: false
repositoryCredentials:
credentialsParameter: string
resourceRequirements:
- type: string
value: string
secrets:
- name: string
valueFrom: string
startTimeout: 0
stopTimeout: 0
systemControls:
- namespace: string
value: string
ulimits:
- hardLimit: 0
name: string
softLimit: 0
user: string
volumesFrom:
- readOnly: false
sourceContainer: string
workingDirectory: string
cpu: string
ephemeralStorage:
sizeInGib: 0
executionRole:
args:
description: string
forceDetachPolicies: false
inlinePolicies:
- name: string
policy: string
managedPolicyArns:
- string
maxSessionDuration: 0
name: string
namePrefix: string
path: string
permissionsBoundary: string
policyArns:
- string
tags:
string: string
roleArn: string
skip: false
family: string
inferenceAccelerators:
- deviceName: string
deviceType: string
ipcMode: string
logGroup:
args:
kmsKeyId: string
logGroupClass: string
name: string
namePrefix: string
retentionInDays: 0
skipDestroy: false
tags:
string: string
existing:
arn: string
name: string
region: string
skip: false
memory: string
pidMode: string
placementConstraints:
- expression: string
type: string
proxyConfiguration:
containerName: string
properties:
string: string
type: string
runtimePlatform:
cpuArchitecture: string
operatingSystemFamily: string
skipDestroy: false
tags:
string: string
taskRole:
args:
description: string
forceDetachPolicies: false
inlinePolicies:
- name: string
policy: string
managedPolicyArns:
- string
maxSessionDuration: 0
name: string
namePrefix: string
path: string
permissionsBoundary: string
policyArns:
- string
tags:
string: string
roleArn: string
skip: false
trackLatest: false
volumes:
- configureAtLaunch: false
dockerVolumeConfiguration:
autoprovision: false
driver: string
driverOpts:
string: string
labels:
string: string
scope: string
efsVolumeConfiguration:
authorizationConfig:
accessPointId: string
iam: string
fileSystemId: string
rootDirectory: string
transitEncryption: string
transitEncryptionPort: 0
fsxWindowsFileServerVolumeConfiguration:
authorizationConfig:
credentialsParameter: string
domain: string
fileSystemId: string
rootDirectory: string
hostPath: string
name: string
triggers:
string: string
volumeConfiguration:
managedEbsVolume:
encrypted: false
fileSystemType: string
iops: 0
kmsKeyId: string
roleArn: string
sizeInGb: 0
snapshotId: string
throughput: 0
volumeType: string
name: string
FargateService Resource Properties
To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.
Inputs
The FargateService resource accepts the following input properties:
- Alarms
Pulumi.
Aws. Ecs. Inputs. Service Alarms Information about the CloudWatch alarms. See below.
This type is defined in the AWS Classic package.
- Assign
Public boolIp - Assign a public IP address to the ENI (Fargate launch type only). Valid values are
true
orfalse
. Defaultfalse
. - Cluster string
- ARN of an ECS cluster.
- Continue
Before boolSteady State - If
true
, this provider will not wait for the service to reach a steady state (likeaws ecs wait services-stable
) before continuing. Defaultfalse
. - Deployment
Circuit Pulumi.Breaker Aws. Ecs. Inputs. Service Deployment Circuit Breaker Configuration block for deployment circuit breaker. See below.
This type is defined in the AWS Classic package.
- Deployment
Controller Pulumi.Aws. Ecs. Inputs. Service Deployment Controller Configuration block for deployment controller configuration. See below.
This type is defined in the AWS Classic package.
- Deployment
Maximum intPercent - Upper limit (as a percentage of the service's desiredCount) of the number of running tasks that can be running in a service during a deployment. Not valid when using the
DAEMON
scheduling strategy. - Deployment
Minimum intHealthy Percent - Lower limit (as a percentage of the service's desiredCount) of the number of running tasks that must remain running and healthy in a service during a deployment.
- Desired
Count int - Number of instances of the task definition to place and keep running. Defaults to 1. Do not specify if using the
DAEMON
scheduling strategy. - bool
- Whether to enable Amazon ECS managed tags for the tasks within the service.
- Enable
Execute boolCommand - Whether to enable Amazon ECS Exec for the tasks within the service.
- Force
New boolDeployment - Enable to force a new task deployment of the service. This can be used to update tasks to use a newer Docker image with same image/tag combination (e.g.,
myimage:latest
), roll Fargate tasks onto a newer platform version, or immediately deployordered_placement_strategy
andplacement_constraints
updates. - Health
Check intGrace Period Seconds - Seconds to ignore failing load balancer health checks on newly instantiated tasks to prevent premature shutdown, up to 2147483647. Only valid for services configured to use load balancers.
- Iam
Role string - ARN of the IAM role that allows Amazon ECS to make calls to your load balancer on your behalf. This parameter is required if you are using a load balancer with your service, but only if your task definition does not use the
awsvpc
network mode. If usingawsvpc
network mode, do not specify this role. If your account has already created the Amazon ECS service-linked role, that role is used by default for your service unless you specify a role here. - Load
Balancers List<Pulumi.Aws. Ecs. Inputs. Service Load Balancer> - Configuration block for load balancers. See below.
- Name string
Name of the service (up to 255 letters, numbers, hyphens, and underscores)
The following arguments are optional:
- Network
Configuration Pulumi.Aws. Ecs. Inputs. Service Network Configuration Network configuration for the service. This parameter is required for task definitions that use the
awsvpc
network mode to receive their own Elastic Network Interface, and it is not supported for other network modes. See below.This type is defined in the AWS Classic package.
- Placement
Constraints List<Pulumi.Aws. Ecs. Inputs. Service Placement Constraint> - Rules that are taken into consideration during task placement. Updates to this configuration will take effect next task deployment unless
force_new_deployment
is enabled. Maximum number ofplacement_constraints
is10
. See below. - Platform
Version string - Platform version on which to run your service. Only applicable for
launch_type
set toFARGATE
. Defaults toLATEST
. More information about Fargate platform versions can be found in the AWS ECS User Guide. - string
- Whether to propagate the tags from the task definition or the service to the tasks. The valid values are
SERVICE
andTASK_DEFINITION
. - Scheduling
Strategy string - Scheduling strategy to use for the service. The valid values are
REPLICA
andDAEMON
. Defaults toREPLICA
. Note that Tasks using the Fargate launch type or theCODE_DEPLOY
orEXTERNAL
deployment controller types don't support theDAEMON
scheduling strategy. - Service
Connect Pulumi.Configuration Aws. Ecs. Inputs. Service Service Connect Configuration ECS Service Connect configuration for this service to discover and connect to services, and be discovered by, and connected from, other services within a namespace. See below.
This type is defined in the AWS Classic package.
- Service
Registries Pulumi.Aws. Ecs. Inputs. Service Service Registries Service discovery registries for the service. The maximum number of
service_registries
blocks is1
. See below.This type is defined in the AWS Classic package.
- Dictionary<string, string>
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - Task
Definition string - Family and revision (
family:revision
) or full ARN of the task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided. - Task
Definition FargateArgs Service Task Definition - The args of task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided.
- Triggers Dictionary<string, string>
- Map of arbitrary keys and values that, when changed, will trigger an in-place update (redeployment). Useful with
"plantimestamp()"
. When using the triggers property you also need to set the forceNewDeployment property to True. - Volume
Configuration Pulumi.Aws. Ecs. Inputs. Service Volume Configuration Configuration for a volume specified in the task definition as a volume that is configured at launch time. Currently, the only supported volume type is an Amazon EBS volume. See below.
This type is defined in the AWS Classic package.
- Alarms
Service
Alarms Args Information about the CloudWatch alarms. See below.
This type is defined in the AWS Classic package.
- Assign
Public boolIp - Assign a public IP address to the ENI (Fargate launch type only). Valid values are
true
orfalse
. Defaultfalse
. - Cluster string
- ARN of an ECS cluster.
- Continue
Before boolSteady State - If
true
, this provider will not wait for the service to reach a steady state (likeaws ecs wait services-stable
) before continuing. Defaultfalse
. - Deployment
Circuit ServiceBreaker Deployment Circuit Breaker Args Configuration block for deployment circuit breaker. See below.
This type is defined in the AWS Classic package.
- Deployment
Controller ServiceDeployment Controller Args Configuration block for deployment controller configuration. See below.
This type is defined in the AWS Classic package.
- Deployment
Maximum intPercent - Upper limit (as a percentage of the service's desiredCount) of the number of running tasks that can be running in a service during a deployment. Not valid when using the
DAEMON
scheduling strategy. - Deployment
Minimum intHealthy Percent - Lower limit (as a percentage of the service's desiredCount) of the number of running tasks that must remain running and healthy in a service during a deployment.
- Desired
Count int - Number of instances of the task definition to place and keep running. Defaults to 1. Do not specify if using the
DAEMON
scheduling strategy. - bool
- Whether to enable Amazon ECS managed tags for the tasks within the service.
- Enable
Execute boolCommand - Whether to enable Amazon ECS Exec for the tasks within the service.
- Force
New boolDeployment - Enable to force a new task deployment of the service. This can be used to update tasks to use a newer Docker image with same image/tag combination (e.g.,
myimage:latest
), roll Fargate tasks onto a newer platform version, or immediately deployordered_placement_strategy
andplacement_constraints
updates. - Health
Check intGrace Period Seconds - Seconds to ignore failing load balancer health checks on newly instantiated tasks to prevent premature shutdown, up to 2147483647. Only valid for services configured to use load balancers.
- Iam
Role string - ARN of the IAM role that allows Amazon ECS to make calls to your load balancer on your behalf. This parameter is required if you are using a load balancer with your service, but only if your task definition does not use the
awsvpc
network mode. If usingawsvpc
network mode, do not specify this role. If your account has already created the Amazon ECS service-linked role, that role is used by default for your service unless you specify a role here. - Load
Balancers ServiceLoad Balancer Args - Configuration block for load balancers. See below.
- Name string
Name of the service (up to 255 letters, numbers, hyphens, and underscores)
The following arguments are optional:
- Network
Configuration ServiceNetwork Configuration Args Network configuration for the service. This parameter is required for task definitions that use the
awsvpc
network mode to receive their own Elastic Network Interface, and it is not supported for other network modes. See below.This type is defined in the AWS Classic package.
- Placement
Constraints ServicePlacement Constraint Args - Rules that are taken into consideration during task placement. Updates to this configuration will take effect next task deployment unless
force_new_deployment
is enabled. Maximum number ofplacement_constraints
is10
. See below. - Platform
Version string - Platform version on which to run your service. Only applicable for
launch_type
set toFARGATE
. Defaults toLATEST
. More information about Fargate platform versions can be found in the AWS ECS User Guide. - string
- Whether to propagate the tags from the task definition or the service to the tasks. The valid values are
SERVICE
andTASK_DEFINITION
. - Scheduling
Strategy string - Scheduling strategy to use for the service. The valid values are
REPLICA
andDAEMON
. Defaults toREPLICA
. Note that Tasks using the Fargate launch type or theCODE_DEPLOY
orEXTERNAL
deployment controller types don't support theDAEMON
scheduling strategy. - Service
Connect ServiceConfiguration Service Connect Configuration Args ECS Service Connect configuration for this service to discover and connect to services, and be discovered by, and connected from, other services within a namespace. See below.
This type is defined in the AWS Classic package.
- Service
Registries ServiceService Registries Args Service discovery registries for the service. The maximum number of
service_registries
blocks is1
. See below.This type is defined in the AWS Classic package.
- map[string]string
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - Task
Definition string - Family and revision (
family:revision
) or full ARN of the task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided. - Task
Definition FargateArgs Service Task Definition Args - The args of task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided.
- Triggers map[string]string
- Map of arbitrary keys and values that, when changed, will trigger an in-place update (redeployment). Useful with
"plantimestamp()"
. When using the triggers property you also need to set the forceNewDeployment property to True. - Volume
Configuration ServiceVolume Configuration Args Configuration for a volume specified in the task definition as a volume that is configured at launch time. Currently, the only supported volume type is an Amazon EBS volume. See below.
This type is defined in the AWS Classic package.
- alarms
Service
Alarms Information about the CloudWatch alarms. See below.
This type is defined in the AWS Classic package.
- assign
Public BooleanIp - Assign a public IP address to the ENI (Fargate launch type only). Valid values are
true
orfalse
. Defaultfalse
. - cluster String
- ARN of an ECS cluster.
- continue
Before BooleanSteady State - If
true
, this provider will not wait for the service to reach a steady state (likeaws ecs wait services-stable
) before continuing. Defaultfalse
. - deployment
Circuit ServiceBreaker Deployment Circuit Breaker Configuration block for deployment circuit breaker. See below.
This type is defined in the AWS Classic package.
- deployment
Controller ServiceDeployment Controller Configuration block for deployment controller configuration. See below.
This type is defined in the AWS Classic package.
- deployment
Maximum IntegerPercent - Upper limit (as a percentage of the service's desiredCount) of the number of running tasks that can be running in a service during a deployment. Not valid when using the
DAEMON
scheduling strategy. - deployment
Minimum IntegerHealthy Percent - Lower limit (as a percentage of the service's desiredCount) of the number of running tasks that must remain running and healthy in a service during a deployment.
- desired
Count Integer - Number of instances of the task definition to place and keep running. Defaults to 1. Do not specify if using the
DAEMON
scheduling strategy. - Boolean
- Whether to enable Amazon ECS managed tags for the tasks within the service.
- enable
Execute BooleanCommand - Whether to enable Amazon ECS Exec for the tasks within the service.
- force
New BooleanDeployment - Enable to force a new task deployment of the service. This can be used to update tasks to use a newer Docker image with same image/tag combination (e.g.,
myimage:latest
), roll Fargate tasks onto a newer platform version, or immediately deployordered_placement_strategy
andplacement_constraints
updates. - health
Check IntegerGrace Period Seconds - Seconds to ignore failing load balancer health checks on newly instantiated tasks to prevent premature shutdown, up to 2147483647. Only valid for services configured to use load balancers.
- iam
Role String - ARN of the IAM role that allows Amazon ECS to make calls to your load balancer on your behalf. This parameter is required if you are using a load balancer with your service, but only if your task definition does not use the
awsvpc
network mode. If usingawsvpc
network mode, do not specify this role. If your account has already created the Amazon ECS service-linked role, that role is used by default for your service unless you specify a role here. - load
Balancers List<ServiceLoad Balancer> - Configuration block for load balancers. See below.
- name String
Name of the service (up to 255 letters, numbers, hyphens, and underscores)
The following arguments are optional:
- network
Configuration ServiceNetwork Configuration Network configuration for the service. This parameter is required for task definitions that use the
awsvpc
network mode to receive their own Elastic Network Interface, and it is not supported for other network modes. See below.This type is defined in the AWS Classic package.
- placement
Constraints List<ServicePlacement Constraint> - Rules that are taken into consideration during task placement. Updates to this configuration will take effect next task deployment unless
force_new_deployment
is enabled. Maximum number ofplacement_constraints
is10
. See below. - platform
Version String - Platform version on which to run your service. Only applicable for
launch_type
set toFARGATE
. Defaults toLATEST
. More information about Fargate platform versions can be found in the AWS ECS User Guide. - String
- Whether to propagate the tags from the task definition or the service to the tasks. The valid values are
SERVICE
andTASK_DEFINITION
. - scheduling
Strategy String - Scheduling strategy to use for the service. The valid values are
REPLICA
andDAEMON
. Defaults toREPLICA
. Note that Tasks using the Fargate launch type or theCODE_DEPLOY
orEXTERNAL
deployment controller types don't support theDAEMON
scheduling strategy. - service
Connect ServiceConfiguration Service Connect Configuration ECS Service Connect configuration for this service to discover and connect to services, and be discovered by, and connected from, other services within a namespace. See below.
This type is defined in the AWS Classic package.
- service
Registries ServiceService Registries Service discovery registries for the service. The maximum number of
service_registries
blocks is1
. See below.This type is defined in the AWS Classic package.
- Map<String,String>
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - task
Definition String - Family and revision (
family:revision
) or full ARN of the task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided. - task
Definition FargateArgs Service Task Definition - The args of task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided.
- triggers Map<String,String>
- Map of arbitrary keys and values that, when changed, will trigger an in-place update (redeployment). Useful with
"plantimestamp()"
. When using the triggers property you also need to set the forceNewDeployment property to True. - volume
Configuration ServiceVolume Configuration Configuration for a volume specified in the task definition as a volume that is configured at launch time. Currently, the only supported volume type is an Amazon EBS volume. See below.
This type is defined in the AWS Classic package.
- alarms
pulumi
Aws.types.input. Service Alarms Information about the CloudWatch alarms. See below.
This type is defined in the AWS Classic package.
- assign
Public booleanIp - Assign a public IP address to the ENI (Fargate launch type only). Valid values are
true
orfalse
. Defaultfalse
. - cluster string
- ARN of an ECS cluster.
- continue
Before booleanSteady State - If
true
, this provider will not wait for the service to reach a steady state (likeaws ecs wait services-stable
) before continuing. Defaultfalse
. - deployment
Circuit pulumiBreaker Aws.types.input. Service Deployment Circuit Breaker Configuration block for deployment circuit breaker. See below.
This type is defined in the AWS Classic package.
- deployment
Controller pulumiAws.types.input. Service Deployment Controller Configuration block for deployment controller configuration. See below.
This type is defined in the AWS Classic package.
- deployment
Maximum numberPercent - Upper limit (as a percentage of the service's desiredCount) of the number of running tasks that can be running in a service during a deployment. Not valid when using the
DAEMON
scheduling strategy. - deployment
Minimum numberHealthy Percent - Lower limit (as a percentage of the service's desiredCount) of the number of running tasks that must remain running and healthy in a service during a deployment.
- desired
Count number - Number of instances of the task definition to place and keep running. Defaults to 1. Do not specify if using the
DAEMON
scheduling strategy. - boolean
- Whether to enable Amazon ECS managed tags for the tasks within the service.
- enable
Execute booleanCommand - Whether to enable Amazon ECS Exec for the tasks within the service.
- force
New booleanDeployment - Enable to force a new task deployment of the service. This can be used to update tasks to use a newer Docker image with same image/tag combination (e.g.,
myimage:latest
), roll Fargate tasks onto a newer platform version, or immediately deployordered_placement_strategy
andplacement_constraints
updates. - health
Check numberGrace Period Seconds - Seconds to ignore failing load balancer health checks on newly instantiated tasks to prevent premature shutdown, up to 2147483647. Only valid for services configured to use load balancers.
- iam
Role string - ARN of the IAM role that allows Amazon ECS to make calls to your load balancer on your behalf. This parameter is required if you are using a load balancer with your service, but only if your task definition does not use the
awsvpc
network mode. If usingawsvpc
network mode, do not specify this role. If your account has already created the Amazon ECS service-linked role, that role is used by default for your service unless you specify a role here. - load
Balancers pulumiAws.types.input. Service Load Balancer[] - Configuration block for load balancers. See below.
- name string
Name of the service (up to 255 letters, numbers, hyphens, and underscores)
The following arguments are optional:
- network
Configuration pulumiAws.types.input. Service Network Configuration Network configuration for the service. This parameter is required for task definitions that use the
awsvpc
network mode to receive their own Elastic Network Interface, and it is not supported for other network modes. See below.This type is defined in the AWS Classic package.
- placement
Constraints pulumiAws.types.input. Service Placement Constraint[] - Rules that are taken into consideration during task placement. Updates to this configuration will take effect next task deployment unless
force_new_deployment
is enabled. Maximum number ofplacement_constraints
is10
. See below. - platform
Version string - Platform version on which to run your service. Only applicable for
launch_type
set toFARGATE
. Defaults toLATEST
. More information about Fargate platform versions can be found in the AWS ECS User Guide. - string
- Whether to propagate the tags from the task definition or the service to the tasks. The valid values are
SERVICE
andTASK_DEFINITION
. - scheduling
Strategy string - Scheduling strategy to use for the service. The valid values are
REPLICA
andDAEMON
. Defaults toREPLICA
. Note that Tasks using the Fargate launch type or theCODE_DEPLOY
orEXTERNAL
deployment controller types don't support theDAEMON
scheduling strategy. - service
Connect pulumiConfiguration Aws.types.input. Service Service Connect Configuration ECS Service Connect configuration for this service to discover and connect to services, and be discovered by, and connected from, other services within a namespace. See below.
This type is defined in the AWS Classic package.
- service
Registries pulumiAws.types.input. Service Service Registries Service discovery registries for the service. The maximum number of
service_registries
blocks is1
. See below.This type is defined in the AWS Classic package.
- {[key: string]: string}
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - task
Definition string - Family and revision (
family:revision
) or full ARN of the task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided. - task
Definition FargateArgs Service Task Definition - The args of task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided.
- triggers {[key: string]: string}
- Map of arbitrary keys and values that, when changed, will trigger an in-place update (redeployment). Useful with
"plantimestamp()"
. When using the triggers property you also need to set the forceNewDeployment property to True. - volume
Configuration pulumiAws.types.input. Service Volume Configuration Configuration for a volume specified in the task definition as a volume that is configured at launch time. Currently, the only supported volume type is an Amazon EBS volume. See below.
This type is defined in the AWS Classic package.
- alarms
pulumi_
aws.ecs. Service Alarms Args Information about the CloudWatch alarms. See below.
This type is defined in the AWS Classic package.
- assign_
public_ boolip - Assign a public IP address to the ENI (Fargate launch type only). Valid values are
true
orfalse
. Defaultfalse
. - cluster str
- ARN of an ECS cluster.
- continue_
before_ boolsteady_ state - If
true
, this provider will not wait for the service to reach a steady state (likeaws ecs wait services-stable
) before continuing. Defaultfalse
. - deployment_
circuit_ pulumi_breaker aws.ecs. Service Deployment Circuit Breaker Args Configuration block for deployment circuit breaker. See below.
This type is defined in the AWS Classic package.
- deployment_
controller pulumi_aws.ecs. Service Deployment Controller Args Configuration block for deployment controller configuration. See below.
This type is defined in the AWS Classic package.
- deployment_
maximum_ intpercent - Upper limit (as a percentage of the service's desiredCount) of the number of running tasks that can be running in a service during a deployment. Not valid when using the
DAEMON
scheduling strategy. - deployment_
minimum_ inthealthy_ percent - Lower limit (as a percentage of the service's desiredCount) of the number of running tasks that must remain running and healthy in a service during a deployment.
- desired_
count int - Number of instances of the task definition to place and keep running. Defaults to 1. Do not specify if using the
DAEMON
scheduling strategy. - bool
- Whether to enable Amazon ECS managed tags for the tasks within the service.
- enable_
execute_ boolcommand - Whether to enable Amazon ECS Exec for the tasks within the service.
- force_
new_ booldeployment - Enable to force a new task deployment of the service. This can be used to update tasks to use a newer Docker image with same image/tag combination (e.g.,
myimage:latest
), roll Fargate tasks onto a newer platform version, or immediately deployordered_placement_strategy
andplacement_constraints
updates. - health_
check_ intgrace_ period_ seconds - Seconds to ignore failing load balancer health checks on newly instantiated tasks to prevent premature shutdown, up to 2147483647. Only valid for services configured to use load balancers.
- iam_
role str - ARN of the IAM role that allows Amazon ECS to make calls to your load balancer on your behalf. This parameter is required if you are using a load balancer with your service, but only if your task definition does not use the
awsvpc
network mode. If usingawsvpc
network mode, do not specify this role. If your account has already created the Amazon ECS service-linked role, that role is used by default for your service unless you specify a role here. - load_
balancers Sequence[pulumi_aws.ecs. Service Load Balancer Args] - Configuration block for load balancers. See below.
- name str
Name of the service (up to 255 letters, numbers, hyphens, and underscores)
The following arguments are optional:
- network_
configuration pulumi_aws.ecs. Service Network Configuration Args Network configuration for the service. This parameter is required for task definitions that use the
awsvpc
network mode to receive their own Elastic Network Interface, and it is not supported for other network modes. See below.This type is defined in the AWS Classic package.
- placement_
constraints Sequence[pulumi_aws.ecs. Service Placement Constraint Args] - Rules that are taken into consideration during task placement. Updates to this configuration will take effect next task deployment unless
force_new_deployment
is enabled. Maximum number ofplacement_constraints
is10
. See below. - platform_
version str - Platform version on which to run your service. Only applicable for
launch_type
set toFARGATE
. Defaults toLATEST
. More information about Fargate platform versions can be found in the AWS ECS User Guide. - str
- Whether to propagate the tags from the task definition or the service to the tasks. The valid values are
SERVICE
andTASK_DEFINITION
. - scheduling_
strategy str - Scheduling strategy to use for the service. The valid values are
REPLICA
andDAEMON
. Defaults toREPLICA
. Note that Tasks using the Fargate launch type or theCODE_DEPLOY
orEXTERNAL
deployment controller types don't support theDAEMON
scheduling strategy. - service_
connect_ pulumi_configuration aws.ecs. Service Service Connect Configuration Args ECS Service Connect configuration for this service to discover and connect to services, and be discovered by, and connected from, other services within a namespace. See below.
This type is defined in the AWS Classic package.
- service_
registries pulumi_aws.ecs. Service Service Registries Args Service discovery registries for the service. The maximum number of
service_registries
blocks is1
. See below.This type is defined in the AWS Classic package.
- Mapping[str, str]
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - task_
definition str - Family and revision (
family:revision
) or full ARN of the task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided. - task_
definition_ Fargateargs Service Task Definition Args - The args of task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided.
- triggers Mapping[str, str]
- Map of arbitrary keys and values that, when changed, will trigger an in-place update (redeployment). Useful with
"plantimestamp()"
. When using the triggers property you also need to set the forceNewDeployment property to True. - volume_
configuration pulumi_aws.ecs. Service Volume Configuration Args Configuration for a volume specified in the task definition as a volume that is configured at launch time. Currently, the only supported volume type is an Amazon EBS volume. See below.
This type is defined in the AWS Classic package.
- alarms Property Map
Information about the CloudWatch alarms. See below.
This type is defined in the AWS Classic package.
- assign
Public BooleanIp - Assign a public IP address to the ENI (Fargate launch type only). Valid values are
true
orfalse
. Defaultfalse
. - cluster String
- ARN of an ECS cluster.
- continue
Before BooleanSteady State - If
true
, this provider will not wait for the service to reach a steady state (likeaws ecs wait services-stable
) before continuing. Defaultfalse
. - deployment
Circuit Property MapBreaker Configuration block for deployment circuit breaker. See below.
This type is defined in the AWS Classic package.
- deployment
Controller Property Map Configuration block for deployment controller configuration. See below.
This type is defined in the AWS Classic package.
- deployment
Maximum NumberPercent - Upper limit (as a percentage of the service's desiredCount) of the number of running tasks that can be running in a service during a deployment. Not valid when using the
DAEMON
scheduling strategy. - deployment
Minimum NumberHealthy Percent - Lower limit (as a percentage of the service's desiredCount) of the number of running tasks that must remain running and healthy in a service during a deployment.
- desired
Count Number - Number of instances of the task definition to place and keep running. Defaults to 1. Do not specify if using the
DAEMON
scheduling strategy. - Boolean
- Whether to enable Amazon ECS managed tags for the tasks within the service.
- enable
Execute BooleanCommand - Whether to enable Amazon ECS Exec for the tasks within the service.
- force
New BooleanDeployment - Enable to force a new task deployment of the service. This can be used to update tasks to use a newer Docker image with same image/tag combination (e.g.,
myimage:latest
), roll Fargate tasks onto a newer platform version, or immediately deployordered_placement_strategy
andplacement_constraints
updates. - health
Check NumberGrace Period Seconds - Seconds to ignore failing load balancer health checks on newly instantiated tasks to prevent premature shutdown, up to 2147483647. Only valid for services configured to use load balancers.
- iam
Role String - ARN of the IAM role that allows Amazon ECS to make calls to your load balancer on your behalf. This parameter is required if you are using a load balancer with your service, but only if your task definition does not use the
awsvpc
network mode. If usingawsvpc
network mode, do not specify this role. If your account has already created the Amazon ECS service-linked role, that role is used by default for your service unless you specify a role here. - load
Balancers List<Property Map> - Configuration block for load balancers. See below.
- name String
Name of the service (up to 255 letters, numbers, hyphens, and underscores)
The following arguments are optional:
- network
Configuration Property Map Network configuration for the service. This parameter is required for task definitions that use the
awsvpc
network mode to receive their own Elastic Network Interface, and it is not supported for other network modes. See below.This type is defined in the AWS Classic package.
- placement
Constraints List<Property Map> - Rules that are taken into consideration during task placement. Updates to this configuration will take effect next task deployment unless
force_new_deployment
is enabled. Maximum number ofplacement_constraints
is10
. See below. - platform
Version String - Platform version on which to run your service. Only applicable for
launch_type
set toFARGATE
. Defaults toLATEST
. More information about Fargate platform versions can be found in the AWS ECS User Guide. - String
- Whether to propagate the tags from the task definition or the service to the tasks. The valid values are
SERVICE
andTASK_DEFINITION
. - scheduling
Strategy String - Scheduling strategy to use for the service. The valid values are
REPLICA
andDAEMON
. Defaults toREPLICA
. Note that Tasks using the Fargate launch type or theCODE_DEPLOY
orEXTERNAL
deployment controller types don't support theDAEMON
scheduling strategy. - service
Connect Property MapConfiguration ECS Service Connect configuration for this service to discover and connect to services, and be discovered by, and connected from, other services within a namespace. See below.
This type is defined in the AWS Classic package.
- service
Registries Property Map Service discovery registries for the service. The maximum number of
service_registries
blocks is1
. See below.This type is defined in the AWS Classic package.
- Map<String>
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - task
Definition String - Family and revision (
family:revision
) or full ARN of the task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided. - task
Definition Property MapArgs - The args of task definition that you want to run in your service. Either [taskDefinition] or [taskDefinitionArgs] must be provided.
- triggers Map<String>
- Map of arbitrary keys and values that, when changed, will trigger an in-place update (redeployment). Useful with
"plantimestamp()"
. When using the triggers property you also need to set the forceNewDeployment property to True. - volume
Configuration Property Map Configuration for a volume specified in the task definition as a volume that is configured at launch time. Currently, the only supported volume type is an Amazon EBS volume. See below.
This type is defined in the AWS Classic package.
Outputs
All input properties are implicitly available as output properties. Additionally, the FargateService resource produces the following output properties:
- Service
Pulumi.
Aws. Ecs. Service - Underlying ECS Service resource This type is defined in the AWS Classic package.
- Service Service
- Underlying ECS Service resource This type is defined in the AWS Classic package.
- service Service
- Underlying ECS Service resource This type is defined in the AWS Classic package.
- service
pulumi
Aws. Service - Underlying ECS Service resource This type is defined in the AWS Classic package.
- service
pulumi_
aws.ecs. Service - Underlying ECS Service resource This type is defined in the AWS Classic package.
- service aws::Service
- Underlying ECS Service resource This type is defined in the AWS Classic package.
Supporting Types
DefaultLogGroup, DefaultLogGroupArgs
- Args
Pulumi.
Awsx. Awsx. Inputs. Log Group - Arguments to use instead of the default values during creation.
- Existing
Pulumi.
Awsx. Awsx. Inputs. Existing Log Group - Identity of an existing log group to use. Cannot be used in combination with
args
oropts
. - Skip bool
- Skip creation of the log group.
- Args
Log
Group - Arguments to use instead of the default values during creation.
- Existing
Existing
Log Group - Identity of an existing log group to use. Cannot be used in combination with
args
oropts
. - Skip bool
- Skip creation of the log group.
- args
Log
Group - Arguments to use instead of the default values during creation.
- existing
Existing
Log Group - Identity of an existing log group to use. Cannot be used in combination with
args
oropts
. - skip Boolean
- Skip creation of the log group.
- args
awsx.
Log Group - Arguments to use instead of the default values during creation.
- existing
awsx.
Existing Log Group - Identity of an existing log group to use. Cannot be used in combination with
args
oropts
. - skip boolean
- Skip creation of the log group.
- args
awsx.
Log Group - Arguments to use instead of the default values during creation.
- existing
awsx.
Existing Log Group - Identity of an existing log group to use. Cannot be used in combination with
args
oropts
. - skip bool
- Skip creation of the log group.
- args Property Map
- Arguments to use instead of the default values during creation.
- existing Property Map
- Identity of an existing log group to use. Cannot be used in combination with
args
oropts
. - skip Boolean
- Skip creation of the log group.
DefaultRoleWithPolicy, DefaultRoleWithPolicyArgs
- Args
Pulumi.
Awsx. Awsx. Inputs. Role With Policy - Args to use when creating the role and policies. Can't be specified if
roleArn
is used. - Role
Arn string - ARN of existing role to use instead of creating a new role. Cannot be used in combination with
args
oropts
. - Skip bool
- Skips creation of the role if set to
true
.
- Args
Role
With Policy - Args to use when creating the role and policies. Can't be specified if
roleArn
is used. - Role
Arn string - ARN of existing role to use instead of creating a new role. Cannot be used in combination with
args
oropts
. - Skip bool
- Skips creation of the role if set to
true
.
- args
Role
With Policy - Args to use when creating the role and policies. Can't be specified if
roleArn
is used. - role
Arn String - ARN of existing role to use instead of creating a new role. Cannot be used in combination with
args
oropts
. - skip Boolean
- Skips creation of the role if set to
true
.
- args
awsx.
Role With Policy - Args to use when creating the role and policies. Can't be specified if
roleArn
is used. - role
Arn string - ARN of existing role to use instead of creating a new role. Cannot be used in combination with
args
oropts
. - skip boolean
- Skips creation of the role if set to
true
.
- args
awsx.
Role With Policy - Args to use when creating the role and policies. Can't be specified if
roleArn
is used. - role_
arn str - ARN of existing role to use instead of creating a new role. Cannot be used in combination with
args
oropts
. - skip bool
- Skips creation of the role if set to
true
.
- args Property Map
- Args to use when creating the role and policies. Can't be specified if
roleArn
is used. - role
Arn String - ARN of existing role to use instead of creating a new role. Cannot be used in combination with
args
oropts
. - skip Boolean
- Skips creation of the role if set to
true
.
ExistingLogGroup, ExistingLogGroupArgs
FargateServiceTaskDefinition, FargateServiceTaskDefinitionArgs
- Container
Task
Definition Container Definition Single container to make a TaskDefinition from. Useful for simple cases where there aren't multiple containers, especially when creating a TaskDefinition to call [run] on.
Either [container] or [containers] must be provided.
- Containers
Dictionary<string, Task
Definition Container Definition> All the containers to make a TaskDefinition from. Useful when creating a Service that will contain many containers within.
Either [container] or [containers] must be provided.
- Cpu string
- The number of cpu units used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- Ephemeral
Storage Pulumi.Aws. Ecs. Inputs. Task Definition Ephemeral Storage The amount of ephemeral storage to allocate for the task. This parameter is used to expand the total amount of ephemeral storage available, beyond the default amount, for tasks hosted on AWS Fargate. See Ephemeral Storage.
This type is defined in the AWS Classic package.
- Execution
Role Pulumi.Awsx. Awsx. Inputs. Default Role With Policy - The execution role that the Amazon ECS container agent and the Docker daemon can assume. Will be created automatically if not defined.
- Family string
- An optional unique name for your task definition. If not specified, then a default will be created.
- Inference
Accelerators List<Pulumi.Aws. Ecs. Inputs. Task Definition Inference Accelerator> - Configuration block(s) with Inference Accelerators settings. Detailed below.
- Ipc
Mode string - IPC resource namespace to be used for the containers in the task The valid values are
host
,task
, andnone
. - Log
Group Pulumi.Awsx. Awsx. Inputs. Default Log Group - A set of volume blocks that containers in your task may use.
- Memory string
- The amount (in MiB) of memory used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- Pid
Mode string - Process namespace to use for the containers in the task. The valid values are
host
andtask
. - Placement
Constraints List<Pulumi.Aws. Ecs. Inputs. Task Definition Placement Constraint> - Configuration block for rules that are taken into consideration during task placement. Maximum number of
placement_constraints
is10
. Detailed below. - Proxy
Configuration Pulumi.Aws. Ecs. Inputs. Task Definition Proxy Configuration Configuration block for the App Mesh proxy. Detailed below.
This type is defined in the AWS Classic package.
- Runtime
Platform Pulumi.Aws. Ecs. Inputs. Task Definition Runtime Platform Configuration block for runtime_platform that containers in your task may use.
This type is defined in the AWS Classic package.
- Skip
Destroy bool - Whether to retain the old revision when the resource is destroyed or replacement is necessary. Default is
false
. - Dictionary<string, string>
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - Task
Role Pulumi.Awsx. Awsx. Inputs. Default Role With Policy - IAM role that allows your Amazon ECS container task to make calls to other AWS services. Will be created automatically if not defined.
- Track
Latest bool - Whether should track latest
ACTIVE
task definition on AWS or the one created with the resource stored in state. Default isfalse
. Useful in the event the task definition is modified outside of this resource. - Volumes
List<Pulumi.
Aws. Ecs. Inputs. Task Definition Volume> - Configuration block for volumes that containers in your task may use. Detailed below.
- Container
Task
Definition Container Definition Single container to make a TaskDefinition from. Useful for simple cases where there aren't multiple containers, especially when creating a TaskDefinition to call [run] on.
Either [container] or [containers] must be provided.
- Containers
map[string]Task
Definition Container Definition All the containers to make a TaskDefinition from. Useful when creating a Service that will contain many containers within.
Either [container] or [containers] must be provided.
- Cpu string
- The number of cpu units used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- Ephemeral
Storage TaskDefinition Ephemeral Storage The amount of ephemeral storage to allocate for the task. This parameter is used to expand the total amount of ephemeral storage available, beyond the default amount, for tasks hosted on AWS Fargate. See Ephemeral Storage.
This type is defined in the AWS Classic package.
- Execution
Role DefaultRole With Policy - The execution role that the Amazon ECS container agent and the Docker daemon can assume. Will be created automatically if not defined.
- Family string
- An optional unique name for your task definition. If not specified, then a default will be created.
- Inference
Accelerators TaskDefinition Inference Accelerator - Configuration block(s) with Inference Accelerators settings. Detailed below.
- Ipc
Mode string - IPC resource namespace to be used for the containers in the task The valid values are
host
,task
, andnone
. - Log
Group DefaultLog Group - A set of volume blocks that containers in your task may use.
- Memory string
- The amount (in MiB) of memory used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- Pid
Mode string - Process namespace to use for the containers in the task. The valid values are
host
andtask
. - Placement
Constraints TaskDefinition Placement Constraint - Configuration block for rules that are taken into consideration during task placement. Maximum number of
placement_constraints
is10
. Detailed below. - Proxy
Configuration TaskDefinition Proxy Configuration Configuration block for the App Mesh proxy. Detailed below.
This type is defined in the AWS Classic package.
- Runtime
Platform TaskDefinition Runtime Platform Configuration block for runtime_platform that containers in your task may use.
This type is defined in the AWS Classic package.
- Skip
Destroy bool - Whether to retain the old revision when the resource is destroyed or replacement is necessary. Default is
false
. - map[string]string
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - Task
Role DefaultRole With Policy - IAM role that allows your Amazon ECS container task to make calls to other AWS services. Will be created automatically if not defined.
- Track
Latest bool - Whether should track latest
ACTIVE
task definition on AWS or the one created with the resource stored in state. Default isfalse
. Useful in the event the task definition is modified outside of this resource. - Volumes
Task
Definition Volume - Configuration block for volumes that containers in your task may use. Detailed below.
- container
Task
Definition Container Definition Single container to make a TaskDefinition from. Useful for simple cases where there aren't multiple containers, especially when creating a TaskDefinition to call [run] on.
Either [container] or [containers] must be provided.
- containers
Map<String,Task
Definition Container Definition> All the containers to make a TaskDefinition from. Useful when creating a Service that will contain many containers within.
Either [container] or [containers] must be provided.
- cpu String
- The number of cpu units used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- ephemeral
Storage TaskDefinition Ephemeral Storage The amount of ephemeral storage to allocate for the task. This parameter is used to expand the total amount of ephemeral storage available, beyond the default amount, for tasks hosted on AWS Fargate. See Ephemeral Storage.
This type is defined in the AWS Classic package.
- execution
Role DefaultRole With Policy - The execution role that the Amazon ECS container agent and the Docker daemon can assume. Will be created automatically if not defined.
- family String
- An optional unique name for your task definition. If not specified, then a default will be created.
- inference
Accelerators List<TaskDefinition Inference Accelerator> - Configuration block(s) with Inference Accelerators settings. Detailed below.
- ipc
Mode String - IPC resource namespace to be used for the containers in the task The valid values are
host
,task
, andnone
. - log
Group DefaultLog Group - A set of volume blocks that containers in your task may use.
- memory String
- The amount (in MiB) of memory used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- pid
Mode String - Process namespace to use for the containers in the task. The valid values are
host
andtask
. - placement
Constraints List<TaskDefinition Placement Constraint> - Configuration block for rules that are taken into consideration during task placement. Maximum number of
placement_constraints
is10
. Detailed below. - proxy
Configuration TaskDefinition Proxy Configuration Configuration block for the App Mesh proxy. Detailed below.
This type is defined in the AWS Classic package.
- runtime
Platform TaskDefinition Runtime Platform Configuration block for runtime_platform that containers in your task may use.
This type is defined in the AWS Classic package.
- skip
Destroy Boolean - Whether to retain the old revision when the resource is destroyed or replacement is necessary. Default is
false
. - Map<String,String>
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - task
Role DefaultRole With Policy - IAM role that allows your Amazon ECS container task to make calls to other AWS services. Will be created automatically if not defined.
- track
Latest Boolean - Whether should track latest
ACTIVE
task definition on AWS or the one created with the resource stored in state. Default isfalse
. Useful in the event the task definition is modified outside of this resource. - volumes
List<Task
Definition Volume> - Configuration block for volumes that containers in your task may use. Detailed below.
- container
Task
Definition Container Definition Single container to make a TaskDefinition from. Useful for simple cases where there aren't multiple containers, especially when creating a TaskDefinition to call [run] on.
Either [container] or [containers] must be provided.
- containers
{[key: string]: Task
Definition Container Definition} All the containers to make a TaskDefinition from. Useful when creating a Service that will contain many containers within.
Either [container] or [containers] must be provided.
- cpu string
- The number of cpu units used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- ephemeral
Storage pulumiAws.types.input. Task Definition Ephemeral Storage The amount of ephemeral storage to allocate for the task. This parameter is used to expand the total amount of ephemeral storage available, beyond the default amount, for tasks hosted on AWS Fargate. See Ephemeral Storage.
This type is defined in the AWS Classic package.
- execution
Role awsx.Default Role With Policy - The execution role that the Amazon ECS container agent and the Docker daemon can assume. Will be created automatically if not defined.
- family string
- An optional unique name for your task definition. If not specified, then a default will be created.
- inference
Accelerators pulumiAws.types.input. Task Definition Inference Accelerator[] - Configuration block(s) with Inference Accelerators settings. Detailed below.
- ipc
Mode string - IPC resource namespace to be used for the containers in the task The valid values are
host
,task
, andnone
. - log
Group awsx.Default Log Group - A set of volume blocks that containers in your task may use.
- memory string
- The amount (in MiB) of memory used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- pid
Mode string - Process namespace to use for the containers in the task. The valid values are
host
andtask
. - placement
Constraints pulumiAws.types.input. Task Definition Placement Constraint[] - Configuration block for rules that are taken into consideration during task placement. Maximum number of
placement_constraints
is10
. Detailed below. - proxy
Configuration pulumiAws.types.input. Task Definition Proxy Configuration Configuration block for the App Mesh proxy. Detailed below.
This type is defined in the AWS Classic package.
- runtime
Platform pulumiAws.types.input. Task Definition Runtime Platform Configuration block for runtime_platform that containers in your task may use.
This type is defined in the AWS Classic package.
- skip
Destroy boolean - Whether to retain the old revision when the resource is destroyed or replacement is necessary. Default is
false
. - {[key: string]: string}
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - task
Role awsx.Default Role With Policy - IAM role that allows your Amazon ECS container task to make calls to other AWS services. Will be created automatically if not defined.
- track
Latest boolean - Whether should track latest
ACTIVE
task definition on AWS or the one created with the resource stored in state. Default isfalse
. Useful in the event the task definition is modified outside of this resource. - volumes
pulumi
Aws.types.input. Task Definition Volume[] - Configuration block for volumes that containers in your task may use. Detailed below.
- container
Task
Definition Container Definition Single container to make a TaskDefinition from. Useful for simple cases where there aren't multiple containers, especially when creating a TaskDefinition to call [run] on.
Either [container] or [containers] must be provided.
- containers
Mapping[str, Task
Definition Container Definition] All the containers to make a TaskDefinition from. Useful when creating a Service that will contain many containers within.
Either [container] or [containers] must be provided.
- cpu str
- The number of cpu units used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- ephemeral_
storage pulumi_aws.ecs. Task Definition Ephemeral Storage Args The amount of ephemeral storage to allocate for the task. This parameter is used to expand the total amount of ephemeral storage available, beyond the default amount, for tasks hosted on AWS Fargate. See Ephemeral Storage.
This type is defined in the AWS Classic package.
- execution_
role awsx.Default Role With Policy - The execution role that the Amazon ECS container agent and the Docker daemon can assume. Will be created automatically if not defined.
- family str
- An optional unique name for your task definition. If not specified, then a default will be created.
- inference_
accelerators Sequence[pulumi_aws.ecs. Task Definition Inference Accelerator Args] - Configuration block(s) with Inference Accelerators settings. Detailed below.
- ipc_
mode str - IPC resource namespace to be used for the containers in the task The valid values are
host
,task
, andnone
. - log_
group awsx.Default Log Group - A set of volume blocks that containers in your task may use.
- memory str
- The amount (in MiB) of memory used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- pid_
mode str - Process namespace to use for the containers in the task. The valid values are
host
andtask
. - placement_
constraints Sequence[pulumi_aws.ecs. Task Definition Placement Constraint Args] - Configuration block for rules that are taken into consideration during task placement. Maximum number of
placement_constraints
is10
. Detailed below. - proxy_
configuration pulumi_aws.ecs. Task Definition Proxy Configuration Args Configuration block for the App Mesh proxy. Detailed below.
This type is defined in the AWS Classic package.
- runtime_
platform pulumi_aws.ecs. Task Definition Runtime Platform Args Configuration block for runtime_platform that containers in your task may use.
This type is defined in the AWS Classic package.
- skip_
destroy bool - Whether to retain the old revision when the resource is destroyed or replacement is necessary. Default is
false
. - Mapping[str, str]
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - task_
role awsx.Default Role With Policy - IAM role that allows your Amazon ECS container task to make calls to other AWS services. Will be created automatically if not defined.
- track_
latest bool - Whether should track latest
ACTIVE
task definition on AWS or the one created with the resource stored in state. Default isfalse
. Useful in the event the task definition is modified outside of this resource. - volumes
Sequence[pulumi_
aws.ecs. Task Definition Volume Args] - Configuration block for volumes that containers in your task may use. Detailed below.
- container Property Map
Single container to make a TaskDefinition from. Useful for simple cases where there aren't multiple containers, especially when creating a TaskDefinition to call [run] on.
Either [container] or [containers] must be provided.
- containers Map<Property Map>
All the containers to make a TaskDefinition from. Useful when creating a Service that will contain many containers within.
Either [container] or [containers] must be provided.
- cpu String
- The number of cpu units used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- ephemeral
Storage Property Map The amount of ephemeral storage to allocate for the task. This parameter is used to expand the total amount of ephemeral storage available, beyond the default amount, for tasks hosted on AWS Fargate. See Ephemeral Storage.
This type is defined in the AWS Classic package.
- execution
Role Property Map - The execution role that the Amazon ECS container agent and the Docker daemon can assume. Will be created automatically if not defined.
- family String
- An optional unique name for your task definition. If not specified, then a default will be created.
- inference
Accelerators List<Property Map> - Configuration block(s) with Inference Accelerators settings. Detailed below.
- ipc
Mode String - IPC resource namespace to be used for the containers in the task The valid values are
host
,task
, andnone
. - log
Group Property Map - A set of volume blocks that containers in your task may use.
- memory String
- The amount (in MiB) of memory used by the task. If not provided, a default will be computed based on the cumulative needs specified by [containerDefinitions]
- pid
Mode String - Process namespace to use for the containers in the task. The valid values are
host
andtask
. - placement
Constraints List<Property Map> - Configuration block for rules that are taken into consideration during task placement. Maximum number of
placement_constraints
is10
. Detailed below. - proxy
Configuration Property Map Configuration block for the App Mesh proxy. Detailed below.
This type is defined in the AWS Classic package.
- runtime
Platform Property Map Configuration block for runtime_platform that containers in your task may use.
This type is defined in the AWS Classic package.
- skip
Destroy Boolean - Whether to retain the old revision when the resource is destroyed or replacement is necessary. Default is
false
. - Map<String>
- Key-value map of resource tags. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level. - task
Role Property Map - IAM role that allows your Amazon ECS container task to make calls to other AWS services. Will be created automatically if not defined.
- track
Latest Boolean - Whether should track latest
ACTIVE
task definition on AWS or the one created with the resource stored in state. Default isfalse
. Useful in the event the task definition is modified outside of this resource. - volumes List<Property Map>
- Configuration block for volumes that containers in your task may use. Detailed below.
LogGroup, LogGroupArgs
- Kms
Key stringId - The ARN of the KMS Key to use when encrypting log data. Please note, after the AWS KMS CMK is disassociated from the log group, AWS CloudWatch Logs stops encrypting newly ingested data for the log group. All previously ingested data remains encrypted, and AWS CloudWatch Logs requires permissions for the CMK whenever the encrypted data is requested.
- Log
Group stringClass - Specified the log class of the log group. Possible values are:
STANDARD
orINFREQUENT_ACCESS
. - Name string
- The name of the log group. If omitted, this provider will assign a random, unique name.
- Name
Prefix string - Creates a unique name beginning with the specified prefix. Conflicts with
name
. - Retention
In intDays - Specifies the number of days you want to retain log events in the specified log group. Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1096, 1827, 2192, 2557, 2922, 3288, 3653, and 0. If you select 0, the events in the log group are always retained and never expire.
- Skip
Destroy bool - Set to true if you do not wish the log group (and any logs it may contain) to be deleted at destroy time, and instead just remove the log group from the state.
- Dictionary<string, string>
- A map of tags to assign to the resource. .If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- Kms
Key stringId - The ARN of the KMS Key to use when encrypting log data. Please note, after the AWS KMS CMK is disassociated from the log group, AWS CloudWatch Logs stops encrypting newly ingested data for the log group. All previously ingested data remains encrypted, and AWS CloudWatch Logs requires permissions for the CMK whenever the encrypted data is requested.
- Log
Group stringClass - Specified the log class of the log group. Possible values are:
STANDARD
orINFREQUENT_ACCESS
. - Name string
- The name of the log group. If omitted, this provider will assign a random, unique name.
- Name
Prefix string - Creates a unique name beginning with the specified prefix. Conflicts with
name
. - Retention
In intDays - Specifies the number of days you want to retain log events in the specified log group. Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1096, 1827, 2192, 2557, 2922, 3288, 3653, and 0. If you select 0, the events in the log group are always retained and never expire.
- Skip
Destroy bool - Set to true if you do not wish the log group (and any logs it may contain) to be deleted at destroy time, and instead just remove the log group from the state.
- map[string]string
- A map of tags to assign to the resource. .If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- kms
Key StringId - The ARN of the KMS Key to use when encrypting log data. Please note, after the AWS KMS CMK is disassociated from the log group, AWS CloudWatch Logs stops encrypting newly ingested data for the log group. All previously ingested data remains encrypted, and AWS CloudWatch Logs requires permissions for the CMK whenever the encrypted data is requested.
- log
Group StringClass - Specified the log class of the log group. Possible values are:
STANDARD
orINFREQUENT_ACCESS
. - name String
- The name of the log group. If omitted, this provider will assign a random, unique name.
- name
Prefix String - Creates a unique name beginning with the specified prefix. Conflicts with
name
. - retention
In IntegerDays - Specifies the number of days you want to retain log events in the specified log group. Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1096, 1827, 2192, 2557, 2922, 3288, 3653, and 0. If you select 0, the events in the log group are always retained and never expire.
- skip
Destroy Boolean - Set to true if you do not wish the log group (and any logs it may contain) to be deleted at destroy time, and instead just remove the log group from the state.
- Map<String,String>
- A map of tags to assign to the resource. .If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- kms
Key stringId - The ARN of the KMS Key to use when encrypting log data. Please note, after the AWS KMS CMK is disassociated from the log group, AWS CloudWatch Logs stops encrypting newly ingested data for the log group. All previously ingested data remains encrypted, and AWS CloudWatch Logs requires permissions for the CMK whenever the encrypted data is requested.
- log
Group stringClass - Specified the log class of the log group. Possible values are:
STANDARD
orINFREQUENT_ACCESS
. - name string
- The name of the log group. If omitted, this provider will assign a random, unique name.
- name
Prefix string - Creates a unique name beginning with the specified prefix. Conflicts with
name
. - retention
In numberDays - Specifies the number of days you want to retain log events in the specified log group. Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1096, 1827, 2192, 2557, 2922, 3288, 3653, and 0. If you select 0, the events in the log group are always retained and never expire.
- skip
Destroy boolean - Set to true if you do not wish the log group (and any logs it may contain) to be deleted at destroy time, and instead just remove the log group from the state.
- {[key: string]: string}
- A map of tags to assign to the resource. .If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- kms_
key_ strid - The ARN of the KMS Key to use when encrypting log data. Please note, after the AWS KMS CMK is disassociated from the log group, AWS CloudWatch Logs stops encrypting newly ingested data for the log group. All previously ingested data remains encrypted, and AWS CloudWatch Logs requires permissions for the CMK whenever the encrypted data is requested.
- log_
group_ strclass - Specified the log class of the log group. Possible values are:
STANDARD
orINFREQUENT_ACCESS
. - name str
- The name of the log group. If omitted, this provider will assign a random, unique name.
- name_
prefix str - Creates a unique name beginning with the specified prefix. Conflicts with
name
. - retention_
in_ intdays - Specifies the number of days you want to retain log events in the specified log group. Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1096, 1827, 2192, 2557, 2922, 3288, 3653, and 0. If you select 0, the events in the log group are always retained and never expire.
- skip_
destroy bool - Set to true if you do not wish the log group (and any logs it may contain) to be deleted at destroy time, and instead just remove the log group from the state.
- Mapping[str, str]
- A map of tags to assign to the resource. .If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- kms
Key StringId - The ARN of the KMS Key to use when encrypting log data. Please note, after the AWS KMS CMK is disassociated from the log group, AWS CloudWatch Logs stops encrypting newly ingested data for the log group. All previously ingested data remains encrypted, and AWS CloudWatch Logs requires permissions for the CMK whenever the encrypted data is requested.
- log
Group StringClass - Specified the log class of the log group. Possible values are:
STANDARD
orINFREQUENT_ACCESS
. - name String
- The name of the log group. If omitted, this provider will assign a random, unique name.
- name
Prefix String - Creates a unique name beginning with the specified prefix. Conflicts with
name
. - retention
In NumberDays - Specifies the number of days you want to retain log events in the specified log group. Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1096, 1827, 2192, 2557, 2922, 3288, 3653, and 0. If you select 0, the events in the log group are always retained and never expire.
- skip
Destroy Boolean - Set to true if you do not wish the log group (and any logs it may contain) to be deleted at destroy time, and instead just remove the log group from the state.
- Map<String>
- A map of tags to assign to the resource. .If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
RoleWithPolicy, RoleWithPolicyArgs
- Description string
- Description of the role.
- Force
Detach boolPolicies - Whether to force detaching any policies the role has before destroying it. Defaults to
false
. - Inline
Policies List<Pulumi.Aws. Iam. Inputs. Role Inline Policy> - Configuration block defining an exclusive set of IAM inline policies associated with the IAM role. See below. If no blocks are configured, the provider will not manage any inline policies in this resource. Configuring one empty block (i.e.,
inline_policy {}
) will cause the provider to remove all inline policies added out of band onapply
. - Managed
Policy List<string>Arns - Max
Session intDuration - Maximum session duration (in seconds) that you want to set for the specified role. If you do not specify a value for this setting, the default maximum of one hour is applied. This setting can have a value from 1 hour to 12 hours.
- Name string
- Friendly name of the role. If omitted, the provider will assign a random, unique name. See IAM Identifiers for more information.
- Name
Prefix string - Creates a unique friendly name beginning with the specified prefix. Conflicts with
name
. - Path string
- Path to the role. See IAM Identifiers for more information.
- Permissions
Boundary string - ARN of the policy that is used to set the permissions boundary for the role.
- Policy
Arns List<string> - ARNs of the policies to attach to the created role.
- Dictionary<string, string>
- Key-value mapping of tags for the IAM role. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- Description string
- Description of the role.
- Force
Detach boolPolicies - Whether to force detaching any policies the role has before destroying it. Defaults to
false
. - Inline
Policies RoleInline Policy - Configuration block defining an exclusive set of IAM inline policies associated with the IAM role. See below. If no blocks are configured, the provider will not manage any inline policies in this resource. Configuring one empty block (i.e.,
inline_policy {}
) will cause the provider to remove all inline policies added out of band onapply
. - Managed
Policy []stringArns - Max
Session intDuration - Maximum session duration (in seconds) that you want to set for the specified role. If you do not specify a value for this setting, the default maximum of one hour is applied. This setting can have a value from 1 hour to 12 hours.
- Name string
- Friendly name of the role. If omitted, the provider will assign a random, unique name. See IAM Identifiers for more information.
- Name
Prefix string - Creates a unique friendly name beginning with the specified prefix. Conflicts with
name
. - Path string
- Path to the role. See IAM Identifiers for more information.
- Permissions
Boundary string - ARN of the policy that is used to set the permissions boundary for the role.
- Policy
Arns []string - ARNs of the policies to attach to the created role.
- map[string]string
- Key-value mapping of tags for the IAM role. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- description String
- Description of the role.
- force
Detach BooleanPolicies - Whether to force detaching any policies the role has before destroying it. Defaults to
false
. - inline
Policies List<RoleInline Policy> - Configuration block defining an exclusive set of IAM inline policies associated with the IAM role. See below. If no blocks are configured, the provider will not manage any inline policies in this resource. Configuring one empty block (i.e.,
inline_policy {}
) will cause the provider to remove all inline policies added out of band onapply
. - managed
Policy List<String>Arns - max
Session IntegerDuration - Maximum session duration (in seconds) that you want to set for the specified role. If you do not specify a value for this setting, the default maximum of one hour is applied. This setting can have a value from 1 hour to 12 hours.
- name String
- Friendly name of the role. If omitted, the provider will assign a random, unique name. See IAM Identifiers for more information.
- name
Prefix String - Creates a unique friendly name beginning with the specified prefix. Conflicts with
name
. - path String
- Path to the role. See IAM Identifiers for more information.
- permissions
Boundary String - ARN of the policy that is used to set the permissions boundary for the role.
- policy
Arns List<String> - ARNs of the policies to attach to the created role.
- Map<String,String>
- Key-value mapping of tags for the IAM role. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- description string
- Description of the role.
- force
Detach booleanPolicies - Whether to force detaching any policies the role has before destroying it. Defaults to
false
. - inline
Policies pulumiAws.types.input.iam. Role Inline Policy[] - Configuration block defining an exclusive set of IAM inline policies associated with the IAM role. See below. If no blocks are configured, the provider will not manage any inline policies in this resource. Configuring one empty block (i.e.,
inline_policy {}
) will cause the provider to remove all inline policies added out of band onapply
. - managed
Policy string[]Arns - max
Session numberDuration - Maximum session duration (in seconds) that you want to set for the specified role. If you do not specify a value for this setting, the default maximum of one hour is applied. This setting can have a value from 1 hour to 12 hours.
- name string
- Friendly name of the role. If omitted, the provider will assign a random, unique name. See IAM Identifiers for more information.
- name
Prefix string - Creates a unique friendly name beginning with the specified prefix. Conflicts with
name
. - path string
- Path to the role. See IAM Identifiers for more information.
- permissions
Boundary string - ARN of the policy that is used to set the permissions boundary for the role.
- policy
Arns string[] - ARNs of the policies to attach to the created role.
- {[key: string]: string}
- Key-value mapping of tags for the IAM role. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- description str
- Description of the role.
- force_
detach_ boolpolicies - Whether to force detaching any policies the role has before destroying it. Defaults to
false
. - inline_
policies Sequence[pulumi_aws.iam. Role Inline Policy Args] - Configuration block defining an exclusive set of IAM inline policies associated with the IAM role. See below. If no blocks are configured, the provider will not manage any inline policies in this resource. Configuring one empty block (i.e.,
inline_policy {}
) will cause the provider to remove all inline policies added out of band onapply
. - managed_
policy_ Sequence[str]arns - max_
session_ intduration - Maximum session duration (in seconds) that you want to set for the specified role. If you do not specify a value for this setting, the default maximum of one hour is applied. This setting can have a value from 1 hour to 12 hours.
- name str
- Friendly name of the role. If omitted, the provider will assign a random, unique name. See IAM Identifiers for more information.
- name_
prefix str - Creates a unique friendly name beginning with the specified prefix. Conflicts with
name
. - path str
- Path to the role. See IAM Identifiers for more information.
- permissions_
boundary str - ARN of the policy that is used to set the permissions boundary for the role.
- policy_
arns Sequence[str] - ARNs of the policies to attach to the created role.
- Mapping[str, str]
- Key-value mapping of tags for the IAM role. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
- description String
- Description of the role.
- force
Detach BooleanPolicies - Whether to force detaching any policies the role has before destroying it. Defaults to
false
. - inline
Policies List<Property Map> - Configuration block defining an exclusive set of IAM inline policies associated with the IAM role. See below. If no blocks are configured, the provider will not manage any inline policies in this resource. Configuring one empty block (i.e.,
inline_policy {}
) will cause the provider to remove all inline policies added out of band onapply
. - managed
Policy List<String>Arns - max
Session NumberDuration - Maximum session duration (in seconds) that you want to set for the specified role. If you do not specify a value for this setting, the default maximum of one hour is applied. This setting can have a value from 1 hour to 12 hours.
- name String
- Friendly name of the role. If omitted, the provider will assign a random, unique name. See IAM Identifiers for more information.
- name
Prefix String - Creates a unique friendly name beginning with the specified prefix. Conflicts with
name
. - path String
- Path to the role. See IAM Identifiers for more information.
- permissions
Boundary String - ARN of the policy that is used to set the permissions boundary for the role.
- policy
Arns List<String> - ARNs of the policies to attach to the created role.
- Map<String>
- Key-value mapping of tags for the IAM role. If configured with a provider
default_tags
configuration block present, tags with matching keys will overwrite those defined at the provider-level.
TaskDefinitionContainerDefinition, TaskDefinitionContainerDefinitionArgs
- Image string
- The image used to start a container. This string is passed directly to the Docker daemon.
- Name string
- The name of a container. Up to 255 letters (uppercase and lowercase), numbers, hyphens, and underscores are allowed
- Command List<string>
- Cpu int
- Depends
On List<TaskDefinition Container Dependency> - Disable
Networking bool - Dns
Search List<string>Domains - Dns
Servers List<string> - Docker
Labels object - Docker
Security List<string>Options - Entry
Point List<string> - Environment
List<Task
Definition Key Value Pair> - The environment variables to pass to a container
- Environment
Files List<TaskDefinition Environment File> - The list of one or more files that contain the environment variables to pass to a container
- Essential bool
- Extra
Hosts List<TaskDefinition Host Entry> - Firelens
Configuration TaskDefinition Firelens Configuration - Health
Check TaskDefinition Health Check - Hostname string
- Interactive bool
- Links List<string>
- Linux
Parameters TaskDefinition Linux Parameters - Log
Configuration TaskDefinition Log Configuration - Memory int
- The amount (in MiB) of memory to present to the container. If your container attempts to exceed the memory specified here, the container is killed.
- Memory
Reservation int - Mount
Points List<TaskDefinition Mount Point> - Port
Mappings List<TaskDefinition Port Mapping> - Port mappings allow containers to access ports on the host container instance to send or receive traffic.
- Privileged bool
- Pseudo
Terminal bool - Readonly
Root boolFilesystem - Repository
Credentials TaskDefinition Repository Credentials - Resource
Requirements List<TaskDefinition Resource Requirement> - Secrets
List<Task
Definition Secret> - Start
Timeout int - Stop
Timeout int - System
Controls List<TaskDefinition System Control> - Ulimits
List<Task
Definition Ulimit> - User string
- Volumes
From List<TaskDefinition Volume From> - Working
Directory string
- Image string
- The image used to start a container. This string is passed directly to the Docker daemon.
- Name string
- The name of a container. Up to 255 letters (uppercase and lowercase), numbers, hyphens, and underscores are allowed
- Command []string
- Cpu int
- Depends
On []TaskDefinition Container Dependency - Disable
Networking bool - Dns
Search []stringDomains - Dns
Servers []string - Docker
Labels interface{} - Docker
Security []stringOptions - Entry
Point []string - Environment
[]Task
Definition Key Value Pair - The environment variables to pass to a container
- Environment
Files []TaskDefinition Environment File - The list of one or more files that contain the environment variables to pass to a container
- Essential bool
- Extra
Hosts []TaskDefinition Host Entry - Firelens
Configuration TaskDefinition Firelens Configuration - Health
Check TaskDefinition Health Check - Hostname string
- Interactive bool
- Links []string
- Linux
Parameters TaskDefinition Linux Parameters - Log
Configuration TaskDefinition Log Configuration - Memory int
- The amount (in MiB) of memory to present to the container. If your container attempts to exceed the memory specified here, the container is killed.
- Memory
Reservation int - Mount
Points []TaskDefinition Mount Point - Port
Mappings []TaskDefinition Port Mapping - Port mappings allow containers to access ports on the host container instance to send or receive traffic.
- Privileged bool
- Pseudo
Terminal bool - Readonly
Root boolFilesystem - Repository
Credentials TaskDefinition Repository Credentials - Resource
Requirements []TaskDefinition Resource Requirement - Secrets
[]Task
Definition Secret - Start
Timeout int - Stop
Timeout int - System
Controls []TaskDefinition System Control - Ulimits
[]Task
Definition Ulimit - User string
- Volumes
From []TaskDefinition Volume From - Working
Directory string
- image String
- The image used to start a container. This string is passed directly to the Docker daemon.
- name String
- The name of a container. Up to 255 letters (uppercase and lowercase), numbers, hyphens, and underscores are allowed
- command List<String>
- cpu Integer
- depends
On List<TaskDefinition Container Dependency> - disable
Networking Boolean - dns
Search List<String>Domains - dns
Servers List<String> - docker
Labels Object - docker
Security List<String>Options - entry
Point List<String> - environment
List<Task
Definition Key Value Pair> - The environment variables to pass to a container
- environment
Files List<TaskDefinition Environment File> - The list of one or more files that contain the environment variables to pass to a container
- essential Boolean
- extra
Hosts List<TaskDefinition Host Entry> - firelens
Configuration TaskDefinition Firelens Configuration - health
Check TaskDefinition Health Check - hostname String
- interactive Boolean
- links List<String>
- linux
Parameters TaskDefinition Linux Parameters - log
Configuration TaskDefinition Log Configuration - memory Integer
- The amount (in MiB) of memory to present to the container. If your container attempts to exceed the memory specified here, the container is killed.
- memory
Reservation Integer - mount
Points List<TaskDefinition Mount Point> - port
Mappings List<TaskDefinition Port Mapping> - Port mappings allow containers to access ports on the host container instance to send or receive traffic.
- privileged Boolean
- pseudo
Terminal Boolean - readonly
Root BooleanFilesystem - repository
Credentials TaskDefinition Repository Credentials - resource
Requirements List<TaskDefinition Resource Requirement> - secrets
List<Task
Definition Secret> - start
Timeout Integer - stop
Timeout Integer - system
Controls List<TaskDefinition System Control> - ulimits
List<Task
Definition Ulimit> - user String
- volumes
From List<TaskDefinition Volume From> - working
Directory String
- image string
- The image used to start a container. This string is passed directly to the Docker daemon.
- name string
- The name of a container. Up to 255 letters (uppercase and lowercase), numbers, hyphens, and underscores are allowed
- command string[]
- cpu number
- depends
On TaskDefinition Container Dependency[] - disable
Networking boolean - dns
Search string[]Domains - dns
Servers string[] - docker
Labels any - docker
Security string[]Options - entry
Point string[] - environment
Task
Definition Key Value Pair[] - The environment variables to pass to a container
- environment
Files TaskDefinition Environment File[] - The list of one or more files that contain the environment variables to pass to a container
- essential boolean
- extra
Hosts TaskDefinition Host Entry[] - firelens
Configuration TaskDefinition Firelens Configuration - health
Check TaskDefinition Health Check - hostname string
- interactive boolean
- links string[]
- linux
Parameters TaskDefinition Linux Parameters - log
Configuration TaskDefinition Log Configuration - memory number
- The amount (in MiB) of memory to present to the container. If your container attempts to exceed the memory specified here, the container is killed.
- memory
Reservation number - mount
Points TaskDefinition Mount Point[] - port
Mappings TaskDefinition Port Mapping[] - Port mappings allow containers to access ports on the host container instance to send or receive traffic.
- privileged boolean
- pseudo
Terminal boolean - readonly
Root booleanFilesystem - repository
Credentials TaskDefinition Repository Credentials - resource
Requirements TaskDefinition Resource Requirement[] - secrets
Task
Definition Secret[] - start
Timeout number - stop
Timeout number - system
Controls TaskDefinition System Control[] - ulimits
Task
Definition Ulimit[] - user string
- volumes
From TaskDefinition Volume From[] - working
Directory string
- image str
- The image used to start a container. This string is passed directly to the Docker daemon.
- name str
- The name of a container. Up to 255 letters (uppercase and lowercase), numbers, hyphens, and underscores are allowed
- command Sequence[str]
- cpu int
- depends_
on Sequence[TaskDefinition Container Dependency] - disable_
networking bool - dns_
search_ Sequence[str]domains - dns_
servers Sequence[str] - docker_
labels Any - docker_
security_ Sequence[str]options - entry_
point Sequence[str] - environment
Sequence[Task
Definition Key Value Pair] - The environment variables to pass to a container
- environment_
files Sequence[TaskDefinition Environment File] - The list of one or more files that contain the environment variables to pass to a container
- essential bool
- extra_
hosts Sequence[TaskDefinition Host Entry] - firelens_
configuration TaskDefinition Firelens Configuration - health_
check TaskDefinition Health Check - hostname str
- interactive bool
- links Sequence[str]
- linux_
parameters TaskDefinition Linux Parameters - log_
configuration TaskDefinition Log Configuration - memory int
- The amount (in MiB) of memory to present to the container. If your container attempts to exceed the memory specified here, the container is killed.
- memory_
reservation int - mount_
points Sequence[TaskDefinition Mount Point] - port_
mappings Sequence[TaskDefinition Port Mapping] - Port mappings allow containers to access ports on the host container instance to send or receive traffic.
- privileged bool
- pseudo_
terminal bool - readonly_
root_ boolfilesystem - repository_
credentials TaskDefinition Repository Credentials - resource_
requirements Sequence[TaskDefinition Resource Requirement] - secrets
Sequence[Task
Definition Secret] - start_
timeout int - stop_
timeout int - system_
controls Sequence[TaskDefinition System Control] - ulimits
Sequence[Task
Definition Ulimit] - user str
- volumes_
from Sequence[TaskDefinition Volume From] - working_
directory str
- image String
- The image used to start a container. This string is passed directly to the Docker daemon.
- name String
- The name of a container. Up to 255 letters (uppercase and lowercase), numbers, hyphens, and underscores are allowed
- command List<String>
- cpu Number
- depends
On List<Property Map> - disable
Networking Boolean - dns
Search List<String>Domains - dns
Servers List<String> - docker
Labels Any - docker
Security List<String>Options - entry
Point List<String> - environment List<Property Map>
- The environment variables to pass to a container
- environment
Files List<Property Map> - The list of one or more files that contain the environment variables to pass to a container
- essential Boolean
- extra
Hosts List<Property Map> - firelens
Configuration Property Map - health
Check Property Map - hostname String
- interactive Boolean
- links List<String>
- linux
Parameters Property Map - log
Configuration Property Map - memory Number
- The amount (in MiB) of memory to present to the container. If your container attempts to exceed the memory specified here, the container is killed.
- memory
Reservation Number - mount
Points List<Property Map> - port
Mappings List<Property Map> - Port mappings allow containers to access ports on the host container instance to send or receive traffic.
- privileged Boolean
- pseudo
Terminal Boolean - readonly
Root BooleanFilesystem - repository
Credentials Property Map - resource
Requirements List<Property Map> - secrets List<Property Map>
- start
Timeout Number - stop
Timeout Number - system
Controls List<Property Map> - ulimits List<Property Map>
- user String
- volumes
From List<Property Map> - working
Directory String
TaskDefinitionContainerDependency, TaskDefinitionContainerDependencyArgs
- Condition string
- Container
Name string
- Condition string
- Container
Name string
- condition String
- container
Name String
- condition string
- container
Name string
- condition str
- container_
name str
- condition String
- container
Name String
TaskDefinitionDevice, TaskDefinitionDeviceArgs
- Container
Path string - Host
Path string - Permissions List<string>
- Container
Path string - Host
Path string - Permissions []string
- container
Path String - host
Path String - permissions List<String>
- container
Path string - host
Path string - permissions string[]
- container_
path str - host_
path str - permissions Sequence[str]
- container
Path String - host
Path String - permissions List<String>
TaskDefinitionEnvironmentFile, TaskDefinitionEnvironmentFileArgs
TaskDefinitionFirelensConfiguration, TaskDefinitionFirelensConfigurationArgs
TaskDefinitionHealthCheck, TaskDefinitionHealthCheckArgs
- Command List<string>
- A string array representing the command that the container runs to determine if it is healthy.
- Interval int
- The time period in seconds between each health check execution. You may specify between 5 and 300 seconds. The default value is 30 seconds.
- Retries int
- The number of times to retry a failed health check before the container is considered unhealthy. You may specify between 1 and 10 retries. The default value is three retries.
- Start
Period int - The optional grace period within which to provide containers time to bootstrap before failed health checks count towards the maximum number of retries. You may specify between 0 and 300 seconds. The startPeriod is disabled by default.
- Timeout int
- The time period in seconds to wait for a health check to succeed before it is considered a failure. You may specify between 2 and 60 seconds. The default value is 5 seconds.
- Command []string
- A string array representing the command that the container runs to determine if it is healthy.
- Interval int
- The time period in seconds between each health check execution. You may specify between 5 and 300 seconds. The default value is 30 seconds.
- Retries int
- The number of times to retry a failed health check before the container is considered unhealthy. You may specify between 1 and 10 retries. The default value is three retries.
- Start
Period int - The optional grace period within which to provide containers time to bootstrap before failed health checks count towards the maximum number of retries. You may specify between 0 and 300 seconds. The startPeriod is disabled by default.
- Timeout int
- The time period in seconds to wait for a health check to succeed before it is considered a failure. You may specify between 2 and 60 seconds. The default value is 5 seconds.
- command List<String>
- A string array representing the command that the container runs to determine if it is healthy.
- interval Integer
- The time period in seconds between each health check execution. You may specify between 5 and 300 seconds. The default value is 30 seconds.
- retries Integer
- The number of times to retry a failed health check before the container is considered unhealthy. You may specify between 1 and 10 retries. The default value is three retries.
- start
Period Integer - The optional grace period within which to provide containers time to bootstrap before failed health checks count towards the maximum number of retries. You may specify between 0 and 300 seconds. The startPeriod is disabled by default.
- timeout Integer
- The time period in seconds to wait for a health check to succeed before it is considered a failure. You may specify between 2 and 60 seconds. The default value is 5 seconds.
- command string[]
- A string array representing the command that the container runs to determine if it is healthy.
- interval number
- The time period in seconds between each health check execution. You may specify between 5 and 300 seconds. The default value is 30 seconds.
- retries number
- The number of times to retry a failed health check before the container is considered unhealthy. You may specify between 1 and 10 retries. The default value is three retries.
- start
Period number - The optional grace period within which to provide containers time to bootstrap before failed health checks count towards the maximum number of retries. You may specify between 0 and 300 seconds. The startPeriod is disabled by default.
- timeout number
- The time period in seconds to wait for a health check to succeed before it is considered a failure. You may specify between 2 and 60 seconds. The default value is 5 seconds.
- command Sequence[str]
- A string array representing the command that the container runs to determine if it is healthy.
- interval int
- The time period in seconds between each health check execution. You may specify between 5 and 300 seconds. The default value is 30 seconds.
- retries int
- The number of times to retry a failed health check before the container is considered unhealthy. You may specify between 1 and 10 retries. The default value is three retries.
- start_
period int - The optional grace period within which to provide containers time to bootstrap before failed health checks count towards the maximum number of retries. You may specify between 0 and 300 seconds. The startPeriod is disabled by default.
- timeout int
- The time period in seconds to wait for a health check to succeed before it is considered a failure. You may specify between 2 and 60 seconds. The default value is 5 seconds.
- command List<String>
- A string array representing the command that the container runs to determine if it is healthy.
- interval Number
- The time period in seconds between each health check execution. You may specify between 5 and 300 seconds. The default value is 30 seconds.
- retries Number
- The number of times to retry a failed health check before the container is considered unhealthy. You may specify between 1 and 10 retries. The default value is three retries.
- start
Period Number - The optional grace period within which to provide containers time to bootstrap before failed health checks count towards the maximum number of retries. You may specify between 0 and 300 seconds. The startPeriod is disabled by default.
- timeout Number
- The time period in seconds to wait for a health check to succeed before it is considered a failure. You may specify between 2 and 60 seconds. The default value is 5 seconds.
TaskDefinitionHostEntry, TaskDefinitionHostEntryArgs
- hostname str
- ip_
address str
TaskDefinitionKernelCapabilities, TaskDefinitionKernelCapabilitiesArgs
TaskDefinitionKeyValuePair, TaskDefinitionKeyValuePairArgs
TaskDefinitionLinuxParameters, TaskDefinitionLinuxParametersArgs
- capabilities Property Map
- devices List<Property Map>
- init
Process BooleanEnabled - max
Swap Number - Number
- swappiness Number
- tmpfs List<Property Map>
TaskDefinitionLogConfiguration, TaskDefinitionLogConfigurationArgs
- Log
Driver string - Options object
- Secret
Options List<TaskDefinition Secret>
- Log
Driver string - Options interface{}
- Secret
Options []TaskDefinition Secret
- log
Driver String - options Object
- secret
Options List<TaskDefinition Secret>
- log
Driver String - options Any
- secret
Options List<Property Map>
TaskDefinitionMountPoint, TaskDefinitionMountPointArgs
- Container
Path string - Read
Only bool - Source
Volume string
- Container
Path string - Read
Only bool - Source
Volume string
- container
Path String - read
Only Boolean - source
Volume String
- container
Path string - read
Only boolean - source
Volume string
- container_
path str - read_
only bool - source_
volume str
- container
Path String - read
Only Boolean - source
Volume String
TaskDefinitionPortMapping, TaskDefinitionPortMappingArgs
- App
Protocol Pulumi.Awsx. Ecs. Task Definition Port Mapping App Protocol - Container
Port int - Container
Port stringRange - Host
Port int - Name string
- Protocol string
- Target
Group Pulumi.Aws. LB. Target Group - This type is defined in the AWS Classic package.
- App
Protocol TaskDefinition Port Mapping App Protocol - Container
Port int - Container
Port stringRange - Host
Port int - Name string
- Protocol string
- Target
Group TargetGroup - This type is defined in the AWS Classic package.
- app
Protocol TaskDefinition Port Mapping App Protocol - container
Port Integer - container
Port StringRange - host
Port Integer - name String
- protocol String
- target
Group TargetGroup - This type is defined in the AWS Classic package.
- app
Protocol TaskDefinition Port Mapping App Protocol - container
Port number - container
Port stringRange - host
Port number - name string
- protocol string
- target
Group pulumiAws.lb. Target Group - This type is defined in the AWS Classic package.
- app_
protocol TaskDefinition Port Mapping App Protocol - container_
port int - container_
port_ strrange - host_
port int - name str
- protocol str
- target_
group pulumi_aws.lb. Target Group - This type is defined in the AWS Classic package.
- app
Protocol "http" | "http2" | "grpc" - container
Port Number - container
Port StringRange - host
Port Number - name String
- protocol String
- target
Group aws:lb:TargetGroup - This type is defined in the AWS Classic package.
TaskDefinitionPortMappingAppProtocol, TaskDefinitionPortMappingAppProtocolArgs
- Http
- http
- Http2
- http2
- Grpc
- grpc
- Task
Definition Port Mapping App Protocol Http - http
- Task
Definition Port Mapping App Protocol Http2 - http2
- Task
Definition Port Mapping App Protocol Grpc - grpc
- Http
- http
- Http2
- http2
- Grpc
- grpc
- Http
- http
- Http2
- http2
- Grpc
- grpc
- HTTP
- http
- HTTP2
- http2
- GRPC
- grpc
- "http"
- http
- "http2"
- http2
- "grpc"
- grpc
TaskDefinitionRepositoryCredentials, TaskDefinitionRepositoryCredentialsArgs
- Credentials
Parameter string
- Credentials
Parameter string
- credentials
Parameter String
- credentials
Parameter string
- credentials
Parameter String
TaskDefinitionResourceRequirement, TaskDefinitionResourceRequirementArgs
TaskDefinitionSecret, TaskDefinitionSecretArgs
- name str
- value_
from str
TaskDefinitionSystemControl, TaskDefinitionSystemControlArgs
TaskDefinitionTmpfs, TaskDefinitionTmpfsArgs
- Size int
- Container
Path string - Mount
Options List<string>
- Size int
- Container
Path string - Mount
Options []string
- size Integer
- container
Path String - mount
Options List<String>
- size number
- container
Path string - mount
Options string[]
- size int
- container_
path str - mount_
options Sequence[str]
- size Number
- container
Path String - mount
Options List<String>
TaskDefinitionUlimit, TaskDefinitionUlimitArgs
- hard_
limit int - name str
- soft_
limit int