NUMA Architecture and MySQL

Posted In System - By Tum. On Thursday, October 25th, 2012 With 0 Comments

numa-architecture
NUMA เป็นสถาปัตยกรรมแบบใหม่สำหรับ multiple processor โดยแต่ละ processor (physical) จะมี memory ของตัวเอง ชุดหนึ่ง ซึ่งจะทำให้ processor สามารถเข้าถึง memory ได้รวดเร็วมากกว่าสถปัตยกรรมเก่า
ระบบปฏิบัติการ Linux มีวิธีการจัดการกับ NUMA system อย่างไร

  1. จะมอง hardware ในระดับ physical layer
  2. เรียก processor ว่า node หรือก็คือ 1 node คือ 1 physical processor
  3. แบ่งแต่ละ memory module ให้กับ processor
  4. ข้อมูล cost ในการสื่อสารระหว่าง node

คำสั่งสำหรับการตรวจสอบว่า Linux ใช้งาน memory ในแต่ละ processor เท่าไหร่

จากผลลัพธ์ข้างบน จะแบ่งออกได้เป็น 3 ส่วนคือ

  1. จำนวน node ที่มีอยู่ในระบบ
  2. ขนาด memory ที่กำหนดให้ในแต่ละ node และ ขนาดของ memory ที่ยังว่างในแต่ละ node
  3. Distance คือ cost ของการ access memory ในแต่ละ node

Numa setting for MySQL
สำหรับการนำ Numa มาใช้งานร่วมกับ MySQL เพื่อช่วยเสริมประสิทธิภาพการทำงานของ MySQL ให้มีประสิทธิภาพมากขึ้น และป้องกันการ assign memory ในแต่ละ cpu ไม่เท่ากัน ซึ่งอาจจะสังเกตุได้จาก memory เหลือ แต่ระบบใช้ SWAP เพิ่มขึ้นเรื่อยๆ

การ config ให้ MySQL ใช้ NUMA policy ควบคุมการใช้งาน memory สามารถใช้คำสั่ง numactl เข้ามาควบคุมการเข้าใช้งานได้โดย ให้แก้ไขไฟล์ mysqld_safe ตรงด้านล่างของ

โดยให้ใส่ค่าด้านล่างต่อท้ายด้านบน

Tags: ,

Leave a comment

XHTML: You can use these tags: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code class="" title="" data-url=""> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong> <pre class="" title="" data-url=""> <span class="" title="" data-url="">

*