วิธีใช้ Kubernetes nodeSelector

Withi Chi Kubernetes Nodeselector



คลัสเตอร์ Kubernetes ใช้ข้อจำกัดในการกำหนดเวลา เช่น taints, label, tolerations และ nodeSelector เพื่อแยกและกำหนดเวลาปริมาณงานบน Node Pool ต่างๆ ข้อจำกัดด้านการจัดกำหนดการเป็นข้อกำหนดทั่วไปใน Kubernetes สำหรับการจัดการโครงสร้างพื้นฐาน เราจะมุ่งเน้นไปที่ข้อ จำกัด การตั้งเวลา nodeSelector ในบทความนี้ เราจะสำรวจว่า nodeSelector คืออะไร ทำงานอย่างไร และจะใช้งานใน Kubernetes ได้อย่างไร เราจะนำเสนอสถานการณ์ง่ายๆ เพื่อช่วยให้คุณเข้าใจวิธีใช้ Kubernetes nodeSelector อย่างมีประสิทธิภาพ

Kubernetes nodeSelector คืออะไร

nodeSelector คือข้อจำกัดการจัดกำหนดการใน Kubernetes ซึ่งระบุแมปในรูปแบบของคีย์: ตัวเลือกพ็อดที่กำหนดเองสำหรับคู่ค่าและป้ายกำกับโหนดใช้เพื่อกำหนดคู่คีย์และค่า nodeSelector ที่มีป้ายกำกับบนโหนดควรจับคู่กับคีย์: คู่ค่า เพื่อให้พ็อดบางตัวสามารถทำงานบนโหนดเฉพาะได้ ในการกำหนดเวลาพ็อด จะใช้เลเบลบนโหนด และใช้ nodeSelectors บนพ็อด OpenShift Container Platform ตั้งเวลาพ็อดบนโหนดโดยใช้ nodeSelector โดยจับคู่เลเบล

นอกจากนี้ ป้ายกำกับและ nodeSelector ยังใช้เพื่อควบคุมพ็อดที่จะกำหนดเวลาบนโหนดเฉพาะ เมื่อคุณใช้ป้ายกำกับและ nodeSelector ให้ติดป้ายกำกับโหนดก่อน เพื่อไม่ให้พ็อดถูกยกเลิกกำหนดการ แล้วจึงเพิ่ม nodeSelector ลงในพ็อด ในการวางพ็อดบางอย่างบนโหนดหนึ่งๆ จะใช้ nodeSelector ในขณะที่ nodeSelector ทั่วทั้งคลัสเตอร์จะให้คุณวางพ็อดใหม่บนโหนดหนึ่งๆ ที่มีอยู่ที่ใดก็ได้ในคลัสเตอร์ nodeSelector ของโปรเจ็กต์ใช้เพื่อวางพ็อดใหม่บนโหนดหนึ่งๆ ของโปรเจ็กต์







ข้อกำหนดเบื้องต้น

หากต้องการใช้ Kubernetes nodeSelector ตรวจสอบให้แน่ใจว่าคุณได้ติดตั้งเครื่องมือต่อไปนี้ในระบบของคุณ:



  • Ubuntu 20.04 หรือเวอร์ชันล่าสุดอื่น ๆ
  • คลัสเตอร์ Minikube ที่มีโหนดผู้ปฏิบัติงานอย่างน้อยหนึ่งโหนด
  • เครื่องมือบรรทัดคำสั่ง Kubectl

ตอนนี้ เรากำลังย้ายไปยังส่วนถัดไปที่เราจะสาธิตวิธีการใช้ nodeSelector บนคลัสเตอร์ Kubernetes



การกำหนดค่า nodeSelector ใน Kubernetes

พ็อดสามารถถูกจำกัดให้สามารถรันบนโหนดที่ระบุได้เท่านั้นโดยใช้ nodeSelector nodeSelector เป็นข้อจำกัดการเลือกโหนดที่ระบุไว้ใน PodSpec ข้อมูลจำเพาะของพ็อด พูดง่ายๆ ก็คือ nodeSelector เป็นคุณลักษณะการจัดกำหนดการที่ให้คุณควบคุมพ็อดเพื่อกำหนดเวลาพ็อดบนโหนดที่มีป้ายชื่อเดียวกันกับที่ผู้ใช้ระบุสำหรับป้าย nodeSelector หากต้องการใช้หรือกำหนดค่า nodeSelector ใน Kubernetes คุณต้องมีคลัสเตอร์ minikube เริ่มคลัสเตอร์ minikube ด้วยคำสั่งด้านล่าง:





> เริ่ม minikube

เมื่อเริ่มคลัสเตอร์ minikube สำเร็จแล้ว เราสามารถเริ่มใช้งานการกำหนดค่าของ nodeSelector ใน Kubernetes ได้ ในเอกสารนี้ เราจะแนะนำให้คุณสร้างการปรับใช้สองแบบ แบบหนึ่งไม่มี nodeSelector และอีกแบบหนึ่งแบบใช้ nodeSelector



กำหนดค่าการปรับใช้โดยไม่มี nodeSelector

ก่อนอื่น เราจะแยกรายละเอียดของโหนดทั้งหมดที่กำลังใช้งานอยู่ในคลัสเตอร์โดยใช้คำสั่งที่ระบุด้านล่าง:

> kubectl รับโหนด

คำสั่งนี้จะแสดงรายการโหนดทั้งหมดที่มีอยู่ในคลัสเตอร์โดยมีรายละเอียดของพารามิเตอร์ชื่อ สถานะ บทบาท อายุ และเวอร์ชัน ดูผลลัพธ์ตัวอย่างที่ระบุด้านล่าง:

ตอนนี้ เราจะตรวจสอบว่าเทนต์ใดที่ใช้งานอยู่บนโหนดในคลัสเตอร์ เพื่อให้เราสามารถวางแผนปรับใช้พ็อดบนโหนดได้ คำสั่งที่ระบุด้านล่างจะใช้เพื่อรับคำอธิบายของ taints ที่ใช้กับโหนด ไม่ควรมีจุดบกพร่องที่ใช้งานอยู่บนโหนด เพื่อให้สามารถติดตั้งพ็อดได้อย่างง่ายดาย ดังนั้น ให้เราดูว่า taints ใดที่ใช้งานอยู่ในคลัสเตอร์โดยดำเนินการคำสั่งต่อไปนี้:

> kubectl อธิบายโหนด minikube | จับ มัวหมอง

จากเอาต์พุตที่ให้ไว้ข้างต้น เราจะเห็นว่าไม่มี taint ที่ใช้บนโหนด ตรงกับสิ่งที่เราต้องการในการปรับใช้พ็อดบนโหนด ตอนนี้ ขั้นตอนต่อไปคือการสร้างการปรับใช้โดยไม่ต้องระบุ nodeSelector ใดๆ ในนั้น สำหรับเรื่องนั้น เราจะใช้ไฟล์ YAML ที่เราจะเก็บการกำหนดค่า nodeSelector คำสั่งที่แนบมาที่นี่จะใช้สำหรับการสร้างไฟล์ YAML:

> นาโน deplond.yaml

ที่นี่ เรากำลังพยายามสร้างไฟล์ YAML ชื่อ deplond.yaml ด้วยคำสั่งนาโน

เมื่อดำเนินการคำสั่งนี้ เราจะมีไฟล์ deplond.yaml ซึ่งเราจะจัดเก็บการกำหนดค่าการปรับใช้ ดูการกำหนดค่าการปรับใช้ที่ระบุด้านล่าง:

ตอนนี้ เราจะสร้างการปรับใช้โดยใช้ไฟล์การกำหนดค่าการปรับใช้ ไฟล์ deplond.yaml จะถูกใช้พร้อมกับคำสั่ง 'create' เพื่อสร้างการกำหนดค่า ดูคำสั่งที่สมบูรณ์ด้านล่าง:

> kubectl สร้าง -ฉ deplond.yaml

ดังที่แสดงไว้ด้านบน การปรับใช้ถูกสร้างขึ้นสำเร็จ แต่ไม่มี nodeSelector ตอนนี้ให้เราตรวจสอบโหนดที่มีอยู่แล้วในคลัสเตอร์ด้วยคำสั่งที่ระบุด้านล่าง:

> kubectl รับพ็อด

ซึ่งจะแสดงรายการพ็อดทั้งหมดที่มีอยู่ในคลัสเตอร์ ดูผลลัพธ์ที่ระบุด้านล่าง:

  คำอธิบายข้อความที่สร้างขึ้นโดยอัตโนมัติ

ต่อไป เราจำเป็นต้องเปลี่ยนจำนวนของเรพลิคา ซึ่งสามารถทำได้โดยการแก้ไขไฟล์ deplond.yaml เพียงเปิดไฟล์ deplond.yaml และแก้ไขค่าของแบบจำลอง ที่นี่ เรากำลังเปลี่ยนแบบจำลอง: 3 เป็นแบบจำลอง: 30 ดูการแก้ไขในภาพรวมที่ระบุด้านล่าง:

ตอนนี้ การเปลี่ยนแปลงจำเป็นต้องนำไปใช้กับการปรับใช้จากไฟล์ข้อกำหนดการปรับใช้ และสามารถทำได้โดยใช้คำสั่งต่อไปนี้:

> kubectl ใช้ -ฉ deplond.yaml

  คำอธิบายข้อความที่สร้างขึ้นโดยอัตโนมัติ

ตอนนี้ ให้เราตรวจสอบรายละเอียดเพิ่มเติมของพ็อดโดยใช้ตัวเลือก -o กว้าง:

> kubectl รับพ็อด -เดอะ กว้าง

  คำอธิบายข้อความที่สร้างขึ้นโดยอัตโนมัติ

จากเอาต์พุตที่ให้ไว้ข้างต้น เราจะเห็นว่าโหนดใหม่ได้รับการสร้างและกำหนดเวลาบนโหนด เนื่องจากไม่มี taint ที่ใช้งานอยู่บนโหนดที่เราใช้จากคลัสเตอร์ ดังนั้นเราจึงจำเป็นต้องเปิดใช้ taint เป็นพิเศษเพื่อให้แน่ใจว่าพ็อดได้รับการกำหนดเวลาบนโหนดที่ต้องการเท่านั้น เพื่อสิ่งนั้น เราจำเป็นต้องสร้างป้ายกำกับบนโหนดหลัก:

> โหนดฉลาก kubectl ต้นแบบ on-master= จริง

กำหนดค่าการปรับใช้ด้วย nodeSelector

ในการกำหนดค่าการปรับใช้ด้วย nodeSelector เราจะทำตามขั้นตอนเดียวกันซึ่งตามมาสำหรับการกำหนดค่าการปรับใช้โดยไม่มี nodeSelector

ก่อนอื่น เราจะสร้างไฟล์ YAML ด้วยคำสั่ง 'nano' ซึ่งเราจำเป็นต้องจัดเก็บการกำหนดค่าของการปรับใช้

> นาโน nd.yaml

ตอนนี้ บันทึกข้อกำหนดการปรับใช้ในไฟล์ คุณสามารถเปรียบเทียบไฟล์การกำหนดค่าทั้งสองไฟล์เพื่อดูความแตกต่างระหว่างข้อกำหนดการกำหนดค่า

ตอนนี้ สร้างการปรับใช้ nodeSelector ด้วยคำสั่งที่ระบุด้านล่าง:

> kubectl สร้าง -ฉ nd.yaml

รับรายละเอียดของพ็อดโดยใช้แฟล็ก -o แบบกว้าง:

> kubectl รับพ็อด -เดอะ กว้าง

  ข้อความ ปฏิทิน คำอธิบายที่สร้างขึ้นโดยอัตโนมัติด้วยความมั่นใจปานกลาง

จากเอาต์พุตที่ให้ไว้ด้านบน เราสังเกตเห็นว่าพ็อดกำลังถูกปรับใช้บนโหนด minikube ให้เราเปลี่ยนจำนวนของแบบจำลองเพื่อตรวจสอบว่าพ็อดใหม่ถูกนำไปใช้งานที่ใดในคลัสเตอร์

ใช้การเปลี่ยนแปลงใหม่ในการปรับใช้โดยใช้คำสั่งต่อไปนี้:

> kubectl ใช้ -ฉ nd.yaml

  คำอธิบายข้อความที่สร้างขึ้นโดยอัตโนมัติ

บทสรุป

ในบทความนี้ เรามีภาพรวมของข้อจำกัดการกำหนดค่า nodeSelector ใน Kubernetes เราได้เรียนรู้ว่า nodeSelector คืออะไรใน Kubernetes และด้วยความช่วยเหลือของสถานการณ์ง่ายๆ เราได้เรียนรู้วิธีสร้างการปรับใช้โดยมีและไม่มีข้อจำกัดการกำหนดค่า nodeSelector คุณสามารถอ้างอิงถึงบทความนี้หากคุณยังใหม่กับแนวคิด nodeSelector และค้นหาข้อมูลที่เกี่ยวข้องทั้งหมด