AAR การจัดการส่วนกินระบบ (Performance Hog)


เมื่อวาน ดร.จันทวรรณ และผมนั่งค้นหาสาเหตุที่ KnowledgeVolution ช้าอืดแถมกินกำลังการประมวลผลและหน่วยความจำมาก

KnowledgeVolution เป็น Rails application ซึ่งเป็น framework ที่เลื่องลือกันว่าไม่กินทรัพยากรระบบเท่าไหร่เลย แล้วทำไมระบบเราถึงกินจัง? หรือ Rails ไม่ได้ดีอย่างที่เขาเลื่องลือ เพราะนี่ก็เป็น Rails application ตัวแรกของเรา เราหลงใช้ framework ผิดหรือเปล่านี่?

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

เริ่มจากเรื่องการกินหน่วยความจำ เราก็ดูจาก Ruby modules ที่เราใช้พิเศษจาก Rails ปกติได้แก่ RMagick และ Ruby-Tidy ครับ

RMagick นั่นมีชื่อเสียงในแง่ว่ากินหน่วยความจำ เราก็ได้แก้ไขไปแล้ว ลดการกินลงมาหน่อย แต่ Tidy นี่จริงๆ แล้วไม่น่าจะเป็นผู้ต้องสงสัยเลย เพราะ Tidy เป็น library ที่เล็กจะตาย

ปรากฎว่าการใช้ Tidy นี่ละตัวร้าย ตัว Tidy ในฐานะ C library เองไม่มีปัญหาหรอก แต่ Ruby-Tidy ซึ่งเป็น Ruby module ที่ติดต่อกับ Tidy นี่สิ เขียนได้ไม่ดีและกินทั้งหน่วยความจำและกำลังการประมวลผล แต่เราก็อยากใช้เลยพยายาม optimize ให้เป็นไปได้ ปรากฎว่าเกินกำลังครับ ท่าน Tidy “กิน” จริงๆ เลยสรุปว่าต้องเลิกใช้ รอให้ Ruby-Tidy ปรับปรุงให้ดีกว่านี้หน่อย พอเลิกใช้ Tidy ระบบจากที่ load อยู่ 80-90% ก็กลับมาวิ่งฉิวเหมือนไม่มี load อะไรเลย

เรื่องต่อมาก็คือการไล่เก็บพวก hotlinks ต่างๆ ที่ใช้ GotoKnow.org เป็นที่เก็บไฟล์ อันนี้ก็ดักเรียบร้อย ไม่มีปัญหา ถ้า hotlink มาหารูปจากที่อื่น เราก็จะคืน 404 File Not Found ไป

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

นอกจากสองเรื่องดังกล่าวแล้ว เรายัง optimize โปรแกรมในส่วนต่างๆ อีกหลายจุดด้วยกัน เรียกว่าทำงานกันข้ามคืนทีเดียว แต่หลังจากเรียบร้อยแล้วก็ได้ KnowledgeVolution ที่วิ่งฉิวสมใจ นับว่าคุ้มค่าในการทุ่มเวลา ได้ GotoKnow.org ที่มีความเร็วให้ผู้ใช้สามารถใช้งานได้อย่างเต็มที่ในวันมหามงคลในวันนี้ครับ

หมายเลขบันทึก: 33477เขียนเมื่อ 9 มิถุนายน 2006 19:38 น. ()แก้ไขเมื่อ 11 กุมภาพันธ์ 2012 15:07 น. ()สัญญาอนุญาต: จำนวนที่อ่าน


ความเห็น
ในช่วง AAR ไปนั่งคุยกันให้ bloggers ฟังในวันที่ 15 มิย. ดีไหมอาจารย์ บรรยากาศเป็นอันเอง สบายสบาย :)
เห็นด้วยค่ะ ที่อาจารย์จัน กับ อ.ธวัชชัยจะได้เล่าให้พวกเราฟังในวันที่ 15 มิ.ย นี้ค่ะ เราจะได้เป็นกระบอกเสียงให้ต่อๆกันไปด้วย มีคนรอให้กำลังใจอาจารย์ทั้งคู่อยู่มากมายค่ะ งานหนักขนาดนี้ serve พวกเราอย่างล้นเหลือ ไม่บอกกล่าวรายละเอียดไม่ได้หรอกค่ะ จะได้เก็บไว้เป็นประวัติศาสตร์คลังความรู้ของเมืองไทยด้วยนะคะ

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

... แต่เสียดายในส่วนที่ แสดงความคิดเห็นล่าสุด ครั้งก่อนจะอยู่ด้านขวาล่างให้เลย เข้ามาก็เห็นเลย ... ครั้งนี้จะต้องคลิ๊กเข้าไปหาอีกที แต่คงไม่เป็นไรหรอกค่ะ เพราะว่าถ้าตัดความอืดออกไปแล้ว ก็คงจะไวขึ้น (คราวที่แล้ว ก้อทำไปหยุดทำไป เพราะความอืด และหลุดบ่อย นี่ละค่ะ)

  • ส่งกำลังใจมาให้อาจารย์ทั้ง 2 ท่านครับผม
พบปัญหาการใช้งานกรุณาแจ้ง LINE ID @gotoknow
ClassStart
ระบบจัดการการเรียนการสอนผ่านอินเทอร์เน็ต
ทั้งเว็บทั้งแอปใช้งานฟรี
ClassStart Books
โครงการหนังสือจากคลาสสตาร์ท