رایانش ماشین بدون پوشش

از ویکی‌پدیا، دانشنامهٔ آزاد

رایانش ماشین بدون پوشش (به انگلیسی: Bare Machine Computing) یک معماری رایانه است که بر اساس ماشین های بدون پوشش می باشد. در الگوی BMC، برنامه‌ها بدون پشتیبانی هیچ سیستم عامل یا هسته متمرکزی اجرا می‌شوند، هیچ نرم‌افزار واسطه‌ای روی "ماشین بدون پوشش" قبل از برنامه های اجرا شونده بارگذاری نمی‌شود. این برنامه‌ها که "برنامه‌های ماشین بدون پوشش" یا به‌طور خلاصه برنامه‌های BMC نامیده می‌شوند، از هیچ انبارش ثابت یا دیسک سختی استفاده نمی‌کنند و در عوض در حافظه‌های بزرگ جداشونده مانند حافظه فلش ذخیره می‌شوند. یک برنامه BMC شامل یک برنامه واحد یا یک رشته کوچک از برنامه ها است که به عنوان یک اجراشونده واحد در یک فضای آدرس اجرا می شود. برنامه های BMC به منابع سخت افزاری حیاتی خود دسترسی مستقیم دارند. آنها نهادهایی خودکفا، خود مدیریت شونده و خودکنترلی هستند که بدون استفاده از اجزای نرم افزاری دیگری یا نرم افزار خارجی راه اندازی، بارگیری و اجرا می شوند. برنامه های BMC به دلیل طراحی خود دارای امنیت ذاتی هستند. هیچ آسیب‌پذیری مرتبط با سیستم‌عاملی وجود ندارد و هر برنامه فقط شامل عملکردهای ضروری (حداقلی) است. هیچ وضعیت ممتازی در سیستم BMC وجود ندارد زیرا برنامه ها فقط در وضعیت کاربر اجرا می شوند. همچنین، چون کد برنامه به صورت ایستا گردآوری (کامپایل) می شود - هیچ راهکاری برای تغییر پویای جریان برنامه ی BMC در طول اجرا وجود ندارد.

تاریخچه[ویرایش]

در روزهای ابتدایی رایانش، نرم افزار های رایانه ای به طور مستقیم با سخت افزار در ارتباط بودند و هیچ سیستم عاملی وجود نداشت.با بزرگتر شدن برنامه ها و دربرگرفتن دامنه های مختلف، سیستم های عامل اختراع شدند. آنها به عنوان یک میان برنامه که لایه ی انتزاعی سخت افزاری را در اختیار برنامه ها میگذارد عمل میکردند.سیستم های عامل در اندازه و پیچیدگی خود به میزان بسیار زیادی رشد کرده اند که باعث تلاش هایی برای کم کردن بار سیستم های عامل و بهبود عملکردشان شده است، که شامل میکروکرنل(به انگلیسی: Microkernel)، اگزوکرنل (به انگلیسی: Exokernel)، سیستم عامل تاینی (به انگلیسی: Tiny-OS) ، سیستم عامل کیت (به انگلیسی: OS-Kit[۱] پالاشیوز و کیتن (به انگلیسی: Palacios and Kitten[۲] آی او-لایت (به انگلیسی: IO_Lite) ، [۳]بیر-متال لینوکس (به انگلیسی: bare-metal Linux) ، آی بی ام-لیبرا (به انگلیسی: IBM-Libra) و دیگر کرنل های پشتیبان می شود.علاوه بر رویکرد های بالا، در سامانه های نهفته مانند موبایل های هوشمند، یک بخش کوچک و اختصاصی از سیستم عامل و یک رشته از برنامه ها به صورت خیلی نزدیکی با سخت افزار هم راستا شده اند.همچنین تعداد بی شماری کنترل های صنعتی و بازی های رایانه ای هستند که به طور مستقیم روی سخت افزار اجرا می شوند. در اکثر این سامانه ها، سخت افزار دسترسی ندارد تا برنامه های همه کاره را اجرا کند.

رایانش ماشین بی پوشش، از مفهوم شیئ برنامه ای (AO) که توسط کارنه در دانشگاه توسان ابداء شده بود نشات گرفته است.[۴]این برنامه با گذشت سالیان به سیستم عامل های پراکنده(DOSC) [۵]تکامل پیدا کرد و در نهایت به الگوی BMC تبدیل شد.

مقایسه با رایانش مرسوم[ویرایش]

الگوی BMC در مسائل محتلفی با رایانش مرسوم متفاوت است. هنگام اجرای برنامه های BMC هیچ هسته ی مرکزی و یا سیستم عاملی وجود ندارد. همچنین یک ماشین بدون پوشش در الگوی BMC هیچ مالکیتی ندارد و منابع با ارزش را ذخیره نمی کند و از آن می توان برای اجرای برنامه های رایانشی همه کاره استفاده کرد.

این ویژگی ها را نمی توان در رایانش معمول و مرسوم مانند سامانه های نهفته و سامانه روی تراشه (SOC) پیدا کرد. مفهوم BMC یک رویکرد حداقلی برای دستیابی به سادگی، اندازه ی کد های کوچکتر و امنیت می باشد.[۶]

در رایانش ماشین بی پوشش، دستگاه محاسبه گر بدون پوشش است و برنامه ی آن مستقیما با سخت افزار در ارتباط است. نرم افزار و برنامه های سامانه در حقیقت یکی هستند.یک وضعیت کاربر و یا وضعیت کرنل در این سامانه وجود ندارد. وقتی یک رشته برنامه در حال اجرا هستند هیچ چیز دیگری در حال اجرا نمی باشد. تمام برنامه ها با یک زبان برنامه نویسی C/C++ و با مقدار بسیار کمی کد نوشته می شوند.برنامه نویس نرم افزار تمامی منابع سخت افزاری را کنترل می کند.این روش بر اساس رویداد ها بنا شده است به همین جهت نیازی به هسته (کرنل) ندارد. یک رشته برنامه ی BMC بر اساس یک معماری مجموعه دستورالعمل داده شده (ISA) خیلی ساده می تواند برای همیشه اجرا شود، البته تا زمانی که دستورالعمل ها قابلیت رقابتی خود را با مرور زمان از دست نداده اند.این روش با رایانش سبز بسیار همخوانی دارد چرا که نیازی نیست تا سخت افزار و یا نرم افزار را به خاطر منسوخ شدن از پیش تعیین شده ی قراردادی، که امروزه در تمامی وجه های سیستم های اطلاعاتی ما وجود دارد، دور بیاندازیم.

موارد استفاده و پژوهش[ویرایش]

الگوی BMC برای ایجاد وب سرور ها،[۷] سرور های جدا از هم،[۸] [۹]صدا روی پروتکل اینترنت (VoIP)[۱۰]، سرور SIP [۱۱]، ایمیل،[۱۲] وبمیل، [۱۳]جستجوگر متنی ،[۱۴] پروتکل های امنیتی،[۱۵] [۱۶]سامانه های فایل بندی،[۱۷][۱۸][۱۹] آرایه چندگانه دیسک‌های مستقل (RAID)،[۲۰] اس کیو لایت تبدیل شده ی بی پوشش،[۲۱][۲۲] میان برنامه برای کارت های رابط شبکه (NICs) [۲۳]و ارتباط اترنت بر روی سرور های تحت وب BMC با استفاده از دو کارت رابط شبکه،[۲۴] استفاده شده است. موفقیت در تبدیل برنامه های مرسوم ویندوز یا لینوکس به طوریکه به عنوان برنامه های BMC اجرا شوند راه را برای استفاده های جدید الگوی BMC باز می کند. [۲۵]مشکلات طراحی در اجرای یک وب سرور بر روی رایانه بی پوشش با معماری 32 بیت چند هسته ای با استفاده از پروتکل هدایت انتقال (TCP) توضیح داده شده است.[۲۶]یک پروتکل مشتری/سرور برای ارتباط تحت وب بر روی قرارداد داده‌نگار کاربر (UDP) با استفاده از معماری 32 بیتی روی ماشین بی پوشش نمایش داده شده است.[۲۷]توسعه و اجرای نرم افزار های رایانه بدون استفاده از هیچ سیستم عامل یا کرنلی در معماری 64 بیتی چند هسته ای نشان داده شده است.[۲۸]

منابع[ویرایش]

  1. "The OS Kit Project". Salt Lake, Utah: School of Computing, University of Utah. June 2002.
  2. J. Lange et al, “Palacios and Kitten: New high performance operating systems for scalable virtualized and native supercomputing,” 24th IEEEInternational Paral-lel and Distributed Processing Symposium (IPDPS), 2010, pp. 1-12
  3. Pai, V. S.; Druschel, P.; Zwaenepoel, W. (February 2000). "IO-Lite: A Unified I/O Buffering and Caching System" (PDF). ACM Transactions on Computer Systems. 18 (1): 37–66. doi:10.1145/332799.332895. S2CID 5280787.
  4. Karne, R. K. (December 1995). "Object-Oriented Computer Architectures for New Generation of Applications, Computer Architecture News". 23 (5): 8–19. doi:10.1145/218328.218332. S2CID 880971. {{cite journal}}: Cite journal requires |journal= (help)
  5. Karne, R.K, Venkatasamy, K (Karthick Jaganathan), Ahmed, T. Dispersed Operating System Computing (DOSC), Onward Track, OOPSLA 2005, San Diego, CA, October 2005.
  6. Soumya, S.; Guerin, R.; Hosanagar, K. (September 2011). "Functionality-Rich vs. Minimalist Platforms: A Two-Sided Market Analysis". ACM Computer Communication Review. 41 (5): 36–43. doi:10.1145/2043165.2043171. S2CID 890141.
  7. He, L., Karne, R. K., Wijesinha, A.L., and Emdadi, A. Design and Performance of a Bare PC Web Server, International Journal of Computers and Their Applications (IJCA), June 2008.
  8. B. Rawal, R. K. Karne, and A. L. Wijesinha. Splitting HTTP Requests on Two Servers, The Third International Conference on Communication Systems and Networks: COMSNETS 2011, January 2011, Bangalore, India.
  9. B. Rawal, R. K. Karne, and A. L. Wijesinha. “Mini Web server clusters for HTTP request splitting,” IEEE International Conference on High-Performance Computing and Communications (HPCC), pp. 94-100.
  10. G. H. Khaksari, A. L. Wijesinha, R. K. Karne, L. He, and S. Girumala, “”A peer-to-peer bare PC VoIP application,” 4th IEEE Consumer Communications and Networking Conference (CCNC), 2007, pp. 803-807.
  11. A. Alexander, R. Yasinovskyy, A. Wijesinha, and R. Karne, "SIP Server Implementation and Performance on a Bare PC," International Journal in Advances on Telecommunications, vol. 4, no. 1 and 2, 2011.
  12. Ford,G.H., Karne, R.K., Wijesinha, A.L., and Appiah-Kubi, P. The Design and Implementation of a Bare PC Email Server,33rd Annual IEEE International Computer Software and Applications Conference (COMPSAC 2009), Seattle, Washington, July 2009, p480-485.
  13. P. Appiah-kubi, R. K. Karne, and A. L. Wijesinha. The Design and Performance of a Bare PC Webmail Server, The 12th IEEE International Conference on High-Performance Computing and Communications, AHPCC 2010, Sept 1-3, 2010, Melbourne, Australia, p521-526.
  14. S.Almautairi, R. K. Karne and A.L. Wijesinha, A Bare PC Text Based Browser, 2019 Workshop On Computing, Networking and Communications (CNC), Honolulu, Hawaii, February 2019
  15. N. Kazemi, A. L. Wijesinha, and R. Karne. Design and Implementation of IPsec on a Bare PC, 2nd International Conference on Computer Science and its Applications (CSA), 2009.
  16. A. Emdadi, R. K. Karne, and A. L. Wijesinha. Implementing the TLS Protocol on a Bare PC, ICCRD2010, The 2nd International Conference on Computer Research and Development, Kaula Lumpur, Malaysia, May 2010.
  17. W. V. Thompson, H. Alabsi, R. K. Karne, S. Linag, A.L. Wijesinha, R. Almajed, and H. Chang, A Mass Storage System for Bare PC Applications Using USBs, International Journal on Advances in Internet Technology, vol 9, no 3 and 4, year 2016. p63-74.
  18. W. Thompson, R. Karne, A. Wijesinha, H. Alabsi, and H. Chang, Implementing a USB File System for Bare PC Applications, ICIW 2016: The Eleventh International Conference on Internet and Web Applications and Services, p58-63.
  19. W. Thompson, R. Karne, A. Wijesinha, H. Alabsi, and H. Chang, Implementing a USB File System for Bare PC Applications, ICIW 2016: The Eleventh International Conference on Internet and Web Applications and Services, p58-63.
  20. H. Z. Alabsi, W. V. Thompson, R. K. Karne, A. L. Wijesinha, R. Almajed, F. Almansour, A Bare Machine RAID File System for USBs, SEDE 2017: 26th International Conference on Software Engineering and Data Engineering, pp 113-118.
  21. W. Thompson, R. K. Karne and A.L. Wijesinha, Interoperable SQLite for a Bare PC, 13th International Conference Beyond Database Architectures and Structures (BDAS'17), 2017, p177-188.
  22. U. Okafor, R. K. Karne, A. L. Wijesinha and B. Rawal Transforming SQLITE to Run on a Bare PC, In Proceedings of the 7th International Conference on Software Paradigm Trends, pages 311-314, Rome, Italy, July 2012.
  23. F. Almansour, R. K. Karne, A.L. Wijesinha, H. Alabsi and R. Almajed, Middleware for NICs in Bare PC Applications, 26th International Conference on Computer Communications and Networks (Poster Paper), ICCCN2017, Vancouver, Canada, 2017.
  24. F.Almansour, R K. Karne, A. L. Wijesinha, B. S. Rawal “Ethernet Bonding on a Bare PC Web Server with Dual NICs”, The 33rd ACM Symposium On Applied Computing SAC 2018, April 2018, Pau, France.
  25. Peter, A.; Karne, R.; Wijesinha, A.; Appiah-Kubi, P. (April 4–7, 2013). Transforming a Bare PC Application to Run on an ARM Device. IEEE SoutheastCon. Jacksonville, Florida.
  26. N. Soundararajan, R. Karne, A. Wijesinha, N. Ordouie, H. Chang, Design Issues in Running a Webserver on Bare PC Multi-Core Architecture, IEEE 44th Annual Computers, Software,and Applications Conference (COMPSAC), 2020
  27. N. Soundararajan, R. Karne, A. Wijesinha, N. Ordouie, B.S.Rawal, A Novel Client/Server Protocol for Web-based Communication over UDP on a Bare Machine, 18th IEEE Student Conference on Research and Development (SCOReD), 2020.
  28. N. Ordouie, N. Soundararajan, R. Karne, A. Wijesinha, Developing Computer Applications without any OS or Kernel in a Multi-core Architecture, IEEE ISNCC November 2021.