⏳ افزایش قیمت‌ | آخرین فرصت خرید دوره‌های برنامه‌نویسی با قیمت سال قبل با => ۶۵٪ تخفیف

مشاهده دوره‌ها
Kubernetes (K8s) به زبان ساده: ارکستراسیون کانتینرها برای حرفه‌ای‌ها
ﺯﻣﺎﻥ ﻣﻄﺎﻟﻌﻪ: 17 دقیقه

Kubernetes (K8s) به زبان ساده: ارکستراسیون کانتینرها برای حرفه‌ای‌ها

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

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

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

کانتینر؛ از سادگی جذاب تا پیچیدگی پنهان

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

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

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

وقتی تعداد کانتینرها زیاد می‌شود

فرض کنید به‌جای سه یا چهار کانتینر، با صدها کانتینر سروکار دارید. حالا سوالات جدیدی مطرح می‌شوند:

  • اگر یکی از کانتینرها از کار بیفتد، چه می‌شود؟
  • اگر ترافیک ناگهان دو برابر شود، چگونه مقیاس را افزایش می‌دهید؟
  • اگر یک سرور کامل از دسترس خارج شود، چه کسی سرویس‌ها را بازیابی می‌کند؟
  • چگونه بین این همه کانتینر، ارتباط شبکه‌ای پایدار برقرار می‌شود؟

در این نقطه، مدیریت دستی غیرممکن می‌شود. مهندس سیستم دیگر نمی‌تواند با چند اسکریپت ساده یا دستورهای پراکنده، همه‌چیز را کنترل کند. زیرساخت وارد مرحله‌ای می‌شود که به «مدیریت سیستماتیک» نیاز دارد، نه مدیریت موردی.

مسئله‌ی اصلی: هماهنگی، نه اجرا

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

در مقیاس بزرگ، شما با شبکه‌ای از اجزا مواجه هستید که دائما در حال تغییرند:

  • کانتینرها ساخته و حذف می‌شوند
  • نسخه‌ها بروزرسانی می‌شوند
  • منابع کم یا زیاد می‌شوند
  • خطاها رخ می‌دهند
  • ترافیک نوسان می‌کند

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

از مدیریت دستی تا نیاز به ارکستراسیون

در این مرحله است که مفهوم «ارکستراسیون» معنا پیدا می‌کند. همان‌طور که یک ارکستر بدون رهبر، به‌سختی می‌تواند هماهنگ بنوازد، مجموعه‌ای از کانتینرها هم بدون یک سیستم مرکزیِ هوشمند، دچار آشفتگی می‌شوند.

ارکستراسیون یعنی:

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

کانتینرها ابزار اجرا هستند، اما ارکستراسیون، ابزار مدیریت حیات آن‌هاست. و دقیقا در همین نقطه است که کوبرنتیز وارد داستان می‌شود.

Kubernetes چیست و چگونه به استاندارد صنعت تبدیل شد؟

پس از آن‌که مسئله‌ی مدیریت کانتینرها به یک چالش جدی در زیرساخت‌های مدرن تبدیل شد، بسیاری از شرکت‌ها و تیم‌های فنی به‌دنبال راهکاری بودند که بتواند این پیچیدگی را به‌صورت ساختاریافته و پایدار کنترل کند. یکی از مهم‌ترین پاسخ‌ها به این نیاز، در دل شرکت Google شکل گرفت. گوگل سال‌ها پیش برای مدیریت میلیون‌ها کانتینر در مقیاس جهانی، سیستمی داخلی به نام Borg توسعه داده بود. Kubernetes در واقع حاصل انتقال تجربه‌ی همین سیستم به دنیای متن‌باز است، تجربه‌ای که بعدها با حمایت بنیاد Cloud Native Computing Foundation به یک پروژه‌ی جهانی و استاندارد صنعتی تبدیل شد.

به‌طور خلاصه، کوبرنتیز یک سیستم متن‌باز برای مدیریت، هماهنگی و خودکارسازی اجرای کانتینرها در مقیاس بزرگ است. اما این تعریف، تنها بخش کوچکی از واقعیت را نشان می‌دهد. در عمل، Kubernetes نوعی «مغز مدیریتی» برای زیرساخت محسوب می‌شود که به‌صورت مداوم وضعیت سیستم را بررسی می‌کند و تلاش می‌کند آن را با شرایط ایده‌آلی که شما تعیین کرده‌اید، هماهنگ نگه دارد. شما به‌جای دخالت مستقیم در جزئیات، هدف خود را مشخص می‌کنید و Kubernetes مسئول تحقق آن می‌شود.

یکی از بنیادی‌ترین ایده‌های Kubernetes، مفهوم «وضعیت مطلوب» یا Desired State است. در این سیستم، دستور مستقیم صادر نمی‌کنید، بلکه وضعیت موردنظر خود را تعریف می‌کنید. برای مثال، مشخص می‌کنید که یک سرویس باید همیشه با تعداد معینی نمونه فعال باشد یا میزان مصرف منابع از حدی فراتر نرود. از آن لحظه به بعد، Kubernetes تلاش می‌کند به‌صورت پیوسته وضعیت واقعی سیستم را با این الگوی مطلوب هماهنگ کند و در صورت بروز اختلاف، به‌طور خودکار مداخله نماید.

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

احتمالا در منابع مختلف با نام K8s به‌جای Kubernetes مواجه شده‌اید. این نام‌گذاری یک قرارداد رایج در دنیای فناوری است که از حرف اول و آخر واژه Kubernetes و تعداد حروف میانی آن تشکیل شده است. به همین دلیل، Kubernetes به‌صورت خلاصه K8s نوشته می‌شود و این شکل اختصاری در مستندات و مکالمات حرفه‌ای بسیار متداول است.

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

با گذشت زمان، کوبرنتیز از یک پروژه‌ی فنی ساده فراتر رفت و به هسته‌ی اصلی معماری‌های Cloud-Native تبدیل شد. امروزه اغلب پلتفرم‌های ابری بزرگ از آن پشتیبانی می‌کنند و اکوسیستم گسترده‌ای از ابزارها و سرویس‌ها پیرامون آن شکل گرفته است. به همین دلیل، بسیاری از متخصصان، Kubernetes را نوعی «سیستم‌عامل برای مراکز داده» می‌دانند که مدیریت منابع را در سطحی جدید ممکن ساخته است.

در نهایت، یادگیری کوبرنتیز صرفا به معنای آشنایی با یک ابزار نیست، بلکه به معنای ورود به شیوه‌ای نوین از تفکر درباره‌ی زیرساخت است؛ شیوه‌ای مبتنی بر خودکارسازی، اعتماد به سیستم و طراحی برای مقیاس بزرگ. برای افرادی که قصد فعالیت حرفه‌ای در حوزه‌هایی مانند DevOps، مهندسی ابر یا معماری نرم‌افزار را دارند، تسلط بر Kubernetes نه یک انتخاب اختیاری، بلکه یک ضرورت محسوب می‌شود.

مفاهیم پایه در Kubernetes

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

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

کلاستر (Cluster): بستر اصلی اجرا

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

نود (Node): محل اجرای واقعی برنامه‌ها

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

پاد (Pod): کوچک‌ترین واحد اجرا

Pod کوچک‌ترین و بنیادی‌ترین واحد در کوبرنتیز است. برخلاف تصور اولیه، کوبرنتیز مستقیما با کانتینرها کار نمی‌کند، بلکه آن‌ها را در قالب Pod مدیریت می‌کند.

هر Pod می‌تواند شامل یک یا چند کانتینر باشد که به‌صورت کاملا نزدیک و هماهنگ با هم کار می‌کنند. این کانتینرها:

  • از یک شبکه مشترک استفاده می‌کنند
  • به فضای ذخیره‌سازی مشترک دسترسی دارند
  • معمولاً بخشی از یک سرویس واحد هستند

به همین دلیل، Pod را می‌توان «واحد منطقی اجرای برنامه» در کوبرنتیز دانست.

دیپلویمنت (Deployment): مدیریت نسخه‌ها و پایداری

Deployment یکی از مهم‌ترین ابزارهای مدیریتی در کوبرنتیز است. با استفاده از آن، شما مشخص می‌کنید که یک برنامه چگونه و با چه تعداد نمونه اجرا شود.

Deployment مسئول موارد زیر است:

  • ایجاد و حذف Podها
  • مدیریت تعداد نسخه‌های فعال
  • بروزرسانی تدریجی نرم‌افزار
  • بازگشت به نسخه قبلی در صورت بروز خطا

به‌عبارت دیگر، Deployment تضمین می‌کند که برنامه‌ی شما همیشه در وضعیت پایدار و موردنظر باقی بماند.

سرویس (Service): ارتباط پایدار میان اجزا

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

نیم‌اسپیس (Namespace): نظم‌دهی به منابع

در پروژه‌های بزرگ، تعداد زیادی سرویس، تیم و محیط مختلف وجود دارد. Namespace ابزاری برای سازمان‌دهی این فضاست.

با استفاده از Namespace می‌توان:

  • منابع پروژه‌ها را از هم جدا کرد
  • محیط‌های توسعه، تست و تولید را تفکیک نمود
  • سطح دسترسی کاربران را کنترل کرد

Namespace کمک می‌کند کلاستر از حالت شلوغ و بی‌نظم خارج شود و ساختاری قابل مدیریت داشته باشد.

ConfigMap و Secret: مدیریت تنظیمات و اطلاعات حساس

در معماری مدرن، بهتر است تنظیمات برنامه از کد جدا باشند. Kubernetes این کار را با استفاده از ConfigMap و Secret انجام می‌دهد.

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

Volume و PersistentVolume: مدیریت داده‌ها

کانتینرها ذاتا موقتی هستند و با حذف آن‌ها، داده‌های داخلی‌شان نیز از بین می‌رود. برای حل این مسئله، کوبرنتیز از مفهوم Volume و PersistentVolume استفاده می‌کند. این ابزارها امکان ذخیره‌سازی داده‌ها به‌صورت پایدار را فراهم می‌کنند تا حتی در صورت حذف Pod، اطلاعات باقی بمانند. این قابلیت برای پایگاه‌های داده و سرویس‌های حساس کاملا حیاتی است.

تصویر کلی مفاهیم پایه

اگر بخواهیم همه‌ این مفاهیم را کنار هم بگذاریم، می‌توان گفت:

  • کلاستر بستر کلی است
  • نودها محل اجرا هستند
  • Pod واحد اجرای برنامه است
  • Deployment مدیریت پایداری را بر عهده دارد
  • Service ارتباط را برقرار می‌کند
  • Namespace نظم ایجاد می‌کند
  • ConfigMap و Secret تنظیمات را مدیریت می‌کنند
  • Volume داده‌ها را حفظ می‌کند

معماری درونی Kubernetes

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

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

ساختار کلی: دو بخش اصلی سیستم

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

بخش مدیریتی (Control Plane)
بخش اجرایی (Worker Nodes)

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

Control Plane یا مرکز فرماندهی کلاستر

Control Plane مجموعه‌ای از سرویس‌هاست که وضعیت کل کلاستر را مدیریت می‌کنند. این بخش دائماً در حال بررسی وضعیت سیستم و صدور فرمان‌های لازم است.

مهم‌ترین اجزای Control Plane عبارت‌اند از:

API Server: دروازه‌ی ارتباطی سیستم

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

Scheduler: تصمیم‌گیرنده‌ی محل اجرا

Scheduler مسئول انتخاب محل اجرای Podهاست. وقتی یک Pod جدید ایجاد می‌شود، Scheduler بررسی می‌کند که:

  • کدام نود منابع کافی دارد
  • بار کاری نودها چگونه توزیع شده است
  • محدودیت‌های تعریف‌شده رعایت شده‌اند یا نه

بر اساس این اطلاعات، بهترین نود را برای اجرای Pod انتخاب می‌کند. این فرآیند باعث می‌شود منابع سیستم به‌صورت بهینه استفاده شوند.

Controller Manager: حافظ وضعیت مطلوب

Controller Manager مجموعه‌ای از کنترل‌کننده‌هاست که وظیفه‌ی اصلی آن‌ها، مقایسه‌ی وضعیت واقعی سیستم با وضعیت مطلوب است. برای مثال، اگر شما مشخص کرده باشید که باید سه Pod فعال وجود داشته باشد، یکی از کنترل‌کننده‌ها دائماً بررسی می‌کند که آیا این شرط برقرار است یا نه. اگر تعداد Podها کمتر شود، به‌طور خودکار نمونه‌ی جدید ایجاد می‌کند. Controllerها در واقع نگهبانان «تعادل سیستم» هستند.

etcd: حافظه‌ی مرکزی Kubernetes

etcd یک دیتابیس توزیع‌شده و بسیار پایدار است که تمام اطلاعات حیاتی Kubernetes در آن ذخیره می‌شود. در این دیتابیس، اطلاعاتی مانند موارد زیر نگهداری می‌شوند:

  • وضعیت Podها
  • تنظیمات کلاستر
  • سیاست‌های امنیتی
  • متادیتای سرویس‌ها

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

Worker Nodes: محل اجرای واقعی برنامه‌ها

در مقابل Control Plane، نودهای اجرایی قرار دارند. این نودها مسئول اجرای کانتینرها و ارائه‌ی سرویس‌ها هستند. هر Worker Node شامل چند جزء اصلی است:

Kubelet: نماینده Kubernetes روی هر نود

Kubelet یک سرویس است که روی هر نود اجرا می‌شود و ارتباط آن نود با Control Plane را برقرار می‌کند.

وظایف اصلی Kubelet عبارت‌اند از:

  • دریافت دستور اجرای Pod
  • راه‌اندازی کانتینرها
  • بررسی سلامت برنامه‌ها
  • گزارش وضعیت به مرکز

Kubelet را می‌توان «نماینده‌ی رسمی Kubernetes» روی هر سرور دانست.

Container Runtime: موتور اجرای کانتینر

Container Runtime نرم‌افزاری است که واقعا کانتینرها را اجرا می‌کند. این بخش مسئول ساخت، راه‌اندازی و توقف کانتینرهاست. Kubernetes به‌صورت مستقیم کانتینرها را اجرا نمی‌کند، بلکه این وظیفه را به Runtime می‌سپارد.

Kube-proxy: مدیریت ارتباط شبکه‌ای

Kube-proxy مسئول پیاده‌سازی قوانین شبکه‌ای و توزیع ترافیک در سطح نود است. این سرویس کمک می‌کند Serviceها بتوانند درخواست‌ها را به‌درستی به Podهای مربوطه هدایت کنند و ارتباط داخلی سیستم پایدار بماند.

جریان یک درخواست در Kubernetes

برای درک بهتر معماری، یک مثال ساده را بررسی کنیم:

فرض کنید می‌خواهید یک Deployment جدید ایجاد کنید.

۱. دستور شما به API Server ارسال می‌شود.
۲. API Server آن را اعتبارسنجی کرده و در etcd ذخیره می‌کند.
۳. Controller Manager متوجه تغییر وضعیت می‌شود.
۴. Scheduler نود مناسب را انتخاب می‌کند.
۵. Kubelet روی نود مربوطه دستور اجرا را دریافت می‌کند.
۶. Container Runtime کانتینرها را اجرا می‌کند.
۷. وضعیت نهایی به Control Plane گزارش می‌شود.

این زنجیره‌ی هماهنگ، اساس عملکرد Kubernetes را تشکیل می‌دهد.

جمع‌بندی

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

چه امتیازی برای این مقاله میدهید؟

خیلی بد
بد
متوسط
خوب
عالی
5 از 1 رای

/@arastoo
ارسطو عباسی
کارشناس تست نرم‌افزار و مستندات

...

دیدگاه و پرسش
برای ارسال دیدگاه لازم است وارد شده یا ثبت‌نام کنید ورود یا ثبت‌نام

در حال دریافت نظرات از سرور، لطفا منتظر بمانید

در حال دریافت نظرات از سرور، لطفا منتظر بمانید

ارسطو عباسی

کارشناس تست نرم‌افزار و مستندات