Desktop virtualization
Desktop virtualization
خواندن ۶ دقیقه·۲ سال پیش

پردازش موازی روشی برای تکمیل کارها به صورت همزمان

پردازش موازی
پردازش موازی

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

پردازش موازی چیست؟

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

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

پردازش موازی چگونه کار می‌کند؟

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

معماری‌های پردازش موازی

• چند هسته‌ای: مدار مجتمع (IC) دستگاه دارای دو یا چند هسته پردازش جداگانه است. که هر کدام می‌توانند دستور العمل‌های برنامه را به صورت موازی اجرا کنند. معماری‌های چند هسته‌ای می‌توانند همگن و دارای هسته‌های یکسان، یا ناهمگن و دارای هسته‌هایی باشند که یکسان نیستند.

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

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

• انبوه محاسبات موازی: تعداد زیادی از پردازنده‌های کامیپوتری به طور همزمان مجموعه‌ای از محاسبات را به صورت موازی اجرا می‌کنند.

• Loosely Coupled Multiprocessing: پردازنده‌های جداگانه با حافظه خود پیکربندی شده‌اند و می‌توانند برخی از دستور العمل‌های کاربر و سیستم عامل را به صورت مستقل از یکدیگر جدا کنند.

انواع پردازش موازی

در حال حاضر سه نوع پردازش موازی وجود دارد که بر اساس منبع داده‌ها و نوع پردازش آن دسته بندی می‌شوند.

پردازش داده‌های چندگانه (MIMD):

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

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

پردازش داده‌های تک دستورالعمل چندگانه (MISD):

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

پردازش داده‌های چندگانه تک دستورالعمل (SIMD):

چندین پردازنده با استفاده از دستورالعمل‌های یکسان، کار یکسانی را برای تایید نتایج انجام می‌دهند. کامپیوترهایی که از معماری Single Instruction، Multiple Data (SIMD) استفاده می‌کنند دارای چندین پردازنده هستند که دستورالعمل‌های یکسانی را انجام می‌دهند. با این حال، هر پردازنده دستورالعمل‌ها را با مجموعه منحصر به فرد خود از داده‌ها ارائه می‌کند.

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

فرق پردازش موازی و پردازش همزمان

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

کاربردهای فعلی و آتی پردازش موازی

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

نمایش تصویری پردازش موازی و مشخص کردن عملکرد آن

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

هدف اصلی پردازش موازی چیست؟

یک سیستم پردازش موازی می‌تواند داده‌ها را به صورت همزمان پردازش کند تا وظایف را با سرعت بیشتری انجام دهد. به عنوان مثال: سیستم می‌تواند دستور العمل بعدی را از حافظه دریافت کند، زیرا دستور العمل فعلی توسط  CPUپردازش می‌شود. هدف اصلی پردازش موازی، افزایش قدرت پردازش کامپیوتر و افزایش توان عملیاتی یا افزایش حجم کاری است که می‌توان در یک زمان معین انجام داد. می‌توان از بسیاری از واحدهای عملکردی برای ایجاد یک سیستم پردازش موازی با انجام فعالیت‌های مشابه یا غیر مشابه به طور همزمان استفاده کرد.

نتیجه گیری

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


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