مفهوم CPU Load Average در سیستم عامل لینوکس چیست؟

2 دیدگاه
دسته بندی: آموزش, لینوکس
مفهوم بار cpu load در سیستم عامل لینوکس چیست و چه موقع باید نگران این موضوع بود؟

تسک بیشتر، سرعت پایین‌تر! این یک قانون نانوشته است. فرقی نمی‌کند صحبت از یک کارمند باشد یا قطعه‌ای الکترونیکی. مسلماً  هرچقدر وظایف بیشتر باشند، سرعت رسیدگی به آن‌ها و در نتیجه سرعت کل مجموعه کاهش پیدا می‌کند. تاثیر حجم وظایف بر سرعت عملکرد

CPU Load Average برای سرور لینوکس هم چنین مفهومی دارد. CPU پردازشگر مرکزی سرور است که وظیفه انجام فرایندهای محاسباتی را دارد. با محاسبه این پارامتر، می‌توان فهمید که سرعت کلی پردازش در سرور چگونه است.

اگر دوست داشته باشید می‌توانید مقاله CPU چیست را بخوانید.

در این مقاله می‌خواهیم ببینیم چطور می‌توان این پارامتر را به دست آورد و بهترین حالت چه چیزی است؟ قبل از هرچیز باید با System Load آشنا باشیم.

System Load چیست؟

منظور از System Load، فرایندهای محاسباتی‌ای هستند که داخل هسته کرنل سرور لینوکسی در حال انجام شدن هستند. (البته این اصطلاح فقط مربوط به لینوکس نیست و شامل تمام سیستم‌عامل‌های مبتنی بر یونیکس می‌شود.)

همان‌طور که می‌دانید، برخی از این پردازش‌ها سبک هستند و برخی دیگر فشار زیادی به دستگاه وارد می‌کنند؛ اما بنا به دلایلی، برای محاسبه میزان بار وارده بر سیستم، به میانگین این فرایندهای محاسباتی یا همان System Load نیاز داریم.

چرا میانگین مهم است؟
نوسانات زیادی در تعداد System Loadها وجود دارد. ممکن است سرور در یک ثانیه درگیری ده‌ها فرایند مختلف باشد و فقط چند ثانیه بعد کاملاً بیکار! به همین دلیل است که مقدار میانگین اهمیت بیشتری دارد.

اینجا به مفهوم Load Average یا بار میانگین می‌رسیم.

منظور از CPU Load Average چیست؟

به میانگین تمام System Loadهای یک سرور لینوکس در یک بازه زمانی مشخص، CPU Load Average می‌گویند.

همان‌طور که می‌دانید، CPU پردازشگر سیستم محسوب می‌شود و مسئولیت رسیدگی به فرایندهای پردازشی را دارد. به همین خاطر، Load Average هم مربوط به این قطعه است.

برای به دست آوردن Load Average یک سرور لینوکسی باید از دستور Uptime یا Top استفاده کرد. سپس پاسخی در قالب 3 عدد به شما نمایش داده خواهد شد:

Load average: 1.50, 0.7, 2.0

عدد اول میانگین را در بازه زمانی 1 دقیقه، عدد دوم میانگین را در بازه زمانی 5 دقیقه و عدد سوم میانگین را در بازه زمانی 15 دقیقه نشان می‌دهند.

به‌طور کلی،  هرچقدر اعداد کوچک‌تر باشند، سرور هم سریع‌تر است ؛ چراکه فرایندها هم سریع‌تر انجام می‌شوند.

میزان بار میانگین CPU

قبل از اینکه راجع به مقادیر این پارامتر صحبت کنیم، باید به یک سوال بسیار مهم پاسخ دهیم:

تعداد هسته‌ها اهمیت دارد یا تعداد CPU؟

هر هسته در CPU، توانایی رسیدگی به یک فرایند در آن واحد را دارد؛ پس اگر مجموع‌ هسته‌های موجود در سیستم عدد 8 باشد، سیستم می‌تواند به‌صورت هم‌زمان به 8 درخواست رسیدگی کند!

توجه کنید که حرفی از تعداد CPUها نزدیم؛ یعنی اگر دستگاه تنها یک CPU با 4 هسته داشته باشد، توانایی بیشتری نسبت به دستگاهی دیگر با دو CPU تک‌هسته‌ای دارد.

نکته: در مواقعی که با کمک تکنولوژی مجازی‌سازی یک هسته به دو یا چند هسته تقسیم می‌شود، هرکدام از آن‌ها می‌توانند مسئولیت یک تسک را به‌صورت جداگانه برعهده بگیرند.

بنابراین،  مجموع تعداد هسته‌های پردازشگر در یک سیستم، مهم‌تر از تعداد CPUها است. 

تعداد هسته های CPU مهمتر از تعداد خود CPUها است

اگر می‌خواهید از تعداد هسته‌های موجود در سرور مطلع شوید، از دستور زیر کمک بگیرید:

cat /proc/cpuinfo

همان‌طور که بالاتر هم گفتیم، پس از اجرای یکی از دو دستور لازم برای دریافت CPU Load Average، سه عدد به‌عنوان خروجی نمایش داده خواهند شد. 3 عددی که میانگین را در سه بازی زمانی یک، پنج و پانزده دقیقه نشان می‌دهند.

فرض می‌کنیم اعدادی که نمایش داده می‌شوند به شرح زیر هستند:

Load average: 0.09, 0.05, 0.01

حالا می‌خواهیم معنای این اعداد را در دو حالت مختلف بررسی کنیم. اولین حالت زمانی است که فقط یک پردازشگر تک‌هسته‌ای در سرور موجود باشد.

وقتی پردازشگر تک‌هسته‌ای باشد

اگر موافق باشید تشبیه کنیم. تک‌هسته‌ای که وظیفه رسیدگی به فرایندها را دارد، در نقش صندوق یک فروشگاه است. افرادی که با خریدهای‌شان به این صندوق مراجعه می‌کنند، همان فرایندهای مختلفی هستند که باید توسط پردازشگر به آن‌ها رسیدگی شود.

وقتی فقط یک صندوق وجود داشته باشد یا پردازشگر تک‌هسته‌ای باشد (مثل این مثال)، تمام فرایندها باید به آن مراجعه کنند.

در این حالت، عدد 1.00 به‌معنای استفاده از 100 درصد ظرفیت پردازشگر است؛ یعنی متصدی صندوق با نهایت توان در حال محاسبه خرید هر مشتری است. صف کوتاهی هم شکل گرفته است که هرچند کند، اما در حال جلو رفتن است!

اعداد کوچک‌تر از 1.00 این معنا را می‌رسانند که فقط بخشی از ظرفیت پردازشگر در حال استفاده است. مثلاً اگر عدد 0.5 را مشاهده می‌کنید، یعنی فقط 50 درصد از توان آن هسته درگیر است؛ به عبارت دیگر، صندو‌قدار نیمی از زمان کارش را در استراحت به سر می‌برد.

اما اعداد بزرگ‌تر از 1.00، نوعی خطر محسوب می‌شوند! یعنی تعداد فرایندها، بیشتر از توان رسیدگی هسته هستند و همین موضوع منجر به کندی سرور می‌شود. اگر بخواهیم به مثال صندوق فروشگاه رجوع کنیم، صندوقدار را در حال کار با تمام توان می‌بینیم و در عین حال صفی که منتظر رسیدن نوبت‌شان هستند. (همان فرایندهایی که در صف رسیدگی هستند).

حالا اگر یک پردازشگر 4 هسته‌ای داشته باشیم چه می‌شود؟

وقتی پردازشگر 4 هسته‌ای باشد

زمانی که پردازشگر 4 هسته داشته باشد، درست مثل این است که به‌جای 1 صندوق، 4 صندوق در حال رسیدگی به مشتریان باشند.

در چنین حالتی، عدد 4.00 استفاده از 100 درصد ظرفیت را نشان می‌دهد؛ یعنی چهار صندوقدار در حال خدمت‌رسانی هستند و صف کوتاهی از مشتریان هم وجود دارد؛ صندوقدارها (هسته‌ها) هم فرصت سر خاراندن ندارند و دائماً در حال کار هستند.

در این شرایط، اعداد کوچک‌تر از 4.00، سبک‌تر بودن کار هسته‌ها را نشان می‌دهند و اعداد بزرگ‌تر از آن، تحت فشار بودن آن‌ها و در نتیجه کندی سرور را!

نکته: با اینکه استفاده از ظرفیت 100 درصد هم در سرعت سرور تاثیر آنچنانی ندارد، اما بهتر است عدد خروجی، نشان‌دهنده درگیری ظرفیت کم‌تری باشد. به این ترتیب، اگر احیاناً موقعیت غیرمنتظره‌ای پیش بیاید، فضای جداگانه‌ای برای آن وجود خواهد داشت.

وقتی سی پی یو بیش از توانش درگیر باشد، سرور کند میشود

اما خب اهمیت هرکدام از این اعداد هم با یکدیگر متفاوت است.

کدامیک از اعداد CPU Load Average مهم‌تر هستند؟

عدد دوم و سوم! از آنجایی که این دو عدد میانگین بار سی‌پی‌یو در 5 دقیقه و 15 دقیقه گذشته را نشان می‌دهند، تصویر کلی‌تری از عملکرد سرور در اختیارتان می‌گذارند.

بگذارید این‌طور بگوییم:

گاهی ممکن است بسته به سنگینی یکی از فرایندها، عدد اول که میانگین دقیقه آخر را نشان می‌دهد از ظرفیت حداکثری بیشتر شود!

این اتفاق به این خاطر می‌افتد که ممکن است یکی از فرایندها به‌قدری بزرگ باشد که بخش زیادی از توان CPU را درگیر کند. سپس پس از رسیدگی به آن، باقی فرایندها اندازه معقولی داشته باشند و همه‌چیز طبق روال پیش رود.

اما اگر عدد دوم و سوم اعدادی بیش از ظرفیت را نشان می‌دهند، باید بلافاصله مشکل را پیدا و آن را برطرف کنید؛ چراکه احتمالاً تعداد و اندازه بسیاری از فرایندها بیشتر از توان محاسباتی سیستم است.

سخنان پایانی

رصدن کردن و مانیتورینگ دائم CPU Load Average برای سرورهای لینوکس یک ضرورت است. با این کار می‌توان هم مشکلات کنونی را شناسایی و هم وقوع مشکلات احتمالی را پیش‌بینی کرد.

همان‌طور که در مقاله هم گفتیم، هر هسته از پزدازشگرهای سرور فقط می‌تواند یک فرایند را در آن واحد پردازش کند. به همین خاطر، زیاد شدن تسک‌ها (مخصوصاً وقتی بیشتر از تعداد هسته‌ها باشند) منجر به کندی سرور خواهد شد.

برای تهیه این مقاله از سایت‌های Site24x7، TecMint و بلاگ AppSignal کمک گرفته‌ایم.

با فرستادن این مقاله برای دوستان‌تان، ما را در انتشار گسترده‌تر آن یاری کنید.

با تشکر از همراهی‌تان.

3.7/5 - (3 امتیاز)
مقالات مرتبط

مایلید هر دو هفته یک ایمیل مفید دریافت کنید؟

ما را در شبکه‌های اجتماعی دنبال کنید

همچنین شاید دوست داشته باشید!

نصب وردپرس روی پلسک

نصب وردپرس روی پلسک

0
  زمانی که صحبت از کنترل پنل‌های هاستینگ وب می‌شود، ابزار پلسک (Plesk) یکی از بهترین گزینه‌ها برای کسب‌وکارهای کوچک و بزرگ به حساب می‌آید.…
بلاک کردن آی پی در htaccess

آموزش بلاک کردن آی پی در فایل htaccess

0
بلاک کردن آی پی در فایل htaccess، درِ ورود سایتتان را روی مهمانان پردردسرِ ناخوانده‌ می‌بندد. اگر می‌خواهید کنترل ترافیک ورودی به سایتتان را به…

نظرات کاربران

2 دیدگاه. دیدگاه تازه ای بنویسید

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد.

این فیلد را پر کنید
این فیلد را پر کنید
لطفاً یک نشانی ایمیل معتبر بنویسید.
شما برای ادامه باید با شرایط موافقت کنید

فهرست