Django performances issue

26 views
Skip to first unread message

prakash sharma

unread,
May 2, 2018, 9:24:23 AM5/2/18
to Django users
I have developed the API using DRF but facing the major performances issue.

Here is what the scenario is: I am using DRF. Our API call is growing towards 5k per day. Each API call is taking 3 to 10 minutes of time while responding ( as It creates upto 300 pdf label unique format)

I am using uwsgi( many worker) now with the Apache.

We have implemented the caching but not able improve very much performances level.

Primary query:

Shall we use gunicorn instead of uwsgi? What about message/ job queue? Is this work.

My current server RAM is only 32 GB. Shall I have to increase this if yes how much ( we personal don't want to go for vertical scaling)

Please suggest the approach, first time I am handling such level of performance issue.

I am very optimistic about message/ job queue and gunicorn.

Avraham Serour

unread,
May 2, 2018, 9:33:04 AM5/2/18
to django-users
How many workers do you have?
What those requests do? Even 3 minutes sounds like too much, do they just query from the DB and render a template?
How caching didn't help? did you count the cache miss/hit? What are you caching?


--
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To post to this group, send email to django...@googlegroups.com.
Visit this group at https://groups.google.com/group/django-users.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/86e487d8-6dfe-4049-89a6-5e90a9175d48%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Julio Biason

unread,
May 2, 2018, 9:33:45 AM5/2/18
to django...@googlegroups.com
Hi Prakash,

Do you need to answer the PDF directly? I mean, can't you just use the API to async-ly create the PDFs (using Celery, for example) and just return a jobId of sorts? The use will, then, make calls to check the jobid status; when the PDF is done, the job is changed to complete and you let the user use another URL to download said PDF.

--
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To post to this group, send email to django...@googlegroups.com.
Visit this group at https://groups.google.com/group/django-users.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/86e487d8-6dfe-4049-89a6-5e90a9175d48%40googlegroups.com.
For more options, visit https://groups.google.com/d/optout.



--
Julio Biason, Sofware Engineer
AZION  |  Deliver. Accelerate. Protect.
Office: +55 51 3083 8101  |  Mobile: +55 51 99907 0554

prakash sharma

unread,
May 2, 2018, 11:42:19 AM5/2/18
to Django users
Hi @Julio
I am also planning to go for the job/message queue, but for this we have to change the default follow so this not feasible at this moment for me.

For now what can be the best approach.


Like server scaling, worker count
Reply all
Reply to author
Forward
0 new messages