Crashlytics डैशबोर्ड में, ANR टैग के आधार पर अपने Android ऐप्लिकेशन को डीबग करने का तरीका

'ऐप्लिकेशन काम नहीं कर रहा है' (ANR) वाली गड़बड़ियां तब ट्रिगर होती हैं, जब ऐप्लिकेशन का यूज़र इंटरफ़ेस (यूआई) थ्रेड पांच सेकंड से ज़्यादा समय तक काम नहीं कर रहा हो. Android दस्तावेज़ में, एएनआर और एएनआर का पता लगाने के बारे में ज़्यादा पढ़ा जा सकता है.

इसके अलावा, Crashlytics की मदद से, समस्या वाली खास थ्रेड की पहचान की जा सकती है. हम ANR का विश्लेषण करते हैं. इसके बाद, Crashlytics डैशबोर्ड में, हम लागू होने वाली थ्रेड को टैग करते हैं, ताकि ANR को डीबग करने का तरीका बताया जा सके.

इस पेज पर दिए गए सेक्शन में बताया गया है कि हर एएनआर टैग का क्या मतलब है. साथ ही, उस टैग के साथ एएनआर का एक उदाहरण दिखाया गया है. इसके अलावा, एएनआर को डीबग करने का सुझाया गया समाधान भी दिया गया है.

Triggered ANR

जिस थ्रेड को बहुत लंबे समय तक ब्लॉक किया गया था और जिसकी वजह से ANR ट्रिगर हुआ था उसे इस Triggered ANR टैग के साथ एनोटेट किया गया है.

समस्या वाली थ्रेड, ऐप्लिकेशन की मुख्य थ्रेड हो सकती है या ऐसी कोई भी थ्रेड हो सकती है जो काम नहीं कर रही है. हालांकि, Triggered ANR के तौर पर टैग की गई थ्रेड, एएनआर की असल वजह हो सकती है या नहीं भी. इन एएनआर को डीबग करने और ठीक करने के बारे में अहम जानकारी देने के लिए, Crashlytics उन सभी थ्रेड को भी टैग करता है जो एएनआर में शामिल हैं. इस पेज के नीचे दिए गए सेक्शन में, उन अन्य टैग के बारे में जानें जिन्हें किसी थ्रेड पर लागू किया जा सकता है.

Deadlocked

जिन थ्रेड में डेडलॉक की वजह से एएनआर हुआ है उन्हें इस Deadlocked टैग के साथ एनोटेट किया जाता है.

डेडलॉक तब होता है, जब कोई थ्रेड इंतज़ार की स्थिति में चला जाता है. ऐसा इसलिए होता है, क्योंकि ज़रूरी संसाधन को किसी दूसरी थ्रेड ने अपने पास रखा है. यह थ्रेड भी पहले थ्रेड के पास मौजूद संसाधन की प्रतीक्षा कर रही होती है. अगर ऐप्लिकेशन की मुख्य थ्रेड इस स्थिति में है, तो ANR की गड़बड़ियां दिख सकती हैं.

सुझाव

डेडलॉक में शामिल थ्रेड देखें और उन थ्रेड से हासिल किए गए रिसॉर्स/लॉक की जांच करें. संभावित समाधानों के लिए, डेडलॉक और डेडलॉक को रोकने वाले एल्गोरिदम देखें.

IO Root blocking

धीमी I/O कार्रवाइयां करने वाले और Triggered ANR थ्रेड को ब्लॉक करने वाले किसी भी थ्रेड को IO Root blocking टैग से एनोटेट किया जाता है. अगर Triggered ANR थ्रेड को अन्य थ्रेड ने ब्लॉक नहीं किया है, तो IO Root blocking थ्रेड भी Root blocking थ्रेड है.

सुझाव

आम तौर पर, आपके ऐप्लिकेशन को मुख्य थ्रेड पर ज़्यादा समय लेने वाले I/O ऑपरेशन नहीं करने चाहिए. अगर मुख्य थ्रेड IO Root blocking है, तो मुख्य थ्रेड पर अनजाने में होने वाले किसी भी I/O ऑपरेशन की पहचान करने के लिए, स्ट्रिक्ट मोड का भी इस्तेमाल किया जा सकता है.

Root blocking

जिस थ्रेड ने Triggered ANR के तौर पर टैग की गई थ्रेड को ब्लॉक किया है उस पर Root blocking टैग जोड़ दिया जाता है. अगर किसी थ्रेड को Root blocking और Triggered ANR, दोनों के तौर पर टैग किया गया है, तो इसका मतलब है कि उस थ्रेड को ब्लॉक करने वाली कोई और थ्रेड नहीं है.

अगर कोई Triggered ANR थ्रेड, दूसरी थ्रेड के पूरी तरह से प्रोसेस होने का इंतज़ार कर रही थी, तो वे Root blocking हैं. किसी थ्रेड की वजह से ANR होने की कई वजहें हो सकती हैं.

सुझाव

मुख्य थ्रेड में सीपीयू पर ज़्यादा काम करने वाले टास्क कम से कम करें. सीपीयू पर ज़्यादा लोड डालने वाले टास्क करने के लिए, वर्कर्स या बैकग्राउंड थ्रेड का इस्तेमाल करें.

मुख्य थ्रेड पर, डेटाबेस से लोड करने जैसे ज़्यादा I/O वाले काम को कम से कम करें.

Unknown root cause

किसी थ्रेड को Unknown root cause टैग के साथ तब टैग किया जाता है, जब वह थ्रेड ANR को ट्रिगर करता है, लेकिन ANR होने के दौरान वह प्रोसेस में शामिल नहीं होता. Crashlytics में इस समस्या की मुख्य वजह का पता लगाने के लिए ज़रूरी जानकारी मौजूद नहीं है. इस ANR की कोई साफ़ वजह नहीं है.

सुझाव

ANR से बचने के लिए, सामान्य सलाह अपनाएं. उदाहरण के लिए, अपने कोड में उन जगहों की पहचान करें जहां ऐप्लिकेशन का मुख्य थ्रेड पांच सेकंड से ज़्यादा समय तक व्यस्त हो सकता है.