Edge สำหรับ Private Cloud เวอร์ชัน 4.17.01
เกี่ยวกับปัจจัยการจำลอง Cassandra
Cassandra จะจัดเก็บตัวจำลองข้อมูลไว้ในโหนดต่างๆ เพื่อดูแลให้มีความเสถียรและป้องกันความผิดพลาด กลยุทธ์การจำลองสำหรับคีย์สเปซ Edge แต่ละรายการจะเป็นตัวกำหนดโหนดที่มีการวางตัวจำลอง
จำนวนตัวจำลองทั้งหมดสำหรับคีย์สเปซในคลัสเตอร์ Cassandra จะเรียกว่าปัจจัยการจำลองของคีย์สเปซ ปัจจัยการจำลองของ 1 หมายความว่าแต่ละแถวในคลัสเตอร์ Cassandra จะมีสำเนาเพียง 1 รายการเท่านั้น ปัจจัยการจำลองแบบ 2 หมายความว่ามีสำเนา 2 ชุดของแต่ละแถว โดยที่สำเนาแต่ละรายการอยู่ในโหนดที่ต่างกัน ตัวจำลองทั้งหมดมีความสำคัญเท่ากัน แต่ไม่มีตัวจำลองหลักหรือตัวจำลองต้นแบบ
ในระบบที่ใช้งานจริงที่มีโหนด Cassandra อย่างน้อย 3 โหนดในศูนย์ข้อมูลแต่ละแห่ง ปัจจัยการจำลองเริ่มต้นสำหรับพื้นที่ทำงาน Edge คือ 3 รายการ ตามกฎทั่วไป ปัจจัยการจำลองไม่ควรเกินจำนวนโหนด Cassandra ในคลัสเตอร์
ใช้ขั้นตอนต่อไปนี้เพื่อดูสคีมา Cassandra ซึ่งจะแสดงปัจจัยการจำลองสำหรับคีย์สเปซ Edge แต่ละรายการ
- เข้าสู่ระบบโหนด Cassandra
- เรียกใช้คำสั่งต่อไปนี้
> /opt/apigee/apigee-cassandra/bin/cassandra-cli -h $(hostname -i) <<< "show schema;"
ตำแหน่งที่ $(hostname -i) แก้ไขเป็นที่อยู่ IP ของโหนด Cassandra หรือแทนที่ $(ชื่อโฮสต์ -i) ด้วยที่อยู่ IP ของโหนด
สำหรับแต่ละ Keyspace คุณจะเห็นเอาต์พุตในรูปแบบ:
create keyspace kms with placement_strategy = 'NetworkTopologyStrategy' and strategy_options = {dc-1 : 3} and durable_writes = true;
คุณจะเห็นว่าสำหรับศูนย์ข้อมูล 1, dc-1 ปัจจัยการจำลองเริ่มต้นสำหรับคีย์สเปซ kms คือ 3 สำหรับการติดตั้งที่มีโหนด Cassandra 3 โหนด
หากคุณเพิ่มโหนด Cassandra เพิ่มเติมลงในคลัสเตอร์ ปัจจัยการจำลองเริ่มต้นจะไม่ได้รับผลกระทบ
เช่น หากคุณเพิ่มจำนวนโหนด Cassandra เป็น 6 แต่ทิ้งปัจจัยการจำลองไว้ที่ 3 รายการ คุณไม่ควรตรวจสอบว่าโหนด Cassandra ทั้งหมดมีสำเนาข้อมูลทั้งหมด หากโหนดไม่ทำงาน ปัจจัยการจำลองที่สูงขึ้นหมายถึงความเป็นไปได้ที่สูงขึ้นที่ข้อมูลในโหนดนั้นจะมีอยู่ในโหนดใดโหนดหนึ่งที่เหลืออยู่ ข้อเสียของปัจจัยการจำลองที่สูงขึ้นคือเวลาในการตอบสนองที่เพิ่มขึ้นในการเขียนข้อมูล
เกี่ยวกับระดับความสอดคล้องของ Cassandra
ระดับความสอดคล้องของ Cassandra หมายถึงจำนวนโหนด Cassandra ขั้นต่ำที่ต้องรับทราบการดำเนินการอ่านหรือเขียนก่อนที่จะถือว่าการดำเนินการสำเร็จ คุณกำหนดระดับความสอดคล้องที่แตกต่างกันให้กับแป้น Edge ที่แตกต่างกันได้
เมื่อเชื่อมต่อกับ Cassandra สำหรับการดำเนินการอ่านและเขียน โหนดของผู้ประมวลผลข้อความและเซิร์ฟเวอร์การจัดการมักจะใช้ค่า Cassandra ของ LOCAL_QUORUM เพื่อระบุระดับความสอดคล้องสำหรับคีย์สเปซ อย่างไรก็ตาม คีย์สเปซบางรายการได้รับการกำหนดให้ใช้ระดับที่สอดคล้องกัน 1 รายการ
การคำนวณค่า LOCAL_QUORUM สำหรับศูนย์ข้อมูลจะเท่ากับ
LOCAL_QUORUM = (replication_factor/2) + 1
ตามที่อธิบายไว้ข้างต้น ปัจจัยการจำลองเริ่มต้นสำหรับสภาพแวดล้อมที่ใช้งานจริง Edge ที่มีโหนด Cassandra จำนวน 3 โหนดคือ 3 รายการ ดังนั้น ค่าเริ่มต้นของ LOCAL_QUORUM = (3/2) +1 = 2 (ค่าจะปัดเศษเป็นจำนวนเต็ม)
เมื่อใช้ LOCAL_QUORUM = 2 โหนด Cassandra อย่างน้อย 2 โหนดจาก 3 โหนดในศูนย์ข้อมูลต้องตอบสนองต่อการดำเนินการอ่าน/เขียนเพื่อให้การดำเนินการประสบความสำเร็จ สำหรับคลัสเตอร์ Cassandra แบบ 3 โหนด คลัสเตอร์รองรับจำนวนโหนดที่ลดลง 1 โหนดต่อศูนย์ข้อมูล
เมื่อระบุระดับความสอดคล้องเป็น LOCAL_QUORUM แล้ว Edge จะหลีกเลี่ยงเวลาในการตอบสนองที่ต้องใช้โดยการตรวจสอบการดําเนินการในศูนย์ข้อมูลหลายแห่ง หากคีย์สเปซใช้ค่า Cassandra QUORUM เป็นระดับความสอดคล้อง จะต้องมีการตรวจสอบการดำเนินการอ่าน/เขียนในศูนย์ข้อมูลทั้งหมด
หากต้องการดูระดับความสอดคล้องที่ Edge Message Processor หรือโหนดเซิร์ฟเวอร์การจัดการใช้ ให้ทำดังนี้
- เข้าสู่ระบบโหนดตัวประมวลผลข้อความ
- เปลี่ยนเป็นไดเรกทอรี /opt/apigee/edge-message-processor/conf:
> cd /opt/apigee/edge-message-processor/conf - เพื่อความสอดคล้องในการเขียน
> grep -ri "write.cuniquelevel" * - ดูความสอดคล้องในการอ่านได้
> grep -ri "read.cรวบรวมข้อมูลระดับ" * - เข้าสู่ระบบโหนด Management Server
- เปลี่ยนเป็นไดเรกทอรี /opt/apigee/edge-management-server/conf:
> cd /opt/apigee/edge-management-server/conf - ทำขั้นตอน 3 และ 4 ซ้ำ
หากคุณเพิ่มโหนด Cassandra เพิ่มเติมลงในคลัสเตอร์ ระดับความสอดคล้องจะไม่ได้รับผลกระทบ