के साथ असंतोषजनक नौकरी पुश प्रदर्शन हमारे वेब अनुप्रयोग के पीछे के अंत का समर्थन करने के लिए python-rq
का उपयोग करने का प्रयास कर रहा है, लेकिन नई नौकरियों को धक्का देना बहुत लंबा लगता है - 12 सेकंड तक।पायथन आरक्यू
enqueue_call
फ़ंक्शन कॉल निष्पादित करते समय प्रदर्शन हिट होता है, खासकर जब सिस्टम से जुड़े कार्यकर्ता प्रक्रियाओं की संख्या बढ़ जाती है (200 से अधिक)।
प्रणाली इस प्रकार काम करता है:
- सामने के छोर काम कतार सर्वर से नौकरियों धक्का। कार्य को निष्पादित करने के वास्तविक तर्कों के अतिरिक्त, नौकरी के तर्कों (जैसे टाइमआउट और टीटीएल) में पास करने के लिए यह
enqueue_call
फ़ंक्शन का उपयोग करता है। - एकाधिक प्रक्रियाएं (कई मशीनों पर फैली हुई) श्रमिकों को चला रही हैं, प्रत्येक यूनिक्स
screen
के तहत। कतारों को सुनने के लिएWorker.work()
अनंत लूप फ़ंक्शन निष्पादित करते हुए, दस्तावेज़ प्रलेखन में प्रदान किए गए पैटर्न का पालन करते हैं। - प्रसंस्करण के दौरान, कुछ कार्य नए होते हैं, आमतौर पर उसी कतार पर जो वे चल रहे हैं।
बुनियादी ढांचे के बारे में:
- Redis सर्वर चलाता है कि इस कार्य के लिए कतार इसे करने के लिए समर्पित है। इसके अलावा, दृढ़ता अक्षम है। यह 4 जीबी रैकस्पेस सर्वर में चल रहा है।
- कार्य कतार के साथ सर्वर पर
redis-benchmark
चलाते समय, हमें अधिकतर मानक के लिए औसतन 20000 आर/एस परिणाम मिलते हैं।
हम इस तरह की स्थिति में नई नौकरियों के लिए पुश प्रदर्शन में सुधार कैसे कर सकते हैं? क्या कोई बेहतर पैटर्न है जिसका हमें उपयोग करना चाहिए?
तो (अजवाइन के लिए) प्रदर्शन में बहुत सुधार स्विचन था हो सकता है? मुझे एक ही समस्या का सामना करना पड़ रहा है। –
मैं वर्तमान में एक ही परियोजना पर काम नहीं कर रहा हूं। हालांकि, हमने बैक एंड के रूप में 'आरक्यू' का उपयोग करना जारी रखा, और अंततः बुनियादी ढांचे को साफ करने के दौरान प्रदर्शन समस्याओं को खत्म कर दिया गया। मैं आपके विशिष्ट उपयोग मामले के लिए 'सेलेरी' पर स्विचिंग या 'आरक्यू' के साथ शेष की सिफारिश नहीं कर सका; हालांकि, मैं * परीक्षणों का सुझाव देना चाहता हूं। यह उतना कठिन नहीं हो सकता जितना आप प्रारंभ में सोचेंगे, और मैं ** गारंटी देता हूं ** अच्छे परीक्षण बनाने के साथ व्यतीत किए गए किसी भी समय अंततः भुगतान करेगा, क्योंकि आप अपने सिस्टम की प्रकृति को बेहतर ढंग से समझते हैं। शुभकामनाएँ! –