مراحل به‌روزرسانی کوبرنتیز با استفاده از kubeadm

در این مستند به روز رسانی کلاستر کوبرنتیز رو با استفاده از kubeadm بررسی می‌کنیم. قبلا در یه بلاگ پست اهمیت به روز رسانی کوبرنتیز رو بررسی کردیم و در اینجا نحوه‌ی به روز رسانی رو با استفاده از kubeadm بررسی می‌کنیم.

. بررسی نسخه فعلی

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

 

				
					kubectl version
kubectl get node

				
			

این دستور نسخه‌ی فعلی کوبرنتیز رو به شما نشان می‌دهد. نسخه‌ای که روی کلایند و سرورها نصب شده است. با لیست گرفتن نودها هم می‌تونید نسخه‌ی kubelet روی نودها رو بدست آورید.

۲. تعیین نسخه جدید:

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

با دستور زیر با توجه به ریپوزیتوری که اضافه کردید می‌تونید نسخه‌های در دسترس رو بررسی کنید:

				
					apt-cache policy kubeadm
				
			

. برنامه‌ریزی به‌روزرسانی:

برنامه‌ریزی دقیق به‌روزرسانی یکی از کلیدهای موفقیت است. موارد زیر را در نظر بگیرید:

    • مطالعه‌ی کامل و با دقت Release note: حتما به دقت و با صبر و حوصله ریلیز نوت رو بخونید و از تغییرات که اتفاق می‌افتد مطلع باشید.
    • زمان مناسب: بهترین زمان برای به‌روزرسانی، زمانی است که بار کاری کم است. یا اونقدر نود در دسترس دارید که با کم کردن یک یا چند تا نود اختلالی در فرآیند سرویس‌دهی شما پیش نمی‌آید.
    • پشتیبان‌گیری: حتماً از داده‌ها و پیکربندی‌های سیستم خود پشتیبان بگیرید. حتما از etcd بکاپ بگیرید.
    • آزمون در محیط‌های غیر از پروداکشن: اگر امکانش هست، به‌روزرسانی را ابتدا در محیط‌های غیر پروداکشن (Development/Staging) امتحان کنید. این خیلی می‌‌تونه کمک کنه که فرآیند رو بهینه و بدون ریسک پیش ببرید.
  • بررسی وضعیت swap: حتما بررسی و چک کنید که swap غیر فعال باشد. گاهی پیش می‌آید بعد از ریبوت کردن مجدد swap فعال می‌شود و به خطا می‌خورید. حتما چک کنید که swap داخل fstab غیر فعال باشد.
  • بررسی میزان منابع خالی کلاستر: همواره قبل از به‌روز رسانی بررسی کنید که میزان مناسب منابع خالی داخل کلاستر وجود داشته باشد تا در حین به روز رسانی با مشکل مواجه نشویم. 

. به‌روزرسانی نود کنترل کننده (Control Plane)

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

خالی کردن نود مستر اول:

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

				
					kubectl drain <control-plane-node-name> --ignore-daemonsets --delete-emptydir-data

				
			

این دستور به شما این امکان را می‌دهد که نود را خالی کنید و به سادگی کارهای ناخواسته را متوقف کنید. 

به روز کردن kubeadm داخل نود مستر:

قبل از شروع باید نسخه‌ی kubeadm نود مستر رو به نسخه‌ای که داریم ارتقا دهیم. دقیقا همون نسخه‌ای که می‌خواهیم به روز کنیم. برای این کار ابتدا kubeadm رو از hold خارج کنید و سپس آن را به‌روز کنید. البته اینجا داریم روشی رو بررسی می‌کنیم که از apt شما استفاده می‌کنید در صورتی که باینری آن را نصب کردید از همون روش برای نصب نسخه‌ی جدید ادغام کنید. 

## replace x in 1.28.x-* with the latest patch version

apt-mark unhold kubeadm && \

apt-get update && apt-get install -y kubeadm=’1.28.x-*’ && \

apt-mark hold kubeadm

قبلا کوبرنتیز یه ریپوزیتوری برای apt داشت که همه‌ی نسخه‌ها داخلش بود. این ریپو می‌تونست مشکلاتی ایجاد کنه مثلا اگر ابزارهای کوبرنتیز رو hold نکرده بودیم و سیستم عامل رو به روز می‌کردیم مجموعه‌ی ابزارهای ما هم همگی به روز می‌شدند و این موضوع مخاطرات زیادی برای ما به همراه داشت. تو ریپوزیتوری‌های جدید این طوری هست که هر کدوم فقط یک نسخه‌ی mirror رو پوشش می‌دهد. تنها همون نسخه به همراه تمام patchهایی که دارد را پوشش می‌دهد.

پس از به روز کردن نسخه‌ی جدید ابزار keubadm داخل نود مستر با استفاده از دستور زیر فرآیند آپگرید نود رو بررسی می‌کنیم.

				
					kubeadm upgrade plan

				
			

این دستور جزئیات مربوط به نسخه جدید و نودها را نمایش می‌دهد.

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

پس از بررسی به‌روزرسانی حال از دستور زیر برای اعمال به‌روزرسانی استفاده کنید:

				
					kubeadm upgrade apply v1.28.x

				
			

حتما نسخه‌ای که می‌خواهید سمت آن بروید رو انتخاب کنید.

بعد از به روز رسانی احتمالا همچنین خروجی رو خواهید دید.

[upgrade/successful] SUCCESS! Your cluster was upgraded to “v1.28.x”. Enjoy!

[upgrade/kubelet] Now that your control plane is upgraded, please proceed with upgrading your kubelets if you haven’t already done so.

به روز کردن مابقی ابزارهای داخل نود:

پس از اتمام به روز رسانی ابزارهای kubelet و kubectl رو به روز کنید. برای این کار همانند آپدیت kubeadm رفتار می‌کنیم.

				
					# replace x in 1.28.x-* with the latest patch version
apt-mark unhold kubelet kubectl && \
apt-get update && apt-get install -y kubelet='1.28.x-*' kubectl='1.28.x-*' && \
apt-mark hold kubelet kubectl


				
			

بازنشانی نود کنترل کننده:

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

				
					systemctl restart kubelet
systemctl status kubelet

				
			

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

				
					kubectl uncordon <control-plane-node-name>

				
			

. به‌روزرسانی نودهای دیگر (Worker Nodes)

بعد از به‌روزرسانی نود کنترل کننده‌ی اول سراغ نودهای مستر دیگه و پس از آن به سراغ نودهای ورکر بروید. ادامه‌ی روند به این صورت است که ابتدا نود رو drain کرده و پس از آن kubeadm را به روز می‌کنید و پس از آن upgrade رو انجام بدید و پس از آن که همه چی به خوبی پیش رفت نود رو uncordon کرده و آن را تست کنید.

خالی کردن نود:

نود مورد نظر را ابتدا drain کنید.

				
					kubectl drain <worker-node-name> --ignore-daemonsets  --delete-emptydir-data

				
			

به‌روزرسانی kubeadm نود:

از دستورات زیر برای به‌روزرسانی kubeadm نود استفاده کنید.

## replace x in 1.28.x-* with the latest patch version

apt-mark unhold kubeadm && \

apt-get update && apt-get install -y kubeadm=’1.28.x-*’ && \

apt-mark hold kubeadm

و پس از آن نود رو با استفاده از دستور زیر به روز کنید:

				
					kubeadm upgrade node

				
			

پس از نهایی شدن به روز رسانی مابقی ابزارها رو به روز کنید.

				
					# replace x in 1.28.x-* with the latest patch version
apt-mark unhold kubelet kubectl && \
apt-get update && apt-get install -y kubelet='1.28.x-*' kubectl='1.28.x-*' && \
apt-mark hold kubelet kubectl


				
			

و پس از آن سرویس kubelet رو ریست کنید و از عملکرد آن اطمینان کسب کنید.

				
					systemctl restart kubelet
systemctl status kubelet

				
			

بازنشانی نود:

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

				
					kubectl uncordon <worker-node-name>

				
			

۶. بررسی وضعیت پس از آپگرید

پس از اتمام به‌روزرسانی، باید وضعیت سیستم را بررسی کنید:

				
					kubectl get nodes
kubectl get pods --all-namespaces

				
			

اطمینان حاصل کنید که همه پادها در وضعیت Running هستند و نودها به‌درستی کار می‌کنند. بهتره که همواره اسکریپت‌ و ابزارهای تست داشته باشید تا بتونید همه چیز رو باهاش تست کنید. بهتون توصیه می‌کنم که اگر end to end تست ندارید حتما smoke test داشته باشید که با طی کردن مراحلی از صحت عملکرد کلاستر و سرویس‌های آن اطمینان کسب کنید. Smoke test فرآیندی است که موارد ضروری داخل کلاستر رو با استفاده از آن تست و بررسی می‌کنیم. 

 

نکته‌ی مهم:

  • این فرآیند تنها کوبرنتیز و ابزارهای آن را به روز می‌کند. همواره باید حواسمون به روزرسانی add-onsها همانند ingress و cert-manager و موارد دیگه باشیم.
  • لازمه که دقت کنیم پلاگین‌های کوبرنتیز همانند CNI, CRI و CSI رو نیز به روز کنیم. به روزرسانی‌ آنها مستقل از به روز رسانی کوبرنتیز است. 
  • به روز رسانی سیستم عامل رو هم فراموش نکنید. زمانی که نود رو از دسترس خارج می‌کنید بهترین زمان است که سیستم عامل نود‌ها رو هم به روز کنید. دقت کنید که حتما پکیج‌های مهم hold شده باشد تا در زمان به روز رسانی با مشکل مواجه نشوید.

جمع‌بندی

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

دیدگاه‌ خود را بنویسید

مقاله های داکرمی

Kubernetes

امنیت در طراحی و پیاده‌سازی کلاستر کوبرنتیز

مقدمه در دنیای فناوری اطلاعات امروز، امنیت داده‌ها به یکی از اولویت‌های اصلی سازمان‌ها تبدیل شده است. با رشد تکنولوژی و نیاز به سامانه‌های پیچیده و مقیاس‌پذیر، پلتفرم‌های مدیریت کانتینر مانند کوبرنتیز (Kubernetes) به شدت محبوب شده‌اند. با این حال،

توضیحات بیشتر »
k8s update

آپگرید کوبرنتیز: چالش‌ها، اهمیت و بهترین شیوه‌ها

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

توضیحات بیشتر »
پیمایش به بالا