Debugging failed Lambda renders
General debugging strategy
Reproduce a render via thenpx remotion lambda render
command.
- Use
--props
to pass in a JSON file with the same input props as the render you want to debug. - Use--log=verbose
to get detailed debugging information.
Reasons a render may fail
There are four reasons renders may fail:
- 1An error occurs in your React code.
- 2A timeout occurs after calling
delayRender()
. - 3The Lambda function rendering one of the chunks times out.
- 4The main Lambda function times out.
Error in React code
If your code throws an error, you will see the error in the logs. If you are rendering via the CLI, the error will be symbolicated which can help you find the error in your code. Try to fix the error, redeploy the site and re-render.
Timeouts
Understanding which timeout occurred
If your error message reads that a delayRender()
call timed out, a function has called delayRender()
but did not call continueRender()
within the timeout period. This is usually caused by a bug in your code. See Debugging timeout for more tips.
You can increase the timeout by passing timeoutInMilliseconds
to renderMediaOnLamba()
or passing --timeout
to the CLI when rendering a video. Don't confuse it with the --timeout
flag for the CLI when deploying a function (see below).
If your error message reads that the main Lambda function has timed out, it
means that the render was still ongoing, but the maximum execution duration of
the Lambda function has been hit. This is caused by either:
- A render that takes too long to complete within the specified duration. In that case, you should increase the function timeout by passing
--timeout
to the CLI when deploying a function. - A render that has a bottleneck and completes slowly on Lambda. In that case, you should identify the bottleneck by measuring and optimizing the render. See Optimizing for speed for more tips.
- A chunk is getting stuck, making it impossible for the main function to complete the task of concatenating the chunks. You should identify the chunk that is getting stuck by looking at the logs. See below for how to do this.
Inspecting the logs
Get the Log URL:- If you use the CLI, add
--log=verbose
to the command. This will print a CloudWatch link to the console. - When using
renderMediaOnLambda()
addlogLevel: "verbose"
as an option. You will get acloudWatchLogs
field in the return value.
Open this link and log into AWS if needed. A log stream will open.
By default, the filter is set to:
"method=renderer,renderId=[render-id]"
Find the logs of a specific chunk
Tweak the query to find the logs of a specific chunk:
method=renderer,renderId=[render-id],chunk=12
will for example find the log stream of chunk 12. If your viewport is big enough, you will also see the chunk numbers in the summary view straight away.
Click the blue link in the Log stream name
column to open the log stream. If you don't see any blue links, click "Display", then select "View in columns with details".
In the logstream, you will see debug logging from Remotion as well as any console.log
statements from your React code.
Find the logs of the main function
Tweakt the query to find the logs of the main function:
method=launch,renderId=[render-id]
You should get one result.
Click the blue link in the Log stream name
column to open the log stream. If you don't see any blue links, click "Display", then select "View in columns with details".
Finding the chunk that failed
To find which chunks failed to render, add --log=verbose
to the Lambda render while rendering via the CLI. Look for a log statement Render folder:
to find the link to the render folder in S3.
When using renderMediaOnLambda()
, you will get a folderInS3Console
field in the return value.
After opening the link, open the chunks
subfolder. Go through each existing chunk and find the ones that are missing. The missing chunks are the ones that failed to render.
After you've identified which chunks are missing, inspect the logs for that chunk to find the cause of the error.
Increasing the timeout
Note that two types of timeouts come into play in Remotion:
- The
delayRender()
timeout. This is the timeout that is defined using--timeout
when callingnpx remotion lambda render
or usingtimeoutInMilliseconds
when callingrenderMediaOnLambda()
. - The Lambda function timeout. This is the timeout that is defined using
--timeout
when callingnpx remotion lambda functions deploy
or usingtimeoutInSeconds
when callingdeployFunction()
.
Reporting an issue
You may report an issue on GitHub and Discord.
Include the progress.json
that lies in the S3 folder of the render, because it includes all informations to reproduce a render.
If you include CloudWatch logs, post the full ones (click "Load more messages" until there are no more to load.)