Configure a job run to use Amazon S3 logs
To be able to monitor the job progress and to troubleshoot failures, you must configure your jobs to send log information to Amazon S3, Amazon CloudWatch Logs, or both. This topic helps you get started publishing application logs to Amazon S3 on your jobs that are launched with Amazon EMR on EKS.
S3 logs IAM policy
Before your jobs can send log data to Amazon S3, the following permissions must be included
in the permissions policy for the job execution role. Replace
amzn-s3-demo-logging-bucket
with the name of your logging
bucket.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "s3:PutObject", "s3:GetObject", "s3:ListBucket" ], "Resource": [ "arn:aws:s3:::
amzn-s3-demo-logging-bucket
", "arn:aws:s3:::amzn-s3-demo-logging-bucket
/*", ] } ] }
Note
Amazon EMR on EKS can also create an Amazon S3 bucket. If an Amazon S3 bucket is not available,
include the “s3:CreateBucket”
permission in the IAM policy.
After you've given your execution role the proper permissions to send logs to Amazon S3,
your log data are sent to the following Amazon S3 locations when
s3MonitoringConfiguration
is passed in the
monitoringConfiguration
section of a start-job-run
request, as
shown in Managing job runs with the AWS CLI.
-
Submitter Logs - /
logUri
/virtual-cluster-id
/jobs/job-id
/containers/pod-name
/(stderr.gz/stdout.gz) -
Driver Logs - /
logUri
/virtual-cluster-id
/jobs/job-id
/containers/spark-application-id
/spark-job-id
-driver/(stderr.gz/stdout.gz) -
Executor Logs - /
logUri
/virtual-cluster-id
/jobs/job-id
/containers/spark-application-id
/executor-pod-name
/(stderr.gz/stdout.gz)