data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
The function timeout is set to 900 seconds, but the function gives a 524 error after 1 minute (according to the dashboard UI). It is a cron scheduled function. I can't see the logs because it errors, so I don't even know how far it gets.
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
AFAIK 524 is a timeout error. What does the function do? If you call it directly does it work?
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
The counts the number of users in the db with the users endpoint. It has to do some cursor pagination because there are more than 5k
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
it gets triggered internally by the schedule cron
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
Sure, but can you execute it manually, and does it fail then too?
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
you mean manually using the appwrite dashboard UI?
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
Yes
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
it's now running
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
failed again:
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
Could you up the timeout period?
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
it is set to 900
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
Could you provide the function code?
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
i'm setting a counter to see if it exactly crashes after 60 sec.. i just ran it with less max pages and it run in 34 seconds normally.
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
So if you lower the amount you're fetching it works?
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
Maybe try increasing the limit so it has fewer http requests, and add a select query and select only the $id, so it reduces the payload.
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
log(`fetching page ${counter++}`)
const query = lastId ? [Query.limit(limit), Query.cursorAfter(lastId)] : [Query.limit(limit)]
const page = await users.list(query)
allUsers = allUsers.concat(page.users)
lastId = page.users.length > 0 ? page.users[page.users.length - 1].$id : undefined
} while (lastId && counter < 50)```
it actually runs past 1 minute if I increase the counter enough, so it doesn't seem like a timeout issue. But when I remove the counter it crashes with this vague error code: 524 and then it doesn't display any logs so it's a bit hard to debug the issue. Maybe it's something with the lastId check.
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
ow with 50 it actually crashes
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
It seems like it's an issue with slow queries, but I agree it is hard to know exactly what the issue is
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
anyway to see the actual output / error logs?
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
stacktraces?
data:image/s3,"s3://crabby-images/2514f/2514f67d0bbfa5a784560a7c831a8a6c591ae87f" alt=""
Are you on cloud?
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
Yep
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt=""
PS. the Query.select you suggested to select only the $id doesn't seem to work on the users.list method
AppwriteException: Invalid
queries` param: Invalid query method: select
Recommended threads
- Appwrite - DAO / DTO feature
Hello, I have a question about data selection. Typically, this is achieved using solutions like DAO and DTO, but I’m wondering how to accomplish the same in App...
- functions git app integration
I followed this guide here https://appwrite.io/docs/advanced/self-hosting/functions#git The only thing i did differently was instead of _APP_DOMAIN_FUNCTIONS=f...
- Function Timeout with Header Content-Len...
Hey, We've noticed that some of our functions occasionally fail due to an Execution Timeout. Upon inspecting the logs, we see that these failed requests always...
data:image/s3,"s3://crabby-images/88b4b/88b4b3aac34845c367ed1d6b399a22b7c8c8713b" alt=""