เกี่ยวกับการบํารุงรักษา ZooKeeper

Edge สำหรับ Private Cloud เวอร์ชัน 4.17.09

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

เกี่ยวกับ ZooKeeper และ Edge

ใน Edge โหนด ZooKeeper จะมีข้อมูลการกำหนดค่าเกี่ยวกับตำแหน่งและการกำหนดค่าของคอมโพเนนต์ Edge ต่างๆ และจะแจ้งคอมโพเนนต์ต่างๆ ของการเปลี่ยนแปลงการกำหนดค่า โทโพโลยี Edge ที่รองรับทั้งหมดสำหรับระบบที่ใช้งานจริงระบุว่าให้ใช้โหนด ZooKeeper อย่างน้อย 3 รายการ

ใช้พร็อพเพอร์ตี้ ZK_HOSTS และ ZK_CLIENT_HOSTS ในไฟล์การกำหนดค่า Edge เพื่อระบุโหนด ZooKeeper สำหรับการสอบ

ZK_HOSTS="$IP1 $IP2 $IP3"
ZK_CLIENT_HOSTS="$IP1 $IP2 $IP3"

ที่ไหน

  • ZK_HOSTS - ระบุที่อยู่ IP ของโหนด ZooKeeper ที่อยู่ IP ต้องเรียงลำดับเหมือนกันในโหนด ZooKeeper ทั้งหมด

    ในสภาพแวดล้อมของศูนย์ข้อมูลหลายแหล่ง ให้แสดงรายการโหนด ZooKeeper ทั้งหมดจากศูนย์ข้อมูลทั้งหมด
  • ZK_CLIENT_HOSTS - ระบุที่อยู่ IP ของโหนด ZooKeeper ที่ใช้โดยศูนย์ข้อมูลนี้เท่านั้น ที่อยู่ IP ต้องอยู่ในลำดับเดียวกันบนโหนด ZooKeeper ทั้งหมดในศูนย์ข้อมูล

    ในการติดตั้งศูนย์ข้อมูลเดียว โหนดเหล่านี้เป็นโหนดเดียวกับที่ระบุโดย ZK_HOSTS ในสภาพแวดล้อมของศูนย์ข้อมูลหลายแหล่ง ไฟล์การกำหนดค่า Edge สำหรับแต่ละศูนย์ข้อมูลควรแสดงเฉพาะโหนด ZooKeeper ของศูนย์ข้อมูลดังกล่าว

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

โดยปกติแล้ว คุณจะระบุตัวแก้ไข ":observer" เมื่อสร้างศูนย์ข้อมูล Edge หลายแห่ง หรือเมื่อศูนย์ข้อมูลหนึ่งมีโหนด ZooKeeper จำนวนมาก เช่น ในการติดตั้ง Edge 12 โฮสต์ที่มีศูนย์ข้อมูล 2 แห่ง ZooKeeper บนโหนด 9 ในศูนย์ข้อมูล 2 จะเป็นผู้สังเกตการณ์

จากนั้นใช้การตั้งค่าต่อไปนี้ในไฟล์การกำหนดค่าสำหรับศูนย์ข้อมูล 1

ZK_HOSTS="$IP1 $IP2 $IP3 $IP7 $IP8 $IP9:observer"
ZK_CLIENT_HOSTS="$IP1 $IP2 $IP3"

และสำหรับศูนย์ข้อมูล

ZK_HOSTS="$IP1 $IP2 $IP3 $IP7 $IP8 $IP9:observer"
ZK_CLIENT_HOSTS="$IP7 $IP8 $IP9"

เกี่ยวกับผู้นำ ผู้ติดตาม ผู้ลงคะแนนเสียง และผู้สังเกตการณ์

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

เวลาติดตั้ง Edge คุณจะกําหนดโหนด ZooKeeper แต่ละรายการเป็นผู้โหวตหรือเป็นผู้สังเกตการณ์ จากนั้นโหนด ZooKeeper ของผู้โหวตทั้งหมดจะได้รับการเลือกตั้งผู้นำ ข้อกำหนดหนึ่งสำหรับการเลือกตั้งผู้นำคือต้องมีquorumของโหนดผู้มีสิทธิเลือกตั้ง ZooKeeper ที่ใช้งานได้ โควต้าหมายความว่าโหนด ZooKeeper ของผู้มีสิทธิเลือกตั้งมากกว่าครึ่งหนึ่งของศูนย์ข้อมูลทั้งหมดใช้งานได้

ถ้ายังไม่มีจำนวนโหนดของผู้มีสิทธิเลือกตั้งเลย ก็จะไม่สามารถเลือกผู้นำได้ ในสถานการณ์นี้ Zookeeper แสดงคําขอไม่ได้ ซึ่งหมายความว่าคุณจะส่งคำขอไปยังเซิร์ฟเวอร์ Edge Management, ประมวลผลคำขอ Management API หรือเข้าสู่ระบบ Edge UI ไม่ได้จนกว่าจะกู้คืนโควต้า

ตัวอย่างเช่น ในการติดตั้งศูนย์ข้อมูลเดียว:

  • คุณติดตั้งโหนด ZooKeeper 3 รายการ
  • โหนด ZooKeeper ทั้งหมดเป็นผู้โหวต
  • โควต้าคือโหนดของผู้มีสิทธิเลือกตั้งที่ทำงานได้ 2 โหนด
  • หากมีโหนดผู้โหวตเพียง 1 โหนด ชุด ZooKeeper จะไม่ทำงาน

ในการติดตั้งด้วยศูนย์ข้อมูล 2 แห่ง:

  • คุณติดตั้งโหนด ZooKeeper 3 รายการต่อศูนย์ข้อมูล รวมทั้งหมด 6 โหนด
  • ศูนย์ข้อมูล 1 มีโหนดผู้โหวต 3 โหนด
  • ศูนย์ข้อมูล 2 มีโหนดผู้โหวต 2 โหนดและโหนดผู้สังเกตการณ์ 1 โหนด
  • โควต้าจะขึ้นอยู่กับผู้โหวต 5 คนในศูนย์ข้อมูลทั้ง 2 แห่ง จึงเป็นโหนดผู้มีสิทธิเลือกตั้ง 3 โหนด
  • หากมีโหนดผู้โหวตเพียง 2 โหนดหรือน้อยกว่า ชุด ZooKeeper จะไม่ทำงาน

การเพิ่มโหนดในฐานะผู้ลงคะแนนหรือผู้สังเกตการณ์

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

คุณต้องการตรวจสอบว่ามีโหนดผู้เลือกตั้งเพียงพอ เพื่อที่ว่าเมื่อโหนดของผู้โหวตอย่างน้อย 1 รายการหยุดทำงาน กลุ่ม ZooKeeper จะยังคงทำงานได้ ซึ่งหมายความว่ายังคงมีจำนวนโหนดของผู้มีสิทธิเลือกตั้ง เหลืออยู่ การเพิ่มโหนดผู้มีสิทธิเลือกตั้งจะช่วยเพิ่มขนาดโควต้า คุณจึงทนให้โหนดของผู้มีสิทธิเลือกตั้งลดลงได้

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

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

ในศูนย์ข้อมูลแห่งเดียว Apigee แนะนำให้มีผู้มีสิทธิ์เลือกตั้งไม่เกิน 5 คน โดยไม่คำนึงถึงจำนวนโหนดผู้สังเกตการณ์ Apigee ในศูนย์ข้อมูล 2 แห่ง แนะนำให้คุณไม่มีผู้โหวตเกิน 9 คน (5 คนในศูนย์ข้อมูล 1 แห่งและอีก 4 คน) จากนั้นคุณจะเพิ่มโหนดผู้สังเกตการณ์ได้มากเท่าที่จำเป็นสำหรับข้อกำหนดของระบบ

ข้อควรพิจารณาในการบำรุงรักษา

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

การบำรุงรักษาใน ศูนย์ข้อมูลหลายแห่ง

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

ตําแหน่งของโหนดผู้โหวตในศูนย์ข้อมูลที่ระบุไม่ใช่ปัจจัยเมื่อ ZooKeeper คํานวณโควต้า แต่ละโหนดอาจลงไปอยู่ในศูนย์ข้อมูลต่างๆ ได้ แต่ตราบใดที่ยังมีการเก็บรักษาโควต้าไว้ทั่วทั้งกลุ่ม จากนั้น ZooKeeper ก็จะยังคงทำงานได้ต่อไป

ผลการบำรุงรักษา

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

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

ขั้นตอนการบำรุงรักษา

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

เมื่อตรงตามเงื่อนไขเหล่านี้ ชุดของ ZooKeeper ที่มีขนาดที่กำหนดเองจะยอมรับการสูญเสียโหนดนี้ ณ จุดใดก็ได้โดยไม่มีการสูญเสียข้อมูลหรือผลกระทบที่มีความหมายต่อประสิทธิภาพ ซึ่งหมายความว่าคุณจะทำการบำรุงรักษาในโหนดใดก็ได้ในชุด ตราบใดที่ยังอยู่ในโหนดเดียว

ในขั้นตอนการบำรุงรักษา โปรดใช้ขั้นตอนต่อไปนี้เพื่อระบุประเภทโหนด ZooKeeper (ผู้นำ ผู้มีสิทธิเลือกตั้ง หรือผู้สังเกตการณ์)

  1. หากไม่ได้ติดตั้งในโหนด ZooKeeper ให้ติดตั้ง nc:
    > sudo yum install nc
  2. เรียกใช้คำสั่ง nc ต่อไปนี้ในโหนด
    > echo stat | nc localhost 2181

    โดย 2181 คือพอร์ต ZooKeeper คุณควรเห็นเอาต์พุตในรูปแบบ
    Zookeeper version: 3.4.5-1392090 มีค่าตามหลัง Zookeeper: 3.5-1392090
    บรรทัด 09/30/2012 17:52 GMT
    Clients: /a.b.c.d:xxxx[0](queued=0,recved=1,Outsent=0)
    เวลาในการตอบสนอง min/maxid










    หมายเหตุ: ในการติดตั้ง Edge แบบสแตนด์อโลนที่มีโหนด ZooKeeper เดี่ยว ระบบจะตั้งค่าโหมดเป็นสแตนด์อโลน
  3. ทำขั้นตอนที่ 1 และ 2 ซ้ำในโหนด ZooKeeper แต่ละรายการ

สรุป

วิธีที่ดีที่สุดในการบำรุงรักษาชุด ZooKeeper คือการดำเนินการครั้งละ 1 โหนด ข้อควรจำ:

  • คุณต้องรักษาจำนวนโหนดของผู้มีสิทธิเลือกตั้งไว้ระหว่างการบำรุงรักษาเพื่อให้ชุด ZooKeeper ทำงานได้อย่างต่อเนื่อง
  • การลบโหนดผู้สังเกตการณ์ไม่มีผลต่อควอมหรือความสามารถในการเลือกผู้นำ
  • ระบบจะคำนวณโควต้าจากโหนด ZooKeeper ทั้งหมดในศูนย์ข้อมูลทั้งหมด
  • ดำเนินการบำรุงรักษาเซิร์ฟเวอร์ถัดไปหลังจากเซิร์ฟเวอร์ก่อนหน้าทำงาน
  • ใช้คำสั่ง nc เพื่อตรวจสอบโหนด ZooKeeper