الرئيسيةعريقبحث

كوبيرنيتيس


☰ جدول المحتويات


كوبيرنيتيس (عادة تكتب k8s [2] ) عبارة عن نظام تزامن حاوية مفتوح المصدر لأتمتة نشر التطبيقات، وتوسيع نطاقه وإدارته.[3] تم تصميمه في الأصل بواسطة جوجل، وتقوم الآن بإدارته مؤسسة Cloud Native Computing Foundation. يهدف إلى توفير "نظام أساسي لأتمتة نشر حاويات التطبيقات وتوسيع نطاقها وتشغيلها عبر مجموعات المضيفين". [2] يعمل مع مجموعة من أدوات الحاوية، بما في ذلك Docker.[4] العديد من الخدمات السحابية توفر منصة خدمية مبنية على كوبيرنيتيس أو بنية تحتية كخدمة والتي تمكن من نشر كوبيرنيتيس كمنصة توفير خدمة. كما يوفر العديد من البائعين أيضًا توزيعات كوبيرنيتيس الخاصة بهم.

كوبيرنيتيس
Kubernetes
Kubernetes logo.svg
الشعار
معلومات عامة
نوع
Linux Foundation Project 
نظام التشغيل
موقع الويب
جوجل Container Engine يتحدث في جوجل Cloud Summit

تأسست كوبيرنيتيس ( κυβερνήτης ، اليونانية لـ "حاكم" ، " helmsman " أو "كابتن") [2] على يد جو بيدا وبريندان بيرنز وكريج ماكلوكي، [5] الذين انضموا بسرعة إلى المهندسين الآخرين في جوجل بما في ذلك بريان غرانت وتيم هوكين، وأعلن لأول مرة من قبل جوجل في منتصف عام 2014. [6] يتأثر تطويره وتصميمه بشدة بنظام Borg من جوجل، [7] [8] والعديد من كبار المساهمين في المشروع الذين سبق لهم العمل في Borg. كان الاسم الأصلي لـ كوبيرنيتيس في جوجل هو Project Seven ، في إشارة إلى شخصية Star Trek Seven of Nine التي تعد Borg "صديقة". [9] المتحدثون السبعة على عجلة شعار كوبيرنيتيس هم إشارة إلى هذا الاسم الرمزي. تمت كتابة مشروع Borg الأصلي بالكامل في C ++ [7] ، لكن نظام كوبيرنيتيس المعاد كتابته تم تطبيقه في Go .

تم إصدار كوبيرنيتيس v1.0 في 21 يوليو 2015. [10] إلى جانب إصدار كوبيرنيتيس v1.0 ، دخلت جوجل في شراكة مع Linux Foundation لتشكيل Cloud Native Computing Foundation (CNCF) [11] وعرضت كوبيرنيتيس كتقنية أساسية. في 6 مارس، 2018 ، وصل كوبيرنيتيس Project إلى المركز التاسع في الدعاوى في جيثب، والمركز الثاني في المؤلفين وقضايا نواة لينكس . [12]

كائنات كوبيرنيتيس

يعرّف كوبيرنيتيس مجموعة من الكتل البرمجية الإنشائية ("البدائية") ، والتي توفر مجتمعة الآليات التي تنشر وتحافظ على نطاق التطبيقات على أساس وحدة المعالجة المركزية والذاكرة [13] أو المقاييس المخصصة. [14] كوبيرنيتيس مقترن بشكل فضفاض وقابل للامتداد لتلبية أعباء العمل المختلفة. يتم توفير هذه القابلية للتوسعة في جزء كبير منها بواسطة كوبيرنيتيس API ، والذي يستخدم من قبل المكونات الداخلية وكذلك الامتدادات والحاويات التي تعمل على كوبيرنيتيس. [15] . يمارس النظام الأساسي سيطرته على موارد الحوسبة والتخزين عن طريق تحديد الموارد على أنها كائنات، والتي يمكن إدارتها على هذا النحو. الكائنات الرئيسية هي:

القرون

وحدة الجدولة الأساسية في كوبيرنيتيس هي جراب . [16] ويضيف مستوى أعلى من التجريد من خلال تجميع المكونات في حاويات. يتكون الجراب من حاوية واحدة أو أكثر مضمونة أن تكون موجودة في الجهاز المضيف ويمكنها مشاركة الموارد. [15]

يتم تعيين عنوان Pod Pod فريد لكل كتلة في كوبيرنيتيس داخل المجموعة، مما يسمح للتطبيقات باستخدام المنافذ دون التعرض لخطر التعارض. [17] داخل الحاوية، يمكن لجميع الحاويات أن تشير إلى بعضها البعض على المضيف المحلي، ولكن الحاوية داخل الحافظة لا تملك أي وسيلة للتعامل مباشرة مع حاوية أخرى داخل حافظة أخرى ؛ لذلك، يجب عليه استخدام عنوان IP Pod. يجب على مطور التطبيق ألا يستخدم عنوان بروتوكول الإنترنت (Pod IP) أبدًا للإشارة إلى / استدعاء قدرة في جراب آخر، لأن عناوين بروتوكول الإنترنت (بروتوكول الإنترنت) هي سريعة الزوال - قد يتم تعيين جراب معين يشيرون إليه إلى عنوان IP آخر لجهاز iPod عند إعادة التشغيل. بدلاً من ذلك، يجب عليهم استخدام إشارة إلى الخدمة، التي تحتوي على إشارة إلى جراب الهدف على عنوان IP Pod.

يمكن للقرنة تحديد وحدة تخزين، مثل دليل القرص المحلي أو قرص الشبكة، وتعريضها للحاويات الموجودة في الجراب. [18] يمكن إدارة السنفات يدويًا من خلال كوبيرنيتيس API ، أو يمكن تفويض إدارتها إلى وحدة تحكم. [15] تعد هذه المجلدات أيضًا أساسًا لميزات كوبيرنيتيس الخاصة بـ ConfigMaps (لتوفير الوصول إلى التكوين من خلال نظام الملفات المرئي للحاوية) والأسرار (لتوفير الوصول إلى بيانات الاعتماد اللازمة للوصول إلى الموارد البعيدة بشكل آمن، من خلال توفير بيانات الاعتماد هذه على نظام الملفات المرئي فقط إلى الحاويات المصرح بها).

خدمات

Simplified view showing how Services interact with Pod networking in a كوبيرنيتيس cluster

خدمة كوبيرنيتيس هي مجموعة من القرون التي تعمل معًا، مثل طبقة واحدة من تطبيق متعدد المستويات . يتم تحديد مجموعة القرون التي تشكل خدمة بواسطة محدد التسمية. [15] يوفر كوبيرنيتيس وضعين لاكتشاف الخدمة، باستخدام المتغيرات البيئية أو استخدام كوبيرنيتيس DNS. [19] يعرّف اكتشاف الخدمة عنوان IP ثابتًا واسم DNS للخدمة، ويقوم بتحميل أرصدة الحركة بطريقة متقاربة إلى اتصالات الشبكة لعنوان IP هذا بين القرون التي تتطابق مع المحدد (حتى عندما تتسبب الأعطال في انتقال القرون من آلة إلى أخرى ). [17] بشكل افتراضي، يتم الكشف عن الخدمة داخل مجموعة (على سبيل المثال، قد يتم تجميع قرون النهاية الخلفية في خدمة، مع وجود طلبات من قرون الواجهة الأمامية متوازنة من بينها) ، ولكن يمكن أيضًا كشف خدمة خارج كتلة (مثل للعملاء للوصول إلى القرون الواجهة الأمامية). [20]

أحجام

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

مساحات

يوفر كوبيرنيتيس تقسيم الموارد التي يديرها إلى مجموعات غير متداخلة تسمى مساحات الأسماء. وهي مخصصة للاستخدام في البيئات التي ينتشر فيها العديد من المستخدمين عبر فرق أو مشاريع متعددة أو حتى تفصل بين البيئات مثل التطوير والاختبار والإنتاج.

إدارة كائنات كوبيرنيتيس

يوفر كوبيرنيتيس بعض الآليات التي تسمح للمرء بإدارة كائناته أو تحديدها أو معالجتها.

التسميات والمحددات

يُمكّن كوبيرنيتيس العملاء (المستخدمين أو المكونات الداخلية) من إرفاق أزواج قيمة المفتاح تسمى "ملصقات" إلى أي كائن API في النظام، مثل القرون والعقد . في المقابل، "محددات التسمية" عبارة عن استعلامات مقابل التصنيفات التي تعمل على حل الكائنات المتطابقة. [15] عندما يتم تعريف الخدمة، يمكن للمرء تحديد محددات الملصقات التي سيتم استخدامها من قبل جهاز توجيه / موازن التحميل لتحديد حالات pod التي سيتم توجيه حركة المرور إليها. وبالتالي، يمكن ببساطة تغيير بطاقات العنونة أو تغيير محددات الملصقات الموجودة على الخدمة للتحكم في أي من الرموز تحصل على حركة المرور وأيها لا يمكن استخدامها والتي يمكن استخدامها لدعم أنماط النشر المختلفة مثل عمليات النشر ذات اللون الأزرق والأخضر أو اختبار AB . توفر هذه القدرة على التحكم الديناميكي في كيفية استخدام الخدمات لموارد التنفيذ اقترانًا فضفاضًا داخل البنية التحتية.

على سبيل المثال، إذا كانت القرون الخاصة بالتطبيق تحتوي على تسميات tier نظام (مع قيم مثل front-end back-end ، على سبيل المثال) و release_track (مع قيم مثل canary production على سبيل المثال) ، ثم عملية على الكل يمكن للعقد back-end canary استخدام محدد التسمية، مثل: [21]

tier=back-end AND release_track=canary

محددات المجال

تمامًا مثل التسميات، يتيح لك محددات الحقل أيضًا تحديد موارد كوبيرنيتيس. بخلاف التصنيفات، يعتمد التحديد على قيم السمة الملازمة للمورد الذي يتم تحديده، بدلاً من التصنيف الذي يحدده المستخدم. metadata.name و metadata.namespace هما محددات الحقول التي ستكون موجودة على جميع كائنات كوبيرنيتيس. تعتمد المحددات الأخرى التي يمكن استخدامها على نوع الكائن / المورد.

هندسة

كوبيرنيتيس architecture diagram

يتبع كوبيرنيتيس البنية الأساسية / النسخة المتماثلة . يمكن تقسيم مكونات كوبيرنيتيس إلى تلك التي تدير عقدة فردية وتلك التي تعد جزءًا من مستوى التحكم. [15] [22]

طائرة التحكم كوبيرنيتيس (الابتدائي)

كوبيرنيتيس الأساسي هو وحدة التحكم الرئيسية في المجموعة، وإدارة عبء العمل وتوجيه الاتصالات عبر النظام. تتكون طائرة التحكم كوبيرنيتيس من مكونات مختلفة، كل عملية خاصة بها، يمكن تشغيلها على عقدة رئيسية واحدة أو على عدة انتخابات تمهيدية تدعم مجموعات توفر عالية . [22] المكونات المختلفة لطائرة التحكم كوبيرنيتيس هي كما يلي:

  • etcd: etcd [23] عبارة عن مخزن بيانات مستمر وخفيف الوزن وموزع وذات قيمة كبيرة تم تطويره بواسطة CoreOS ويقوم بتخزين بيانات التكوين الخاصة بالكتلة بشكل موثوق، وهو ما يمثل الحالة الكلية للمجموعة في أي نقطة زمنية محددة. تمامًا مثل Apache ZooKeeper ، etcd هو نظام يدعم الاتساق على التوفر في حالة وجود قسم للشبكة (انظر نظرية CAP ). هذا الاتساق أمر بالغ الأهمية لجدولة وخدمات التشغيل بشكل صحيح. يستخدم كوبيرنيتيس API Server واجهة برمجة التطبيقات الخاصة بمراقبة etcd لمراقبة الكتلة وطرح تغييرات التكوين المهمة أو ببساطة استعادة أي اختلافات في حالة الكتلة، والعودة إلى ما تم إعلانه من قبل الناشر. على سبيل المثال، إذا حدد الناشر أن هناك ثلاث حالات لقرنة معينة يجب تشغيلها، يتم تخزين هذه الحقيقة في etcd. إذا تبين أن حالتين فقط قيد التشغيل، سيتم الكشف عن هذه الدلتا مقارنة ببيانات الخ، وسوف تستخدم كوبيرنيتيس هذا لجدولة إنشاء مثيل إضافي من هذا الملف. [22]
  • خادم API: يعد خادم API مكونًا رئيسيًا ويخدم واجهة برمجة تطبيقات كوبيرنيتيس باستخدام JSON عبر HTTP ، والذي يوفر كلاً من الواجهة الداخلية والخارجية لـ كوبيرنيتيس. [15] [24] يقوم خادم API بمعالجة والتحقق من طلبات REST وتحديث حالة كائنات API في etcd ، وبالتالي السماح للعملاء بتكوين عبء العمل والحاويات عبر عقد Worker. [25]
  • المجدول: المجدول هو المكون القابل للتوصيل والذي يحدد العقدة التي يتم تشغيل جراب غير مجدولة (الكيان الأساسي الذي يديره المجدول) ، بناءً على توفر الموارد. يتعقب المجدول استخدام الموارد على كل عقدة لضمان عدم جدولة عبء العمل عن الموارد المتاحة. لهذا الغرض، يجب أن يعرف المجدول متطلبات الموارد، وتوافر الموارد، وغيرها من القيود التي يوفرها المستخدم وتوجيهات السياسة مثل جودة الخدمة، ومتطلبات التقارب / مكافحة التقارب، ومكان البيانات، وما إلى ذلك. في جوهرها، يتمثل دور المجدول في مطابقة "عرض" المورد مع عبء العمل "الطلب". [26]
  • مدير وحدة التحكم: وحدة التحكم عبارة عن حلقة مصالحة تدفع حالة الكتلة الفعلية نحو حالة الكتلة المطلوبة. [27] يفعل هذا عن طريق إدارة مجموعة من وحدات التحكم. نوع واحد من وحدة تحكم هو وحدة تحكم النسخ المتماثل، الذي يعالج النسخ المتماثل والتحجيم عن طريق تشغيل عدد محدد من نسخ جراب عبر الكتلة. يتعامل أيضًا مع إنشاء قرون بديلة في حالة فشل العقدة الأساسية. [27] تشتمل وحدات التحكم الأخرى التي تشكل جزءًا من نظام كوبيرنيتيس الأساسي على "DaemonSet Controller" لتشغيل جراب واحد تمامًا على كل جهاز (أو بعض مجموعات فرعية من الأجهزة) ، و "Controller Job" لتشغيل الأكواد التي تعمل حتى الاكتمال، على سبيل المثال وظيفة دفعة. [28] يتم تحديد مجموعة القرون التي تديرها وحدة التحكم بواسطة محددات الملصقات التي تعد جزءًا من تعريف وحدة التحكم. [21]
إدارة وحدة التحكم هي عملية تدير وحدات تحكم كوبيرنيتيس الأساسية مثل DaemonSet Controller و Replication Controller. تتصل وحدات التحكم بخادم واجهة برمجة التطبيقات لإنشاء وتحديث وحذف الموارد التي تديرها (السنفات ونقاط نهاية الخدمة، إلخ) ). [24]

عقدة كوبيرنيتيس

تعد Node ، المعروفة أيضًا باسم Worker أو Minion ، عبارة عن آلة يتم نشر حاويات بها (أعباء العمل). كل عقدة في الكتلة يجب تشغيل حاوية وقت التشغيل مثل عامل الميناء ، فضلا عن المكونات المذكورة أدناه، للتواصل مع الابتدائي لتكوين شبكة من هذه الحاويات.

  • Kubelet: Kubelet مسؤول عن حالة التشغيل لكل عقدة، مما يضمن أن جميع الحاويات الموجودة على العقدة صحية. إنه يعتني ببدء ووقف وصيانة حاويات التطبيقات المنظمة في حاضن حسب توجيهات طائرة التحكم. [15] [29]
يراقب Kubelet حالة جراب، وإذا لم يكن في الحالة المرغوبة، فإن الجراب يعاد نشره على نفس العقدة. يتم ترحيل حالة العقدة كل بضع ثوان عبر رسائل نبضات إلى الأساسي. بمجرد أن يكتشف الجهاز الأساسي فشل العقد، يلاحظ وحدة التحكم في النسخ المتماثل هذا التغيير في الحالة وتطلق القرون على عقد صحية أخرى.  
  • Kube-proxy: Kube-proxy هو تطبيق لبروكسي الشبكة وموازن التحميل، وهو يدعم تجريد الخدمة إلى جانب تشغيل الشبكات الأخرى. [15] وهي مسؤولة عن توجيه حركة المرور إلى الحاوية المناسبة بناءً على عنوان IP ورقم المنفذ للطلب الوارد.
  • وقت تشغيل الحاوية: توجد حاوية داخل حاوية. الحاوية هي أدنى مستوى من الخدمة المصغرة التي تحتوي على التطبيق قيد التشغيل والمكتبات وتوابعها. يمكن أن تتعرض الحاويات للعالم من خلال عنوان IP خارجي. تدعم كوبيرنيتيس حاويات Docker منذ إصدارها الأول، وفي يوليو 2016 تمت إضافة محرك حاويات rkt . [30]

إضافات

تعمل الوظائف الإضافية تمامًا مثل أي تطبيق آخر يتم تشغيله داخل المجموعة: يتم تنفيذها من خلال أجهزة الكمبيوتر والخدمات، وهي تختلف فقط من حيث أنها تقوم بتنفيذ ميزات مجموعة كوبيرنيتيس. قد تتم إدارة القرون بواسطة عمليات النشر و ReplicationControllers وما إلى ذلك. هناك العديد من الوظائف الإضافية، والقائمة تنمو. بعض من أهم:

  • DNS: يجب أن يكون لدى كافة مجموعات كوبيرنيتيس DNS الكتلة؛ إنها ميزة إلزامية. Cluster DNS هو خادم DNS ، بالإضافة إلى خادم (خوادم) DNS الأخرى في بيئتك، والذي يقدم سجلات DNS لخدمات كوبيرنيتيس. تتضمن الحاويات التي بدأتها كوبيرنيتيس خادم DNS هذا تلقائيًا في عمليات البحث عن DNS الخاصة بهم.
  • واجهة المستخدم على الويب: هذا هو الغرض العام، واجهة المستخدم على شبكة الإنترنت لمجموعات كوبيرنيتيس. يسمح للمستخدمين بإدارة واستكشاف الأخطاء وإصلاحها التطبيقات التي تعمل في الكتلة، وكذلك الكتلة نفسها.
  • مراقبة موارد الحاوية: توفير وقت تشغيل موثوق للتطبيق، والقدرة على زيادته أو خفضه استجابة لأحمال العمل، يعني القدرة على مراقبة أداء عبء العمل بشكل مستمر وفعال. توفر مراقبة موارد الحاوية هذه الإمكانية من خلال تسجيل مقاييس حول الحاويات في قاعدة بيانات مركزية، وتوفر واجهة مستخدم لتصفح تلك البيانات. يعد cAdvisor مكونًا على عقدة الرقيق يوفر إمكانية محدودة لرصد القياس المتري. هناك خطوط أنابيب كاملة للقياسات، مثل بروميثيوس، يمكنها تلبية معظم احتياجات المراقبة.
  • التسجيل على مستوى الكتلة: يجب أن يكون للسجلات تخزين منفصل ودورة حياة مستقلة عن العقد أو القرون أو الحاويات. خلاف ذلك، يمكن أن يسبب فشل العقدة أو جراب فقدان بيانات الحدث. تسمى القدرة على القيام بذلك التسجيل على مستوى الكتلة، وهذه الآليات مسؤولة عن حفظ سجلات الحاوية في مخزن سجل مركزي بواجهة بحث / تصفح. لا توفر كوبيرنيتيس أي حل تخزين محلي لبيانات السجل، ولكن يمكن للمرء دمج العديد من حلول التسجيل الموجودة في نظام كوبيرنيتيس.

Microservices

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

مقالات ذات صلة

المراجع

  1. Release 1.18.3 — تاريخ الاطلاع: 21 مايو 2020 — تاريخ النشر: 20 مايو 2020
  2. "What is Kubernetes?". Kubernetes. مؤرشف من الأصل في 30 مايو 201931 مارس 2017.
  3. "kubernetes/kubernetes". GitHub (باللغة الإنجليزية). مؤرشف من الأصل في 21 أبريل 201728 مارس 2017.
  4. Kubernetes v1.12: Introducing RuntimeClass - Kubernetes - تصفح: نسخة محفوظة 31 مارس 2019 على موقع واي باك مشين.
  5. "Google Made Its Secret Blueprint Public to Boost Its Cloud" (باللغة الإنجليزية). مؤرشف من الأصل في 01 يوليو 201627 يونيو 2016.
  6. "Google Open Sources Its Secret Weapon in Cloud Computing". Wired. مؤرشف من الأصل في 10 سبتمبر 201524 سبتمبر 2015.
  7. Abhishek Verma; Luis Pedrosa; Madhukar R. Korupolu; David Oppenheimer; Eric Tune; John Wilkes (April 21–24, 2015). "Large-scale cluster management at Google with Borg". Proceedings of the European Conference on Computer Systems (EuroSys). مؤرشف من الأصل في 27 يوليو 2017.
  8. "Borg, Omega, and Kubernetes - ACM Queue". queue.acm.org. مؤرشف من الأصل في 09 يوليو 201627 يونيو 2016.
  9. "Early Stage Startup Heptio Aims to Make Kubernetes Friendly"06 ديسمبر 2016.
  10. "As Kubernetes Hits 1.0, Google Donates Technology To Newly Formed Cloud Native Computing Foundation". TechCrunch. مؤرشف من الأصل في 23 سبتمبر 201524 سبتمبر 2015.
  11. "Cloud Native Computing Foundation". مؤرشف من الأصل في 03 يوليو 2017.
  12. Conway, Sarah. "Kubernetes Is First CNCF Project To Graduate". مؤسسة لينكس (باللغة الإنجليزية). مؤرشف من الأصل في 29 أكتوبر 201803 ديسمبر 2018. Compared to the 1.5 million projects on GitHub, Kubernetes is No. 9 for commits and No. 2 for authors/issues, second only to Linux.
  13. Sharma, Priyanka (13 April 2017). "Autoscaling based on CPU/Memory in Kubernetes—Part II". Powerupcloud Tech Blog. Medium. مؤرشف من الأصل في 17 أكتوبر 201927 ديسمبر 2018.
  14. "Configure Kubernetes Autoscaling With Custom Metrics". Bitnami. BitRock. 15 November 2018. مؤرشف من الأصل في 27 مارس 201927 ديسمبر 2018.
  15. "An Introduction to Kubernetes". DigitalOcean. مؤرشف من الأصل في 01 أكتوبر 201524 سبتمبر 2015.
  16. Pods - Kubernetes - تصفح: نسخة محفوظة 08 مايو 2019 على موقع واي باك مشين.
  17. Langemak, Jon (2015-02-11). "Kubernetes 101 – Networking". Das Blinken Lichten. مؤرشف من الأصل في 25 أكتوبر 201502 نوفمبر 2015.
  18. Strachan, James (2015-05-21). "Kubernetes for Developers". ميديوم. مؤرشف من الأصل في 07 سبتمبر 201502 نوفمبر 2015.
  19. Services - Kubernetes - تصفح: نسخة محفوظة 08 مايو 2019 على موقع واي باك مشين.
  20. Langemak, Jon (2015-02-15). "Kubernetes 101 – External Access Into The Cluster". Das Blinken Lichten. مؤرشف من الأصل في 26 أكتوبر 201502 نوفمبر 2015.
  21. "Intro: Docker and Kubernetes training - Day 2". ريد هات. 2015-10-20. مؤرشف من الأصل في 29 أكتوبر 201502 نوفمبر 2015.
  22. "Kubernetes Infrastructure". OpenShift Community Documentation. OpenShift. مؤرشف من الأصل في 06 يوليو 201524 سبتمبر 2015.
  23. حاويات Linux بواسطة CoreOS: البنية التحتية الكتلة
  24. Marhubi, Kamal (2015-09-26). "Kubernetes from the ground up: API server". kamalmarhubi.com. مؤرشف من الأصل في 29 أكتوبر 201502 نوفمبر 2015.
  25. Ellingwood, Justin (2 May 2018). "An Introduction to Kubernetes". ديجيتال أوشن (باللغة الإنجليزية). مؤرشف من الأصل في 05 يوليو 201820 يوليو 2018. One of the most important primary services is an API server. This is the main management point of the entire cluster as it allows a user to configure Kubernetes' workloads and organizational units. It is also responsible for making sure that the etcd store and the service details of deployed containers are in agreement. It acts as the bridge between various components to maintain cluster health and disseminate information and commands.
  26. "The Three Pillars of Kubernetes Container Orchestration - Rancher Labs". rancher.com. 18 May 2017. مؤرشف من الأصل في 24 يونيو 201722 مايو 2017.
  27. "Overview of a Replication Controller". Documentation. CoreOS. مؤرشف من الأصل في 22 سبتمبر 201502 نوفمبر 2015.
  28. Sanders, Jake (2015-10-02). "Kubernetes: Exciting Experimental Features". Livewyer. مؤرشف من الأصل في 20 أكتوبر 201502 نوفمبر 2015.
  29. Marhubi, Kamal (2015-08-27). "What [..] is a Kubelet?". kamalmarhubi.com. مؤرشف من الأصل في 13 نوفمبر 201502 نوفمبر 2015.
  30. rktnetes brings rkt container engine to Kubernetes - Kubernetes - تصفح: نسخة محفوظة 31 مارس 2019 على موقع واي باك مشين.


روابط خارجية

موسوعات ذات صلة :