मुझे परेशान है कि क्यों अन्य ऐप की तुलना में फ़ायरफ़ॉक्स में मेरी ऐप की मेमोरी इतनी तेज हो जाती है।भारी AJAX ऐप में फ़ायरफ़ॉक्स विशिष्ट मेमोरी बढ़ जाती है
मूल रूप से, ऐप एक अच्छी मात्रा में AJAX का उपयोग करता है, जिसमें बुनियादी कार्रवाई एचटीएमएल के औसत स्तर वाले पदों के नए सेट लोड करने के लिए होती है, और आम तौर पर बड़ी छवियां होती हैं। प्रति पोस्ट कुल भार डेटा (भारित छवियों सहित) 1 एमबी, शायद 900k के तहत है। JQuery 1.7.1 का उपयोग करना।
क्रोम मेमोरी में स्थिर लगता है, लेकिन फ़ायरफ़ॉक्स में, प्रत्येक पोस्ट लोड के परिणामस्वरूप लगभग 20 एमबी नई मेमोरी उपयोग होती है। चूंकि बहुत सी पोस्ट लोड हो जाती हैं, इसलिए आप जल्दी से 1 जीबी और यहां तक कि 1.4 जीबी मेमोरी में आते हैं, और चीजें जल्दी ही रुक जाती हैं।
फ़ायरफ़ॉक्स पर खोदने पर, मैंने 'हटाएं' का उपयोग करके बंद करने और किसी भी बाहरी चर को खत्म करने की कोशिश की। कोई बड़ा सुधार नहीं। मैंने फिर कार्यक्षमता को हटाने शुरू कर दिया, और ऐसा लगता है कि सब कुछ योगदान देता है।
टूलटिप्स को हटाने, एफबी विजेट्स (प्रति पोस्ट एक टिप्पणी विजेट) की अत्यधिक पुनः लोडिंग, मैंने प्रति पोस्ट 10 एमबी नई मेमोरी में एक बड़ा सुधार किया है।
लेकिन उससे परे, मैं बहुत कम नहीं हो सकता! असल में, अगर मैं $ .post() के माध्यम से नई एचटीएमएल + छवियों (फिर से लगभग 900k) लोड करता हूं तो प्रत्येक पोस्ट में नई मेमोरी के ~ 8 एमबी जोड़े जाते हैं, भले ही नई छवियों में "डिस्प्ले: कोई नहीं" हो। (फायरबग को अक्षम करने का भी प्रयास किया)।
यह स्मृति प्रबंधन में मेरा पहला प्रयास है, लेकिन यह बहुत अधिक ओवरहेड जैसा लगता है, और अजीब है क्योंकि मुझे नहीं लगता कि स्मृति वास्तव में क्रोम में इस तरह बढ़ती है। ऐसा लगता है कि मुझे लोड होने वाले डेटा की मात्रा के साथ मेमोरी बढ़ाना चाहिए, 10 एक्स नहीं! (या क्रोम में बिल्कुल भी कोई भी अच्छा नहीं होगा ...)
क्या यह वास्तव में उचित है? इस समस्या को कम करने के लिए समस्याओं के बारे में कोई विचार या मैं क्या कर सकता हूं?
धन्यवाद!
अद्यतन:
के रूप में बोरिस जिसे उपयुक्त मनाया, स्मृति वृद्धि लगभग पूरी तरह से छवियों (कम से कम 80%) की वजह से है। लेकिन फिर से लोड की गई छवियों का आकार बहुत अधिक (10x) है। एक और बात जो मैंने सीखा है: स्मृति - अगर मैं बस एक नया खाली टैब खोलता हूं, तो स्मृति जल्दी से गिर जाती है और लगभग सभी अतिरिक्त छवि संबंधित स्मृति गायब हो जाती है। मैं अनुमान लगा रहा हूं कि जीसी लात मार रहा है, और इस प्रकार बोरिस अनुमान लगाता है, ऐसा लगता है कि यह एक जीसी मुद्दा है?
यदि ऐसा है, तो मैं जांच कैसे कर सकता हूं कि यह केवल एफएफ में स्वाभाविक रूप से क्यों नहीं चल रहा है? जेएस में इसे ट्रिगर करने के तरीके हैं? जैसा कि मैंने उल्लेख किया है, मैंने बंद करने और बंद करने की कोशिश की ...
एक अन्य विचार, divs के बजाय छवि तत्वों (jQuery के माध्यम से) बाध्यकारी खराब हो सकता है? मैंने सोचा कि jQuery ने उन सभी चीजों के साथ निपटाया है।
क्या आप फ़ायरफ़ॉक्स में फ़ायरबग चला रहे हैं? यदि हां, तो क्या होगा यदि आप इसे अक्षम करते हैं? –
जैसा कि मैंने प्रश्न में उल्लेख किया है - मैंने फायरबग को अक्षम करने का प्रयास किया। कोई फर्क नहीं पड़ता। –
यह बहुत अजीब है। क्या आप समस्या दिखाने वाली साइट से लिंक कर सकते हैं? –