इससे पहले कि हम लिनक्स लोड औसत में गोता लगाएँ, हमें लोड की गणना के विभिन्न तरीकों का पता लगाना चाहिए और सीपीयू लोड के सबसे सामान्य माप को संबोधित करना चाहिए - एक प्रतिशत।
विंडोज़, लिनक्स से अलग तरह से लोड की गणना करता है, और चूंकि विंडोज़ ऐतिहासिक रूप से डेस्कटॉप पर अधिक लोकप्रिय रही है, लोड की विंडोज़ परिभाषा को आमतौर पर अधिकांश कंप्यूटर उपयोगकर्ताओं द्वारा समझा जाता है। अधिकांश विंडोज उपयोगकर्ताओं ने 0% से 100% तक के प्रतिशत के रूप में प्रदर्शित कार्य प्रबंधक में सिस्टम लोड देखा है।
विंडोज़ में यह जांच कर लिया गया है कि कितना व्यस्त है सिस्टम निष्क्रिय प्रक्रिया है और सिस्टम लोड का प्रतिनिधित्व करने के लिए व्युत्क्रम का उपयोग कर रहा है। उदाहरण के लिए, यदि निष्क्रिय थ्रेड 99% समय निष्पादित कर रहा है, तो विंडोज़ में CPU लोड 1% होगा। यह मान समझने में आसान है लेकिन सिस्टम की वास्तविक स्थिति के बारे में कम समग्र विवरण प्रदान करता है।
लिनक्स में, लोड औसत को इसके बजाय 0.00 से शुरू होने वाली दशमलव संख्या द्वारा दर्शाया जाता है। मान को मोटे तौर पर पिछले मिनट में प्रक्रियाओं की संख्या के रूप में परिभाषित किया जा सकता है जिन्हें निष्पादन के लिए अपनी बारी का इंतजार करना पड़ा। विंडोज़ के विपरीत, लिनक्स लोड औसत तत्काल माप नहीं है। लोड तीन मानों में दिया जाता है - एक मिनट का औसत, पांच मिनट का औसत और पंद्रह मिनट का औसत।
लिनक्स में लोड औसत को समझना
सबसे पहले, विस्तार की यह अतिरिक्त परत अनावश्यक लगती है यदि आप केवल अपने सिस्टम में सीपीयू लोड की वर्तमान स्थिति जानना चाहते हैं। लेकिन चूंकि तीन समयावधियों का औसत दिया गया है, तत्काल माप के बजाय, आप तीन संख्याओं की एक नज़र में समय के साथ सिस्टम लोड के परिवर्तन का अधिक संपूर्ण विचार प्राप्त कर सकते हैं
लोड औसत प्रदर्शित करना सरल है। कमांड लाइन पर, आप विभिन्न प्रकार के कमांड का उपयोग कर सकते हैं। मैं बस w कमांड का उपयोग करता हूं:
जड़@कन्या[~]# में
इक्कीस: 08:43यूपी38दिन,4:3. 4,4 उपयोगकर्ताओं, औसत भार:3.11,2.75,2.70
शेष कमांड प्रदर्शित करेगा कि किसने लॉग ऑन किया है और वे क्या निष्पादित कर रहे हैं, लेकिन हमारे उद्देश्यों के लिए यह जानकारी अप्रासंगिक है इसलिए मैंने इसे उपरोक्त डिस्प्ले से क्लिप किया है।
एक आदर्श प्रणाली में, किसी भी प्रक्रिया को किसी अन्य प्रक्रिया (या थ्रेड) द्वारा नहीं रोका जाना चाहिए, लेकिन सिंगल प्रोसेसर सिस्टम में, यह तब होता है जब लोड 1.00 से ऊपर चला जाता है।
सिंगल प्रोसेसर सिस्टम शब्द यहां अविश्वसनीय रूप से महत्वपूर्ण हैं। जब तक आप एक प्राचीन कंप्यूटर नहीं चला रहे हैं, तब तक आपकी मशीन में कई CPU कोर हो सकते हैं। मैं जिस मशीन पर हूं, उसमें मेरे पास 16 कोर हैं:
जड़@कन्या[~]# एनप्रोक16
ऐसे में 3.11 का लोड एवरेज बिल्कुल भी चिंताजनक नहीं है। इसका सीधा सा मतलब है कि तीन से अधिक प्रक्रियाएं निष्पादित करने के लिए तैयार थीं और उनके निष्पादन को संभालने के लिए सीपीयू कोर मौजूद थे। इस विशेष प्रणाली पर, भार को १००% पर विचार करने के लिए १६ तक पहुंचना होगा।
इसे प्रतिशत-आधारित सिस्टम लोड में अनुवाद करने के लिए, आप इस सरल का उपयोग कर सकते हैं, यदि अधिक नहीं है, तो कमांड:
बिल्ली /प्रतिशत/लोडावग| कट गया -सी 1-4 | फेंक दिया 'पैमाना = 2; ($ (/`एनप्रोक`) * १०० ' | बीसी -NSयह कमांड अनुक्रम 1 मिनट के औसत को कट और इकोस के माध्यम से अलग करता है, जिसे सीपीयू कोर की संख्या से विभाजित किया जाता है, बीसी के माध्यम से, एक कमांड-लाइन कैलकुलेटर, प्रतिशत प्राप्त करने के लिए।
यह मान किसी भी तरह से वैज्ञानिक नहीं है, लेकिन प्रतिशत में CPU लोड का अनुमानित अनुमान प्रदान करता है।
सीखने के लिए एक मिनट, मास्टर के लिए एक लाइफटाइम
पिछले खंड में मैंने 16 सीपीयू कोर सिस्टम पर 16.0 के लोड का 100% उदाहरण कोट्स में रखा था क्योंकि लिनक्स में लोड की गणना विंडोज की तुलना में थोड़ी अधिक अस्पष्ट है। सिस्टम एडमिनिस्ट्रेटर को यह ध्यान रखना चाहिए कि:
- भार प्रतीक्षा प्रक्रियाओं और धागों में व्यक्त किया जाता है
- यह तात्कालिक मूल्य नहीं है, बल्कि औसत है, और
- इसकी व्याख्या में CPU कोर की संख्या शामिल होनी चाहिए, और
- I/O प्रतीक्षा को अधिक बढ़ा सकता है जैसे डिस्क पढ़ता है
इस वजह से, लिनक्स सिस्टम पर सीपीयू लोड को संभालना पूरी तरह से एक अनुभवजन्य मामला नहीं है। अगर ऐसा होता भी है, तो अकेले सीपीयू लोड समग्र सिस्टम संसाधन उपयोग का पर्याप्त माप नहीं है। जैसे, एक अनुभवी लिनक्स प्रशासक सीपीयू लोड को अन्य मूल्यों जैसे कि I/O प्रतीक्षा और कर्नेल बनाम सिस्टम समय के प्रतिशत के साथ संगीत में विचार करेगा।
मैं/ओ रुको
शीर्ष आदेश के माध्यम से I/O प्रतीक्षा सबसे आसानी से देखी जाती है:
ऊपर के स्क्रीनशॉट में मैंने I/O प्रतीक्षा मान को हाइलाइट किया है। यह उस समय का प्रतिशत है जब CPU इनपुट या आउटपुट कमांड के पूरा होने की प्रतीक्षा कर रहा था। यह आमतौर पर उच्च डिस्क गतिविधि का संकेत है। जबकि एक उच्च प्रतीक्षा प्रतिशत अकेले सीपीयू-बाध्य कार्यों को महत्वपूर्ण रूप से कम नहीं कर सकता है, यह अन्य कार्यों के लिए I/O प्रदर्शन को कम कर देगा और सिस्टम को सुस्त महसूस कराएगा।
बिना किसी स्पष्ट कारण के उच्च I/O प्रतीक्षा डिस्क के साथ समस्या का संकेत दे सकती है। यह देखने के लिए कि क्या कोई त्रुटि हुई है, dmesg कमांड का उपयोग करें।
कर्नेल बनाम सिस्टम समय
उपरोक्त हाइलाइट किए गए मान उपयोगकर्ता और कर्नेल (सिस्टम) समय का प्रतिनिधित्व करते हैं। यह उपयोगकर्ताओं (अर्थात अनुप्रयोगों, आदि) और कर्नेल (अर्थात सिस्टम उपकरणों के साथ बातचीत) द्वारा CPU समय की समग्र खपत का टूटना है। उच्च उपयोगकर्ता समय प्रोग्राम द्वारा अधिक CPU उपयोग को इंगित करेगा जहां उच्च कर्नेल समय अधिक सिस्टम-स्तरीय प्रसंस्करण को इंगित करेगा।
काफी औसत भार
वास्तविक सिस्टम प्रदर्शन के लिए लोड औसत के संबंध को सीखने में समय लगता है, लेकिन बहुत पहले आप एक अलग सहसंबंध देखेंगे। सिस्टम प्रदर्शन मेट्रिक्स की पेचीदगियों से लैस, आप हार्डवेयर अपग्रेड और प्रोग्राम संसाधन उपयोग के बारे में बेहतर निर्णय लेने में सक्षम होंगे।