HBase - สถาปัตยกรรม

ใน HBase ตารางจะแบ่งออกเป็นภูมิภาคและให้บริการโดยเซิร์ฟเวอร์ภูมิภาค ภูมิภาคต่างๆแบ่งตามแนวตั้งตามตระกูลคอลัมน์เป็น "ร้านค้า" ร้านค้าจะถูกบันทึกเป็นไฟล์ใน HDFS ด้านล่างนี้คือสถาปัตยกรรมของ HBase

Note: คำว่า 'store' ใช้สำหรับภูมิภาคเพื่ออธิบายโครงสร้างการจัดเก็บ

HBase มีองค์ประกอบหลักสามส่วน ได้แก่ ไลบรารีไคลเอ็นต์เซิร์ฟเวอร์หลักและเซิร์ฟเวอร์ภูมิภาค สามารถเพิ่มหรือลบเซิร์ฟเวอร์ภูมิภาคได้ตามความต้องการ

มาสเตอร์เซิร์ฟเวอร์

เซิร์ฟเวอร์หลัก -

  • กำหนดขอบเขตให้กับเซิร์ฟเวอร์ภูมิภาคและรับความช่วยเหลือจาก Apache ZooKeeper สำหรับงานนี้

  • จัดการการทำโหลดบาลานซ์ของภูมิภาคข้ามเซิร์ฟเวอร์ภูมิภาค จะยกเลิกการโหลดเซิร์ฟเวอร์ที่ไม่ว่างและเปลี่ยนภูมิภาคไปยังเซิร์ฟเวอร์ที่มีผู้ใช้น้อย

  • รักษาสถานะของคลัสเตอร์โดยการเจรจาการทำโหลดบาลานซ์

  • รับผิดชอบต่อการเปลี่ยนแปลงสคีมาและการดำเนินการข้อมูลเมตาอื่น ๆ เช่นการสร้างตารางและตระกูลคอลัมน์

ภูมิภาค

ภูมิภาคไม่ใช่อะไรนอกจากตารางที่แยกและกระจายไปทั่วเซิร์ฟเวอร์ภูมิภาค

เซิร์ฟเวอร์ภูมิภาค

เซิร์ฟเวอร์ภูมิภาคมีภูมิภาคที่ -

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

เมื่อเราตรวจสอบอย่างละเอียดยิ่งขึ้นในเซิร์ฟเวอร์ภูมิภาคจะมีภูมิภาคและร้านค้าดังที่แสดงด้านล่าง:

ร้านค้าประกอบด้วยที่เก็บหน่วยความจำและ HFiles Memstore ก็เหมือนกับหน่วยความจำแคช สิ่งใดก็ตามที่ป้อนลงใน HBase จะถูกเก็บไว้ที่นี่ในตอนแรก ต่อมาข้อมูลจะถูกถ่ายโอนและบันทึกใน Hfiles เป็นบล็อกและ memstore จะถูกล้าง

Zookeeper

  • Zookeeper เป็นโครงการโอเพ่นซอร์สที่ให้บริการต่างๆเช่นการดูแลรักษาข้อมูลการกำหนดค่าการตั้งชื่อการซิงโครไนซ์แบบกระจายเป็นต้น

  • Zookeeper มีโหนดชั่วคราวที่แสดงถึงเซิร์ฟเวอร์ภูมิภาคต่างๆ เซิร์ฟเวอร์หลักใช้โหนดเหล่านี้เพื่อค้นหาเซิร์ฟเวอร์ที่พร้อมใช้งาน

  • นอกจากความพร้อมใช้งานแล้วโหนดยังใช้เพื่อติดตามความล้มเหลวของเซิร์ฟเวอร์หรือพาร์ติชันเครือข่าย

  • ลูกค้าสื่อสารกับเซิร์ฟเวอร์ภูมิภาคผ่านทาง Zookeeper

  • ในโหมดหลอกและโหมดสแตนด์อโลน HBase เองจะดูแลผู้ดูแลสวนสัตว์