Edge Function 504 error response

Last edited: 4/1/2026

An internal 504 from an Edge Function means the function failed to initiate a response within 150s, the max execution time.

As of now, this limit cannot be increased. If your function always needs more time than allowed, skip to When optimization isn't enough section. Otherwise, follow the steps below to speed up response times.

Step 1: Identifying slow Functions#

You can filter for 504 events in the Log Explorer with the below query:

1
select
2
cast(timestamp as datetime) as timestamp,
3
req.pathname,
4
res.status_code,
5
metadata.execution_time_ms
6
from
7
function_edge_logs
8
cross join UNNEST(metadata) as metadata
9
cross join UNNEST(metadata.request) as req
10
cross join UNNEST(metadata.response) as res
11
where res.status_code = 504
12
limit 20;

You can further explore how much time a specific function takes on average by running the below query:

1
select
2
req.pathname,
3
res.status_code,
4
AVG(metadata.execution_time_ms) as avg_runtime_ms,
5
MIN(metadata.execution_time_ms) as min_runtime_ms,
6
MAX(metadata.execution_time_ms) as max_runtime_ms
7
from
8
function_edge_logs
9
cross join UNNEST(metadata) as metadata
10
cross join UNNEST(metadata.request) as req
11
cross join UNNEST(sb) as sb
12
cross join UNNEST(req.headers) as headers
13
cross join UNNEST(metadata.response) as res
14
where req.pathname = '/functions/v1/YOUR_FUNCTION_NAME' -- <---add your function name or remove filter
15
group by req.pathname, res.status_code
16
limit 20;

Once candidate functions are identified, you can investigate more thoroughly.

Step 2: Investigating slow Functions#

Add console.time labels around suspicious sections to pinpoint where time is being spent:

1
console.time('fetch-user-data')
2
const userData = await fetchUserFromDatabase(id)
3
console.timeEnd('fetch-user-data')

The time response will show up in the function's dashboard under the Log tab with the label you assigned it. You can use the label as a keyword to search for the timestamp.

image

For local development, you can also step through execution with Chrome Dev Tools.

Common culprits:

  • Sequential API calls that could run in parallel
  • Unindexed or unoptimized database queries
  • External APIs that are throttling or rate-limiting you
  • Loops without a clear escape condition

Step 3: Optimize#

The below suggestions are some strategies you can pursue to reduce execution times.

Parallelizing requests#

If requests are independent of one another, rather than calling them sequentially, you can speed up operations by calling them in parallel with Promise.all:

1
// Before: sequential: total time = A + B
2
const resultA = await fetch('https://api-one.com/data')
3
const resultB = await fetch('https://api-two.com/data')
4
5
// After: parallel: total time = max(A, B)
6
const [resultA, resultB] = await Promise.all([
7
fetch('https://api-one.com/data'),
8
fetch('https://api-two.com/data'),
9
])

Splitting up logic#

The Edge Function may be doing more than it needs to. It may be better to split up it's logic into multiple parts that can be called individually and run for shorter periods.

Utilize background tasks#

You can initiate functions in a background task to be handled independently of the request/response handler. The process is outlined in the Background Task docs

Offload work to the client or an external service#

Instead of managing all operations within the function itself, there may be an external API that can execute jobs faster and then send back results. Alternatively, you may be able to offload some processing to the requester rather than doing everything within the function itself.

Using alternative libraries#

Some libraries, may be more optimal than others. It's worth exploring alternative libraries that may execute faster or are lighter weight.

Optimizing database operations#

If you are connecting to Supabase Postgres from your function, you can inspect the speed of your queries in the performance dashboard. If the operations are slow, you can review performance and index advisor for improvement suggestions.

Implement caching#

If you are making requests to the same resource and the return values change irregularly, you may be able to implement an external cache layer, such as Upstash Redis to reduce wait times.

Restrict request load#

If the function is used to evaluate user submissions, you can restrict load size to reduce computational time. You can use the below query in the log explorer to filter by the content size in bytes provided by the initial requester:

1
select
2
req.pathname as function_name,
3
res.status_code,
4
AVG(COALESCE(cast(headers.content_length as int), 0)) as avg_content_size_in_bytes,
5
MIN(COALESCE(cast(headers.content_length as int), 0)) as min_content_size_in_bytes,
6
MAX(COALESCE(cast(headers.content_length as int), 0)) as max_content_size_in_bytes
7
from
8
function_edge_logs
9
cross join UNNEST(metadata) as metadata
10
cross join UNNEST(metadata.request) as req
11
cross join UNNEST(sb) as sb
12
cross join UNNEST(req.headers) as headers
13
cross join UNNEST(metadata.response) as res
14
where req.pathname = '/functions/v1/induce-504'
15
group by req.pathname, res.status_code
16
limit 10;

When optimization is not enough#

Edge Functions have a hard runtime ceiling that cannot be raised. If your use case genuinely requires more, consider:

Still stuck?#

Here are some further resources you can review