هل يتوافق Linux POSIX؟

Is Linux Posix Compliant



البرنامج مكتوب من قبل العديد من المطورين بخلفيات مختلفة. تتوفر الخوارزميات العامة بموجب ترخيص مجاني أو تم نشرها علميًا ، وقد تكون متاحة مجانًا أيضًا لأغراض الدراسة. ينتج عن هذا تطبيقات وإصدارات برامج مختلفة تناسب مجموعة متنوعة من الاحتياجات. يعد توحيد الواجهات وتنسيقات البيانات أمرًا ضروريًا لجعل هذه التطبيقات المختلفة قابلة للتبديل والوحدات.

باختصار ، POSIX [1] يفعل ذلك بالضبط بالنسبة لأنظمة UNIX و UNIX الشبيهة (راجع مقالة Zak H [4] للحصول على تاريخ أكثر تفصيلاً حول هذا الموضوع). وهي تحدد واجهات التبادل وآليات الاتصال والبيانات المنقولة للبرنامج ولكنها تترك التنفيذ الداخلي للمطور أو المشرف على البرنامج. الهدف هو توحيد جميع مفترقات UNIX المختلفة والأنظمة الشبيهة بـ UNIX بطريقة تجعل تطبيقات البرامج المختلفة تتفاعل مع بعضها البعض. الميزة الرئيسية لـ POSIX هي الحصول على وثائق ملزمة لهذه المكونات - واجهات وآليات وبيانات - متوفرة في شكل مكتوب.







يتم تصنيف نظام التشغيل الذي يتبع معيار POSIX في مجمله على أنه متوافق مع POSIX. في هذه المقالة ، نوضح ما يرمز إليه POSIX ، ونحدد ما إذا كان Linux ينتمي إلى هذه الفئة ، وسرد مكونات Linux التي يجب استبعادها من هذا التصنيف.



ماذا يعني مصطلح POSIX؟

POSIX هو اختصار لواجهة نظام التشغيل المحمولة. كما تم شرحه باختصار أعلاه ، POSIX هو اسم مجموعة من المعايير المطلوبة للحفاظ على التوافق بين أنظمة التشغيل. كما هو مذكور في [1] ، [هو] يحدد واجهة برمجة التطبيقات (API) ، جنبًا إلى جنب مع قذائف سطر الأوامر وواجهات الأداة المساعدة ، لتوافق البرامج مع متغيرات Unix وأنظمة التشغيل الأخرى. تم نشر الإصدار الأول من POSIX في عام 1988. ومنذ ذلك الحين ، تم توسيع وتحديث POSIX باستمرار من قبل مجموعة مراجعة المعايير المشتركة في أوستن (المعروفة أيضًا باسم مجموعة أوستن) [7].



اعتبارًا من عام 2021 ، يحتوي معيار POSIX على الأجزاء التالية:





  1. الخدمات الأساسية (يتضمن معيار ANSI C) (IEEE std 1003.1-1988) - إنشاء العمليات والتحكم فيها ، والإشارات ، وعمليات الملفات والدليل ، والأنابيب ، ومكتبة C ، وواجهة منفذ الإدخال / الإخراج والتحكم ، ومشغلات العملية
  1. ملحقات (روابط رمزية)
  2. في الوقت الحقيقي و I / O ملحقات (IEEE Std 1003.1b-1993) - جدولة الأولوية ، إشارات الوقت الفعلي ، الساعات والمؤقتات ، الإشارات ، تمرير الرسائل ، الذاكرة المشتركة ، الإدخال / الإخراج غير المتزامن والمتزامن ، واجهة قفل الذاكرة
  3. ملحقات المواضيع (IEEE Std 1003.1c-1995) - إنشاء الخيط والتحكم والتنظيف وجدولة الخيط ومزامنة الخيط ومعالجة الإشارة
  4. المزيد من ملحقات الوقت الحقيقي
  5. ملحقات الأمان (قوائم التحكم في الوصول)
  1. شل والمرافق (IEEE Std 1003.2-1992) - مترجم الأوامر ، برامج المساعدة

تتم مراجعة المعيار بانتظام ليعكس التغييرات والتحسينات التقنية. قد يستغرق الأمر في بعض الأحيان عدة سنوات قبل نشر إصدار جديد وإدماج التغييرات. قد يكون هذا غير مواتٍ ، لكنه مفهوم نظرًا لنطاق المعيار.

في السنوات الأخيرة ، تم إضافة ملحقات للمعالجة في الوقت الحقيقي. تم إطلاق الإصدار الحالي في أوائل عام 2018 [3]. قام مؤلفو SibylFS [5] أيضًا بنشر العديد من التعليقات التوضيحية على معيار POSIX لتحديد المنطق والتفاعلات ذات الترتيب الأعلى.



ماذا يعني التوافق مع POSIX؟

يعني المصطلح متوافق مع POSIX أن نظام التشغيل يفي بجميع معايير POSIX. يمكن لنظام التشغيل تشغيل برامج UNIX في الأصل ، أو يمكن نقل تطبيق من نظام UNIX إلى نظام آخر. يعد نقل تطبيق من UNIX إلى نظام التشغيل المستهدف أمرًا سهلاً ، أو على الأقل أسهل ، مما لو كان لا يدعم POSIX. لكي تكون في الجانب الآمن ، يجب أن يكون نظام التشغيل قد حقق بنجاح شهادة POSIX [2]. يتم تحقيق هذه الخطوة (بتكلفة) من خلال اجتياز اختبار الشهادة الآلي. يمكن العثور على مجموعة الاختبار المقابلة هنا [11].

اعتبارًا من عام 2021 ، تحتوي قائمة أنظمة التشغيل المعتمدة من POSIX على AIX من IBM و HP-UX من HP و IRIX من SGI و EulerOS [6] من Huawei و Mac OS X من Apple (منذ 10.5 Leopard) و Solaris و QNX Neutrino من Oracle و Inspur's K-UX [11] ونظام التشغيل في الوقت الفعلي INTEGRITY من Green Hills Software [15]. ليس من الواضح حاليًا ما إذا كانت الإصدارات الأحدث من خلفاء Solaris الثلاثة ، OpenSolaris و Illumos و OpenIndiana ، مصنفة على أنها متوافقة تمامًا مع POSIX أيضًا. كانت أنظمة التشغيل هذه متوافقة مع POSIX حتى POSIX 2001.

تشمل أنظمة التشغيل الأخرى المتوافقة مع POSIX في الغالب (ولكن ليس بشكل كامل) Android و BeOS و FreeBSD و Haiku و Linux (انظر أدناه) و VMWare ESXi. بالنسبة لنظام التشغيل Microsoft Windows ، يوفر Cygwin بيئة تطوير ووقت تشغيل متوافقة إلى حد كبير مع POSIX.

هل يتوافق Linux POSIX؟

يشير مصطلح Linux إلى نظام التشغيل Linux بأكمله ، بغض النظر عن النكهة ، مثل Debian GNU / Linux و RedHat Linux و Linux Mint و Ubuntu Linux و Fedora و CentOS ، على سبيل المثال. لكي أكون دقيقًا ، فإن Linux هو مجرد اسم النواة التي تعد المكون الأساسي لنظام التشغيل الحر هذا.

كما وصف لينوس تورفالدس في كتابه فقط للمتعة [8] ، لتطوير نواة لينكس ، طلب نسخة من معيار POSIX. وقد ساعده ذلك في تطبيق نفس الآليات المستخدمة في أنظمة UNIX التجارية. علاوة على ذلك ، سمح له ذلك بربط نواة لينكس بأدوات جنو التي اتبعت بشكل أساسي نفس النهج. لكي نكون منصفين ، يتم المساهمة بالبرنامج الموجود على نظام Linux من مجموعة متنوعة من المصادر التي تحترم معيار POSIX ، ولكنها أيضًا تنفذ أحيانًا مفاهيمها الخاصة. ومع ذلك ، في الوقت نفسه ، يُظهر هذا أيضًا التنوع الذي يتكون منه Linux كنظام تشغيل.

أحد الأمثلة على ذلك هو الطريقة التي تُكتب بها وسيطات سطر الأوامر. الوسائط ذات الشرطتين (على سبيل المثال ، –help) هي اصطلاحات GNU ، بينما أوامر POSIX لا تستخدم أبدًا وسيطات ثنائية الشرط ولكن بدلاً من ذلك تستخدم واحدة فقط (على سبيل المثال ، -help). منذ البداية ، تم تصميم Linux مع وضع GNU في الاعتبار ، ولهذا السبب تحتوي الأوامر على نمط GNU

الحجج. لتحقيق التوافق مع POSIX ، تمت إضافة وسيطات نمط POSIX خطوة بخطوة. ومع ذلك ، يتم اتخاذ القرار النهائي من قبل المطور. اعتبارًا من اليوم ، تقبل معظم الأوامر كلاً من الوسائط القصيرة والطويلة ، أو حتى الوسائط بدون أي شرطات ، مثل الأمر find ، على سبيل المثال. لكي نكون منصفين ، لا يوجد تناسق بين الأوامر على نظام واحد ، ويمكن أن يكون هذا مشكلة عندما تنوي استخدام نفس الأمر على نظام مختلف قائم على UNIX ، خاصة عند التبديل بين Linux و OS X و Solaris.

في الوقت الحالي ، Linux ليس معتمدًا من POSIX نظرًا لارتفاع التكاليف ، باستثناء توزيعتي Linux التجاريتين Inspur K-UX [12] و Huawei EulerOS [6]. بدلاً من ذلك ، يُنظر إلى Linux على أنه متوافق في الغالب مع POSIX.

يرجع هذا التقييم إلى حقيقة أن توزيعات Linux الرئيسية تتبع Linux Standard Base (LSB) بدلاً من POSIX [9]. يهدف LSB إلى تقليل الاختلافات بين توزيعات Linux الفردية [14]. يشير هذا إلى بنية نظام البرنامج ، بما في ذلك معيار التسلسل الهرمي لنظام الملفات (FHS) المستخدم في Linux kernel. يعتمد LSB على مواصفات POSIX ، ومواصفات UNIX الفردية (SUS) [10] ، والعديد من المعايير المفتوحة الأخرى ، ولكنه يمتد أيضًا في مناطق معينة.

تشمل توزيعات Linux المستندة إلى LSB RedHat Linux و Debian GNU / Linux (2002-2015) و Ubuntu (حتى 2015) ، على سبيل المثال لا الحصر.

التطوير مع وضع POSIX في الاعتبار

لفهم POSIX بمزيد من التفصيل ، نوصي بالحصول على نسخة من معيار POSIX وقراءته بالكامل. يمكنك الحصول على الكتاب من موقع Open Group. يتطلب هذا رسوم تسجيل ولكنه يمنحك وصولاً كاملاً إلى هذا المورد القيم. تساعد المعايير لأنها تسمح لك بتطوير البرامج بطريقة تتصرف بنفس الطريقة على جميع أنظمة UNIX.

الروابط والمراجع

اشكرك

يود المؤلف أن يشكر أكسل بيكيرت وفيت شييل على مساعدتهما ونصائحهما أثناء إعداد هذا المقال.