Interface LogConfiguration.Builder
- All Superinterfaces:
- Buildable,- CopyableBuilder<LogConfiguration.Builder,,- LogConfiguration> - SdkBuilder<LogConfiguration.Builder,,- LogConfiguration> - SdkPojo
- Enclosing class:
- LogConfiguration
- 
Method SummaryModifier and TypeMethodDescriptionThe log driver to use for the container.The log driver to use for the container.The configuration options to send to the log driver.secretOptions(Collection<Secret> secretOptions) The secrets to pass to the log configuration.secretOptions(Consumer<Secret.Builder>... secretOptions) The secrets to pass to the log configuration.secretOptions(Secret... secretOptions) The secrets to pass to the log configuration.Methods inherited from interface software.amazon.awssdk.utils.builder.CopyableBuildercopyMethods inherited from interface software.amazon.awssdk.utils.builder.SdkBuilderapplyMutation, buildMethods inherited from interface software.amazon.awssdk.core.SdkPojoequalsBySdkFields, sdkFields
- 
Method Details- 
logDriverThe log driver to use for the container. For tasks on Fargate, the supported log drivers are awslogs,splunk, andawsfirelens.For tasks hosted on Amazon EC2 instances, the supported log drivers are awslogs,fluentd,gelf,json-file,journald,syslog,splunk, andawsfirelens.For more information about using the awslogslog driver, see Send Amazon ECS logs to CloudWatch in the Amazon Elastic Container Service Developer Guide.For more information about using the awsfirelenslog driver, see Send Amazon ECS logs to an Amazon Web Services service or Amazon Web Services Partner.If you have a custom driver that isn't listed, you can fork the Amazon ECS container agent project that's available on GitHub and customize it to work with that driver. We encourage you to submit pull requests for changes that you would like to have included. However, we don't currently provide support for running modified copies of this software. - Parameters:
- logDriver- The log driver to use for the container.- For tasks on Fargate, the supported log drivers are - awslogs,- splunk, and- awsfirelens.- For tasks hosted on Amazon EC2 instances, the supported log drivers are - awslogs,- fluentd,- gelf,- json-file,- journald,- syslog,- splunk, and- awsfirelens.- For more information about using the - awslogslog driver, see Send Amazon ECS logs to CloudWatch in the Amazon Elastic Container Service Developer Guide.- For more information about using the - awsfirelenslog driver, see Send Amazon ECS logs to an Amazon Web Services service or Amazon Web Services Partner.- If you have a custom driver that isn't listed, you can fork the Amazon ECS container agent project that's available on GitHub and customize it to work with that driver. We encourage you to submit pull requests for changes that you would like to have included. However, we don't currently provide support for running modified copies of this software. 
- Returns:
- Returns a reference to this object so that method calls can be chained together.
- See Also:
 
- 
logDriverThe log driver to use for the container. For tasks on Fargate, the supported log drivers are awslogs,splunk, andawsfirelens.For tasks hosted on Amazon EC2 instances, the supported log drivers are awslogs,fluentd,gelf,json-file,journald,syslog,splunk, andawsfirelens.For more information about using the awslogslog driver, see Send Amazon ECS logs to CloudWatch in the Amazon Elastic Container Service Developer Guide.For more information about using the awsfirelenslog driver, see Send Amazon ECS logs to an Amazon Web Services service or Amazon Web Services Partner.If you have a custom driver that isn't listed, you can fork the Amazon ECS container agent project that's available on GitHub and customize it to work with that driver. We encourage you to submit pull requests for changes that you would like to have included. However, we don't currently provide support for running modified copies of this software. - Parameters:
- logDriver- The log driver to use for the container.- For tasks on Fargate, the supported log drivers are - awslogs,- splunk, and- awsfirelens.- For tasks hosted on Amazon EC2 instances, the supported log drivers are - awslogs,- fluentd,- gelf,- json-file,- journald,- syslog,- splunk, and- awsfirelens.- For more information about using the - awslogslog driver, see Send Amazon ECS logs to CloudWatch in the Amazon Elastic Container Service Developer Guide.- For more information about using the - awsfirelenslog driver, see Send Amazon ECS logs to an Amazon Web Services service or Amazon Web Services Partner.- If you have a custom driver that isn't listed, you can fork the Amazon ECS container agent project that's available on GitHub and customize it to work with that driver. We encourage you to submit pull requests for changes that you would like to have included. However, we don't currently provide support for running modified copies of this software. 
- Returns:
- Returns a reference to this object so that method calls can be chained together.
- See Also:
 
- 
optionsThe configuration options to send to the log driver. The options you can specify depend on the log driver. Some of the options you can specify when you use the awslogslog driver to route logs to Amazon CloudWatch include the following:- awslogs-create-group
- 
 Required: No Specify whether you want the log group to be created automatically. If this option isn't specified, it defaults to false.Your IAM policy must include the logs:CreateLogGrouppermission before you attempt to useawslogs-create-group.
- awslogs-region
- 
 Required: Yes Specify the Amazon Web Services Region that the awslogslog driver is to send your Docker logs to. You can choose to send all of your logs from clusters in different Regions to a single region in CloudWatch Logs. This is so that they're all visible in one location. Otherwise, you can separate them by Region for more granularity. Make sure that the specified log group exists in the Region that you specify with this option.
- awslogs-group
- 
 Required: Yes Make sure to specify a log group that the awslogslog driver sends its log streams to.
- awslogs-stream-prefix
- 
 Required: Yes, when using the Fargate launch type.Optional for the EC2 launch type, required for the Fargate launch type. Use the awslogs-stream-prefixoption to associate a log stream with the specified prefix, the container name, and the ID of the Amazon ECS task that the container belongs to. If you specify a prefix with this option, then the log stream takes the formatprefix-name/container-name/ecs-task-id.If you don't specify a prefix with this option, then the log stream is named after the container ID that's assigned by the Docker daemon on the container instance. Because it's difficult to trace logs back to the container that sent them with just the Docker container ID (which is only available on the container instance), we recommend that you specify a prefix with this option. For Amazon ECS services, you can use the service name as the prefix. Doing so, you can trace log streams to the service that the container belongs to, the name of the container that sent them, and the ID of the task that the container belongs to. You must specify a stream-prefix for your logs to have your logs appear in the Log pane when using the Amazon ECS console. 
- awslogs-datetime-format
- 
 Required: No This option defines a multiline start pattern in Python strftimeformat. A log message consists of a line that matches the pattern and any following lines that don’t match the pattern. The matched line is the delimiter between log messages.One example of a use case for using this format is for parsing output such as a stack dump, which might otherwise be logged in multiple entries. The correct pattern allows it to be captured in a single entry. For more information, see awslogs-datetime-format. You cannot configure both the awslogs-datetime-formatandawslogs-multiline-patternoptions.Multiline logging performs regular expression parsing and matching of all log messages. This might have a negative impact on logging performance. 
- awslogs-multiline-pattern
- 
 Required: No This option defines a multiline start pattern that uses a regular expression. A log message consists of a line that matches the pattern and any following lines that don’t match the pattern. The matched line is the delimiter between log messages. For more information, see awslogs-multiline-pattern. This option is ignored if awslogs-datetime-formatis also configured.You cannot configure both the awslogs-datetime-formatandawslogs-multiline-patternoptions.Multiline logging performs regular expression parsing and matching of all log messages. This might have a negative impact on logging performance. 
- mode
- 
 Required: No Valid values: non-blocking|blockingThis option defines the delivery mode of log messages from the container to CloudWatch Logs. The delivery mode you choose affects application availability when the flow of logs from container to CloudWatch is interrupted. If you use the blockingmode and the flow of logs to CloudWatch is interrupted, calls from container code to write to thestdoutandstderrstreams will block. The logging thread of the application will block as a result. This may cause the application to become unresponsive and lead to container healthcheck failure.If you use the non-blockingmode, the container's logs are instead stored in an in-memory intermediate buffer configured with themax-buffer-sizeoption. This prevents the application from becoming unresponsive when logs cannot be sent to CloudWatch. We recommend using this mode if you want to ensure service availability and are okay with some log loss. For more information, see Preventing log loss with non-blocking mode in theawslogscontainer log driver.
- max-buffer-size
- 
 Required: No Default value: 1mWhen non-blockingmode is used, themax-buffer-sizelog option controls the size of the buffer that's used for intermediate message storage. Make sure to specify an adequate buffer size based on your application. When the buffer fills up, further logs cannot be stored. Logs that cannot be stored are lost.
 To route logs using the splunklog router, you need to specify asplunk-tokenand asplunk-url.When you use the awsfirelenslog router to route logs to an Amazon Web Services Service or Amazon Web Services Partner Network destination for log storage and analytics, you can set thelog-driver-buffer-limitoption to limit the number of events that are buffered in memory, before being sent to the log router container. It can help to resolve potential log loss issue because high throughput might result in memory running out for the buffer inside of Docker.Other options you can specify when using awsfirelensto route logs depend on the destination. When you export logs to Amazon Data Firehose, you can specify the Amazon Web Services Region withregionand a name for the log stream withdelivery_stream.When you export logs to Amazon Kinesis Data Streams, you can specify an Amazon Web Services Region with regionand a data stream name withstream.When you export logs to Amazon OpenSearch Service, you can specify options like Name,Host(OpenSearch Service endpoint without protocol),Port,Index,Type,Aws_auth,Aws_region,Suppress_Type_Name, andtls.When you export logs to Amazon S3, you can specify the bucket using the bucketoption. You can also specifyregion,total_file_size,upload_timeout, anduse_put_objectas options.This parameter requires version 1.19 of the Docker Remote API or greater on your container instance. To check the Docker Remote API version on your container instance, log in to your container instance and run the following command: sudo docker version --format '{{.Server.APIVersion}}'- Parameters:
- options- The configuration options to send to the log driver.- The options you can specify depend on the log driver. Some of the options you can specify when you use the - awslogslog driver to route logs to Amazon CloudWatch include the following:- awslogs-create-group
- 
        Required: No Specify whether you want the log group to be created automatically. If this option isn't specified, it defaults to false.Your IAM policy must include the logs:CreateLogGrouppermission before you attempt to useawslogs-create-group.
- awslogs-region
- 
        Required: Yes Specify the Amazon Web Services Region that the awslogslog driver is to send your Docker logs to. You can choose to send all of your logs from clusters in different Regions to a single region in CloudWatch Logs. This is so that they're all visible in one location. Otherwise, you can separate them by Region for more granularity. Make sure that the specified log group exists in the Region that you specify with this option.
- awslogs-group
- 
        Required: Yes Make sure to specify a log group that the awslogslog driver sends its log streams to.
- awslogs-stream-prefix
- 
        Required: Yes, when using the Fargate launch type.Optional for the EC2 launch type, required for the Fargate launch type. Use the awslogs-stream-prefixoption to associate a log stream with the specified prefix, the container name, and the ID of the Amazon ECS task that the container belongs to. If you specify a prefix with this option, then the log stream takes the formatprefix-name/container-name/ecs-task-id.If you don't specify a prefix with this option, then the log stream is named after the container ID that's assigned by the Docker daemon on the container instance. Because it's difficult to trace logs back to the container that sent them with just the Docker container ID (which is only available on the container instance), we recommend that you specify a prefix with this option. For Amazon ECS services, you can use the service name as the prefix. Doing so, you can trace log streams to the service that the container belongs to, the name of the container that sent them, and the ID of the task that the container belongs to. You must specify a stream-prefix for your logs to have your logs appear in the Log pane when using the Amazon ECS console. 
- awslogs-datetime-format
- 
        Required: No This option defines a multiline start pattern in Python strftimeformat. A log message consists of a line that matches the pattern and any following lines that don’t match the pattern. The matched line is the delimiter between log messages.One example of a use case for using this format is for parsing output such as a stack dump, which might otherwise be logged in multiple entries. The correct pattern allows it to be captured in a single entry. For more information, see awslogs-datetime-format. You cannot configure both the awslogs-datetime-formatandawslogs-multiline-patternoptions.Multiline logging performs regular expression parsing and matching of all log messages. This might have a negative impact on logging performance. 
- awslogs-multiline-pattern
- 
        Required: No This option defines a multiline start pattern that uses a regular expression. A log message consists of a line that matches the pattern and any following lines that don’t match the pattern. The matched line is the delimiter between log messages. For more information, see awslogs-multiline-pattern. This option is ignored if awslogs-datetime-formatis also configured.You cannot configure both the awslogs-datetime-formatandawslogs-multiline-patternoptions.Multiline logging performs regular expression parsing and matching of all log messages. This might have a negative impact on logging performance. 
- mode
- 
        Required: No Valid values: non-blocking|blockingThis option defines the delivery mode of log messages from the container to CloudWatch Logs. The delivery mode you choose affects application availability when the flow of logs from container to CloudWatch is interrupted. If you use the blockingmode and the flow of logs to CloudWatch is interrupted, calls from container code to write to thestdoutandstderrstreams will block. The logging thread of the application will block as a result. This may cause the application to become unresponsive and lead to container healthcheck failure.If you use the non-blockingmode, the container's logs are instead stored in an in-memory intermediate buffer configured with themax-buffer-sizeoption. This prevents the application from becoming unresponsive when logs cannot be sent to CloudWatch. We recommend using this mode if you want to ensure service availability and are okay with some log loss. For more information, see Preventing log loss with non-blocking mode in theawslogscontainer log driver.
- max-buffer-size
- 
        Required: No Default value: 1mWhen non-blockingmode is used, themax-buffer-sizelog option controls the size of the buffer that's used for intermediate message storage. Make sure to specify an adequate buffer size based on your application. When the buffer fills up, further logs cannot be stored. Logs that cannot be stored are lost.
 - To route logs using the - splunklog router, you need to specify a- splunk-tokenand a- splunk-url.- When you use the - awsfirelenslog router to route logs to an Amazon Web Services Service or Amazon Web Services Partner Network destination for log storage and analytics, you can set the- log-driver-buffer-limitoption to limit the number of events that are buffered in memory, before being sent to the log router container. It can help to resolve potential log loss issue because high throughput might result in memory running out for the buffer inside of Docker.- Other options you can specify when using - awsfirelensto route logs depend on the destination. When you export logs to Amazon Data Firehose, you can specify the Amazon Web Services Region with- regionand a name for the log stream with- delivery_stream.- When you export logs to Amazon Kinesis Data Streams, you can specify an Amazon Web Services Region with - regionand a data stream name with- stream.- When you export logs to Amazon OpenSearch Service, you can specify options like - Name,- Host(OpenSearch Service endpoint without protocol),- Port,- Index,- Type,- Aws_auth,- Aws_region,- Suppress_Type_Name, and- tls.- When you export logs to Amazon S3, you can specify the bucket using the - bucketoption. You can also specify- region,- total_file_size,- upload_timeout, and- use_put_objectas options.- This parameter requires version 1.19 of the Docker Remote API or greater on your container instance. To check the Docker Remote API version on your container instance, log in to your container instance and run the following command: - sudo docker version --format '{{.Server.APIVersion}}'
- Returns:
- Returns a reference to this object so that method calls can be chained together.
 
- 
secretOptionsThe secrets to pass to the log configuration. For more information, see Specifying sensitive data in the Amazon Elastic Container Service Developer Guide. - Parameters:
- secretOptions- The secrets to pass to the log configuration. For more information, see Specifying sensitive data in the Amazon Elastic Container Service Developer Guide.
- Returns:
- Returns a reference to this object so that method calls can be chained together.
 
- 
secretOptionsThe secrets to pass to the log configuration. For more information, see Specifying sensitive data in the Amazon Elastic Container Service Developer Guide. - Parameters:
- secretOptions- The secrets to pass to the log configuration. For more information, see Specifying sensitive data in the Amazon Elastic Container Service Developer Guide.
- Returns:
- Returns a reference to this object so that method calls can be chained together.
 
- 
secretOptionsThe secrets to pass to the log configuration. For more information, see Specifying sensitive data in the Amazon Elastic Container Service Developer Guide. This is a convenience method that creates an instance of theSecret.Builderavoiding the need to create one manually viaSecret.builder().When the Consumercompletes,SdkBuilder.build()is called immediately and its result is passed tosecretOptions(List<Secret>).- Parameters:
- secretOptions- a consumer that will call methods on- Secret.Builder
- Returns:
- Returns a reference to this object so that method calls can be chained together.
- See Also:
 
 
-