تاریخ امروز۱۴۰۳-۰۲-۳۱

Kubernetes pod چیست

Kubernetes pod چیست؟ Kubernetes pod مجموعه‌ای از یک یا چند کانتینر لینوکس و کوچک‌ترین واحد از یک برنامه Kubernetes می‌باشد.

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

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

در واقع، یک pod مجموعه‌ای از یک یا چند کانتینر مرتبط است که در یک میزبان (node) واحد در کوبرنتیز اجرا می‌شوند و به صورت مشترک منابع سیستمی (مثل CPU و RAM) و شبکه را به اشتراک می‌گذارند.

کنترلرهای کوبرنتیز مانند ReplicaSet یا Deployment مسئولیت ساخت و مدیریت pod‌ها را بر عهده دارند. همچنین، هر pod دارای آدرس IP منحصر به فردی است که درون یک cluster قابل مشاهده است و امکان ارتباط مستقیم با دیگر pod‌ها یا منابع بیرونی را فراهم می‌کند.

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

واحدهای سخت افزاری

Node: کوچکترین واحد سخت افزار در کوبرنتیز است که به عنوان یک ماشین مجزا در نظر گرفته می‌شود.

Cluster: مجموعه‎‌ای از Nodeها است که برای به اشتراک گذاری و تعادل هوشمند منابع با یکدیگر گروه بندی می‌شوند.

واحدهای نرم افزاری

Linux container: مجموعه‌ای از یک یا چند فرآیند، شامل تمام فایل‌های لازم برای اجرا، که آنها را در سراسر ماشین‌ها قابل حمل می‌کند.

Kubernetes pod: مجموعه‌ای از یک یا چند کانتینر لینوکس که با هم بسته‌بندی شده‌اند تا مزایای اشتراک‌گذاری منابع از طریق مدیریت کلاستر را به حداکثر برسانند.

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

چندین مورد از آن nodeها در کلاستر جمع‌آوری می‌شوند و امکان توزیع قدرت محاسباتی در صورت نیاز را فراهم می‌کنند.

در ادامه مطلب Kubernetes pod چیست، به تفاوت میان پاد در مقابل Node ،Cluster و container خواهیم پرداخت.

آشنایی با تفاوت Kubernetes Pod با container
آشنایی با تفاوت Kubernetes Pod با container

تفاوت Kubernetes Pod با container

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

Pods یک لایه انتزاعی بر روی کانتینرها ایجاد می‌کند که وابستگی‌ها و منابعی را فراهم می‌کند که به Kubernetes اجازه می‌دهد تا کانتینرها را به طور موثر مدیریت کند.

در مورد کانتینر اطلاعات بیشتری کسب کنید.

تفاوت Kubernetes Pod با Nodes

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

یک Node چندین Pod در آن تعبیه شده است که کانتینرها را اجرا می‌کنند. دو نوع Node در Kubernetes به عنوان master nodes و worker nodes وجود دارد.

master nodes دارای یک صفحه کنترل است که زمان بندی پادهای موجود در worker nodes را مدیریت می‌کند.worker nodes میزبان پادهایی هستند که برنامه‌های کانتینری را اجرا می‌کنند.

تفاوت Kubernetes Pod با Cluster

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

یک کلاستر با استفاده از حداقل یک master nodes و worker nodes ایجاد می‌شود. از طریق‌ Nodeها، کلاسترها به پادهای Kubernetes محیط‌های پیکربندی‌شده و سبکی برای توسعه، استقرار و مدیریت کارآمد برنامه‌ها ارائه می‌کنند.

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

Pod چه کاری انجام می‌دهد

Pod نشان دهنده فرآیندهای در حال اجرا در یک کلاستر است. با محدود کردن پادها به یک فرآیند، Kubernetes می‌تواند در مورد سلامت هر فرآیندی که در کلاستر اجرا می‌شود، گزارش دهد.

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

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

نحوه کارکرد Kubernetes pod چیست
نحوه کارکرد Kubernetes pod چیست

Pod چگونه کار می‌کند

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

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

سه نوع رایج از کنترلرها عبارتند از:

  • مشاغلی از نوع دسته‌ای که زودگذر هستند و کار را به اتمام می‌رسانند
  • استقرار برنامه‌هایی که بدون حالت و پایدار هستند، مانند وب سرورها (سرورهای HPPT)
  • حالت‌ها برای برنامه‌هایی که هم حالت پذیر و هم پایدار هستند، مانند پایگاه‌های داده

اگر یک Node چندین کانتینر داشته باشد، همه آن‌ها روی یک سرور در کلاستر برنامه ریزی می‌شوند، فرقی ندارد ماشین مجازی یا سرور فیزیکی باشد.

تمام کانتینرها در پاد، منابع و وابستگی‌های خود را به اشتراک می‌گذارند و می‌توانند اجرا و خاتمه فعالیت آن‌ها را هماهنگ کنند.

به عنوان مثال، پادها می‌توانند حاوی کانتینرهای “init” باشند که قبل از اجرای کانتینرهای برنامه اجرا می‌شوند و محیطی را برای برنامه‌های بعدی، تنظیم می‌کنند.

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

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

نحوه ارتباط Podها با یکدیگر چگونه است

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

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

دلیل استفاده از کوبرنتیز از Podها
دلیل استفاده از کوبرنتیز از Podها

چرا کوبرنتیز از Podها استفاده می‌کند

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

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

این سازماندهی کانتینر به صورت پادها، مبنای یکی از ویژگی‌های شناخته شده کوبرنتس به نام تکرار است.

هنگامی که کانتینرها به صورت پاد سازماندهی می‌شوند، کوبرنتس می‌تواند از کنترلرهای تکرار برای مقیاس افقی یک برنامه در صورت نیاز استفاده کند.

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

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

انواع Pod

پادها، کانتینرها را به دو روش اجرا می‌کند:

Single containers

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

Multiple container

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

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

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

نحوه کار با Pods چگونه است

با استفاده از یک ابزار خط فرمان به نام kubectl می توان به پادها دسترسی داشت. Kubectl به شما امکان می‌دهد طیف وسیعی از وظایف مدیریتی را در Nodeها اجرا کنید.

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

دریافت Pods

هنگامی که به داده‌هایی از پادهای کوبرنیت نیاز دارید، از دستور kubectl get pods استفاده کنید. این دستور اطلاعات جدول بندی شده در مورد منابع موجود در یک pod را به شما می‌دهد.

اگر اطلاعات مربوط به یک pod خاص را می‌خواهید، می‌توانید از kubectl get pods name_of _pod استفاده کنید.

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

نحوه ایجاد Pods

برای ایجاد یک pod، از دستور kubectl create -f FILENAME$ استفاده کنید. اگرچه این امکان وجود دارد، اما Kubernetes آن را توصیه نمی‌کند.

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

کنترل‌کننده‌هایی مانند Deployment ،Job و StatefulSets اطمینان حاصل می‌کنند که pod‌ها تکرار می‌شوند، حجم دائمی دارند و به طور موثر و کارآمد اجرا می‌شوند.

آموزش نحوه ایجاد Pods
آموزش نحوه ایجاد Pods

حذف Pods

برای حذف یک pod می‌توانید از دستور kubectl delete -f ./mypod.yaml$ استفاده کنید. این دستور فوراً پادها را حذف می‌کند و مدت مهلت برای خاتمه را لغو می‌کند.

پادهای Kubernetes دارای مهلت پیش فرض ۳۰ ثانیه‌ای برای اتمام هستند. حذف اجباری پادها با منابع مشترک مانند فضای ذخیره‌سازی، API یا نام‌ها توصیه نمی‌شود.

Nodeها مدتی طول می‌کشد تا متوجه حذف اجباری شوند، بنابراین یک حذف ممکن است روی فرآیندهای دیگر با استفاده از شناسایی مشابه پاد حذف شده تأثیر بگذارد.

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

اگر ۱۰ دقیقه برای انتظار ندارید، منابع api kubectl را اجرا کنید تا حافظه کش به سرعت بارگذاری شود.

به‌روزرسانی یا جایگزینی پادها

پس از ایجاد، برخی از اطلاعات در Kubernetes pod غیرقابل تغییر است. اطلاعات شامل فراداده‌ها، فیلدها، نام‌ها و برخی مشخصات می‌باشد.

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

Pods مانیتورینگ

کوبرنیت‌ها به دلیل اجزای زیادی که دارند، خطرات بیشتری برای داشتن تنگناهای عملکردی آن‌ها را تهدید می‌کند. این امر نظارت را ضروری می‌کند.

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

در صورت بروز مشکلات باید دائما به شما هشدار داده شود تا سریعا نسبت به رفع آن اقدام کنید.

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

جمع بندی

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

اشتراک‌گذاری

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *