نشر Kubernetes مع Kubeadm على CentOS 7

نظرة عامة

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

ما هو كوبيدم؟

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

المتطلبات الأساسية

هناك بعض المتطلبات للخوادم التي سننشرها. جهاز أو أكثر يعمل بنظام تشغيل متوافق مع deb / rpm. سنستخدم CentOS.

  • 2 غيغابايت أو أكثر من ذاكرة الوصول العشوائي لكل جهاز
  • 2 وحدات المعالجة المركزية أو أكثر على سيد

اتصال شبكة كاملة بين جميع الأجهزة في الكتلة

الخادمان اللذان تم نشرهما في هذا الدليل هما: - 1 وحدة معالجة مركزية 2 غيغابايت من ذاكرة الوصول العشوائي مع CentOS 7 (عقدة العامل) - 2 وحدة معالجة مركزية 4 غيغابايت من ذاكرة الوصول العشوائي مع CentOS 7 (عقدة رئيسية)

مع هذا الحجم من ذاكرة الوصول العشوائي على كلا الخادمين ، سيكون لدى Kubernetes مساحة كبيرة للتنفس.

تكوين العامل والسيد

فيما يلي الخطوات التي يتعين علينا اتخاذها في كل من العقدة الرئيسية والعاملة:

  • تحديث ومجموعات Yum
  • تثبيت عامل الميناء
  • تعطيل selinux
  • تعطيل المبادلة
  • تعطيل جدار الحماية
  • تحديث IPTables
  • تثبيت kubelet / kubeadm / kubectl

تثبيت Docker

1.14سنستخدم إصدار Kubernetes في هذا البرنامج التعليمي. بالنسبة لهذا الإصدار ، توصي Kubernetes بتشغيل إصدار Docker 18.06.2. تأكد من التحقق من إصدار Docker الموصى به لإصدار Kuberenetes الخاص بك

سنضيف مستودع Docker إلى يم ونقوم بتثبيته على وجه التحديد 18.06.2. بمجرد تثبيت Docker ، سنحتاج إلى تكوين برنامج docker على الإعدادات الموصى بها من قبل Kubernetes.

###Add yum-utils, if not installed already
yum install yum-utils

###Add Docker repository.
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

###Install Docker CE.
yum update && yum install docker-ce-18.06.2.ce

###Create /etc/docker directory.
mkdir /etc/docker

###Setup daemon.
cat > /etc/docker/daemon.json <<EOF
{
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2",
  "storage-opts": [
    "overlay2.override_kernel_check=true"
  ]
}
EOF

mkdir -p /etc/systemd/system/docker.service.d

###Restart Docker
systemctl daemon-reload
systemctl enable docker.service
systemctl restart docker

تعطيل SELinux

نظرًا لأننا نستخدم CentOS ، نحتاج إلى تعطيل SELinux. يعد ذلك ضروريًا للسماح للحاويات بالوصول إلى نظام الملفات المضيف.

setenforce 0
sed -i 's/^SELINUX=enforcing$/SELINUX=disable/' /etc/selinux/config

تعطيل السواب

يجب تعطيل السواب للسماح للعمل kubelet بشكل صحيح.

sed -i '/swap/d' /etc/fstab
swapoff -a

تعطيل جدار الحماية

يستخدم Kubernetes IPTables للتعامل مع حركة المرور الواردة والصادرة - وذلك لتجنب أي مشكلات نقوم بتعطيل جدار الحماية.

systemctl disable firewalld
systemctl stop firewalld

تحديث IPTables

توصي Kubernetes بالتأكد net.bridge.bridge-nf-call-iptablesمن تعيينها على 1. يرجع ذلك إلى المشكلات التي واجهت فيها REHL / CentOS 7 مشاكل في إعادة توجيه حركة المرور بشكل غير صحيح بسبب تجاوز iptables.

cat <<EOF > /etc/sysctl.d/k8s.conf
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
sysctl --system

تثبيت kubelet / kubeadm / kubectl

سنحتاج إلى إضافة kubernetes الريبو إلى يم. بمجرد القيام بذلك ، نحتاج فقط إلى تشغيل أمر التثبيت وتمكين kubelet.

cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=1
repo_gpgcheck=1
gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg
exclude=kube*
EOF

yum install -y kubelet kubeadm kubectl --disableexcludes=kubernetes
systemctl enable --now kubelet

الآن قمنا بتكوين العقدة الرئيسية والعاملة لدينا بالكامل. يمكننا الآن تهيئة العقدة الرئيسية الخاصة بنا والانضمام إلى العقد العاملة لدينا إلى السيد!

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

إعداد العقدة الرئيسية

نريد تهيئة العقدة الرئيسية الخاصة بنا عن طريق تشغيل الأمر التالي. ستحتاج إلى استبدال عنوان IP الخاص بالعقدة الرئيسية في الأمر أدناه. بالإضافة إلى ذلك ، سنقوم بتمرير pod-network-cidr لتسهيل الأمر علينا لاحقًا عندما نقوم بتثبيت تراكب شبكة Flannel.

kubeadm init --apiserver-advertise-address=YOUR_IP_HERE --pod-network-cidr=10.244.0.0/16

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

kubeadm join YOUR_IP:6443 --token 4if8c2.pbqh82zxcg8rswui \
--discovery-token-ca-cert-hash sha256:a0b2bb2b31bf7b06bb5058540f02724240fc9447b0e457e049e59d2ce19fcba2

هذا الأمر هو ما تحتاج العقد المنفذة إلى تنفيذه للانضمام إلى الكتلة ، لذا دوّن ذلك.

التالي هو Flannel. الفانيلا هو ما يسمح للجراب بالاتصال. هناك أنواع أخرى مختلفة من تراكبات الشبكة التي يمكنك تثبيتها ولكن من أجل البساطة ، سيستخدم هذا الدليل Flannel.

انسخ kube/configالملف إلى حسابك $Homeحتى تتمكن من تنفيذ kubectlالأوامر.

mkdir $HOME/.kube
cp /etc/kubernetes/admin.conf $HOME/.kube/config

خطوة أخيرة في العقدة الرئيسية هي تثبيت Flannel. قم بتشغيل الأمر التالي.

kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

مع نسخ هذا التكوين ، ستتمكن من التشغيل kubectl get csوالحصول على استجابة.

NAME                 STATUS    MESSAGE             ERROR
scheduler            Healthy   ok
controller-manager   Healthy   ok
etcd-0               Healthy   {"health":"true"}

تم تعيين العقدة الرئيسية الخاصة بك وجاهزة للانطلاق. على العقدة العاملة!

عقدة العامل

عند هذه النقطة لا يوجد عمل إضافي ضروري على عقدة العامل. كل ما نحتاجه هو تشغيل kubeadm joinالأمر الذي حصلنا عليه من kubeadm initمخرجاتنا.

إذا كنت قد أخطأت في بعض الأحيان في أمر الانضمام kubeadm ، فيمكنك إنشاء أمر آخر على العقدة الرئيسية عن طريق التشغيل kubeadm token create --print-join-command

بمجرد تشغيل أمر الانضمام kubeadm ، إذا قمت بتشغيل kubectl get nodesعلى سيد سترى ناتجًا مشابهًا لما يلي.

NAME          STATUS   ROLES    AGE    VERSION
k8-master   Ready    master   107m   v1.14.2
k8-worker   Ready    <none>   45m    v1.14.2

تغليف

تمامًا مثل ذلك أنك قمت بتمهيد مجموعة Kubernetes باستخدام kubeadm. يمكنك أيضًا القيام بذلك مع الشبكات الخاصة. تسمح Vultr ، بالإضافة إلى موفري السحابة الآخرين ، بالشبكات الخاصة. أيضًا ، إذا كنت ترغب في تنفيذ أوامر kubectl من جهازك المحلي مقابل الكتلة الخاصة بك ، يمكنك تحقيق ذلك عن طريق تثبيت kubectl محليًا وسحب .kube/configالملف من المجموعة إلى جهازك المحلي $HOME/.kube/config.

نأمل أن يساعدك هذا الدليل على اجتياز kubeadm ويجعلك تلعب مع kubernetes في لمح البصر!

روابط مفيدة:



كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك

استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا

كيفية تثبيت CMS أكتوبر على CentOS 7

كيفية تثبيت CMS أكتوبر على CentOS 7

أكتوبر هو نظام إدارة محتوى مفتوح المصدر يعتمد على Laravel PHP Framework. مع واجهة أنيقة وبنية وحدات موجزة

قم بتثبيت RockMongo على CentOS 7

قم بتثبيت RockMongo على CentOS 7

RockMongo هي أداة إدارة MongoDB على الويب تشبه أداة إدارة MySQL: phpMyAdmin. سيغطي هذا البرنامج التعليمي عملية التثبيت

كيفية نشر Lets Chat Server على CentOS 7

كيفية نشر Lets Chat Server على CentOS 7

Lets Chat هو تطبيق دردشة مفتوح المصدر مصمم لتوفير خدمة الرسائل ذاتية الاستضافة للفرق الصغيرة. يعتمد Lets Chat على NodeJS و MongoDB

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

كيفية تثبيت أداة إدارة مشروع Taiga على CentOS 7

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

كيفية تثبيت المجدول المحجوز على CentOS 7

كيفية تثبيت المجدول المحجوز على CentOS 7

استخدام نظام مختلف؟ المتطلبات الأساسية مثيل خادم Vultr CentOS 7. مستخدم sudo. الخطوة 1: تحديث النظام أولاً ، قم بتحديث خادم النظام الخاص بك إلى th

تثبيت Netdata على CentOS 7

تثبيت Netdata على CentOS 7

استخدام نظام مختلف؟ Netdata هي نجمة صاعدة في مجال مراقبة مقاييس النظام في الوقت الفعلي. مقارنة بالأدوات الأخرى من نفس النوع ، Netdata:

كيفية تثبيت DreamFactory Open Source على CentOS 7

كيفية تثبيت DreamFactory Open Source على CentOS 7

DreamFactory هو برنامج مفتوح المصدر يمكنه تحويل أي قاعدة بيانات إلى منصة RESTful API. يمكن نشر DreamFactory على منصات مختلفة. في ثي

كيفية تثبيت خادم Starbound على CentOS 7

كيفية تثبيت خادم Starbound على CentOS 7

استخدام نظام مختلف؟ في هذا البرنامج التعليمي ، سأشرح لك كيفية إعداد خادم Starbound على CentOS 7. المتطلبات الأساسية يجب أن تمتلك هذه اللعبة عليك

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب

كيفية تثبيت Django على CentOS 7

كيفية تثبيت Django على CentOS 7

Django هو إطار Python شائع لكتابة تطبيقات الويب. مع Django ، يمكنك بناء التطبيقات بشكل أسرع ، دون إعادة اختراع العجلة. إذا كنت تريد

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

قم بإعداد خادم SA-MP San Andreas متعدد اللاعبين على CentOS 6

مرحبًا بك في برنامج تعليمي Vultr آخر. هنا ، ستتعلم كيفية تثبيت خادم SAMP وتشغيله. تمت كتابة هذا الدليل الخاص بـ CentOS 6. المتطلبات الأساسية التي ستحتاج إليها

تثبيت Revive Adserver على CentOS 7

تثبيت Revive Adserver على CentOS 7

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

قم بتثبيت Elgg على CentOS 7

قم بتثبيت Elgg على CentOS 7

استخدام نظام مختلف؟ Elgg هو محرك تواصل اجتماعي مفتوح المصدر يسمح بإنشاء بيئات اجتماعية مثل الشبكات الاجتماعية في الحرم الجامعي

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

قم ببناء شبكتك الاجتماعية مع الشتات على CentOS 7

استخدام نظام مختلف؟ الشتات هو شبكة اجتماعية مفتوحة المصدر تدرك الخصوصية. في هذا البرنامج التعليمي ، ستتعلم كيفية إعداد وتكوين po Diaspora po

قم بإعداد Sails.js للتطوير على CentOS 7

قم بإعداد Sails.js للتطوير على CentOS 7

استخدام نظام مختلف؟ مقدمة Sails.js هو إطار عمل MVC لـ Node.js ، مشابه لـ Ruby on Rails. يجعل لتطوير التطبيقات الحديثة ver

كيفية تجميع Nginx من المصدر على CentOS 7

كيفية تجميع Nginx من المصدر على CentOS 7

استخدام نظام مختلف؟ يمكن استخدام NGINX كخادم HTTP / HTTPS أو خادم وكيل عكسي أو خادم وكيل بريد أو موازن تحميل أو فاصل TLS أو ذاكرة تخزين مؤقت

كيفية تثبيت dotCMS على CentOS 7

كيفية تثبيت dotCMS على CentOS 7

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

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

كيفية تثبيت PufferPanel (لوحة تحكم Minecraft المجانية) على CentOS 7

مقدمة في هذا البرنامج التعليمي ، سيتم تثبيت PufferPanel على Vultr VPS. PufferPanel هي لوحة تحكم مفتوحة المصدر مجانية للاستخدام لإدارتك

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

6 أشياء شديدة الجنون حول نينتندو سويتش

6 أشياء شديدة الجنون حول نينتندو سويتش

يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.

وظائف طبقات معمارية مرجعية للبيانات الضخمة

وظائف طبقات معمارية مرجعية للبيانات الضخمة

اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

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

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد