สิ่งที่จะทำให้เรายกระดับการเป็น Developer ขึ้นไปอีก ก็คือเราต้องรู้ว่า Code ที่ตัวเองเขียนไปนั้น Perform ยังไงตรงตามที่คาดคิดไว้รึเปล่า รวมถึงมีไอเดียที่จะปรับปรุงให้มันทำงานได้ดียิ่งขึ้น
ซึ่งขั้นตอนที่ขาดไม่ได้สำหรับการวัดประสิทธิภาพของ Code ก็คือ สิ่งที่เรียกว่า Profiling
ซึ่งทาง Node.js Tools for Visual Studio ก็มีเครื่องมือนี้มาให้ด้วย ซึ่งปกติเครื่องมือช่วยการทำ Profiling เราก็เรียกง่ายๆว่า Profiler (Features อื่นๆ อ่านเพิ่มเติมจาก link นะครับ)
ถ้าผมมี Code ตัวอย่าง JavaScript ประมาณนี้
console.log('Hello world'); for (let i = 0; i < 50; ++i){ let rand = getRandomNum(10000000); print(rand, calSum(rand), findDivideBy5(rand)); } function getRandomNum(max) { return Math.floor((Math.random() * max) + 1); } function calSum(num) { let sum = 0; for (let i = 0; i <= num; ++i) { sum += i; } return sum; } function findDivideBy5(num) { let n = 0; for (let i = 0; i <= num; ++i) { if (i % 5 == 0) { n++; } } return n; } function print(rand, sum, count5) { console.log("number : " + rand); console.log("Sum of 0 to " + rand + " is " + sum); console.log("Can divide by 5 count of 0 to " + rand + " is " + count5); console.log("----------------------"); }
Code นี้ทำอะไรบ้าง?
เป็นการสุ่มค่ามาค่านึง (N) แล้วก็
1. หาผลรวมของ 0 ถึง N – function calSum()
2. หาจำนวนของตัวเลขระหว่าง 0 ถึง N ที่หารด้วย 5 ลงตัว – function findDivideby5()
3. แสดงผล – function print()
คำถามคือ Code ตรงไหนช้าที่สุด…เรามาดูกัน
เราสามารถเริ่มการทำ Profiling จากเมนูนี้
เมื่อ app ทำงานจบหรือเราหยุดการทำงานก่อน Visual Studio ก็จะทำการสร้าง Report มาให้เราอย่างละเอียด
เรามาดู Hi-light ที่สำคัญกันครับ
- Code นี้ใช้พลัง CPU ไป ~20% ซึงเครื่องผมมี 4 Cores แล้วว่าทำงานไปเต็มๆ 1 Core
- มาดูระดับ Function กันครับ ปรากฎว่า app.calSum เป็นผู้ชนะไป (หมายความว่าแย่สุด เพราะใช้ CPU ไปเยอะที่สุด)
- นอกจากนี้ยังสามารถดู Call Tree เพื่อที่จะได้รู้ว่าแต่ละ Function ถูกเรียกมาได้ยังไง รวมถึงใช้ CPU ไปมากน้อยเท่าไหร่
เช่น จากตัวอย่าง Top level (หรือ Global) นั้นได้ทำการเรียก function calSum() กับ app.fineDivideby5()
จากตัวอย่างนี้จะเป็นว่าการทำ Profiling นั้น ช่วยให้เราสามารถวิเคาะห์ปัญหาเกี่ยวกับการใช้งาน CPU ได้สะดวกยิ่งขึ้น แต่ทั้งนี้ทั้งนั้น นอกจากการใช้งาน CPU แล้ว สิ่งที่ควรจะทำการ Profile ก็ควรจะมีทั้ง Memory รวมถึง HTTP Resource หรือ Disk I/O ด้วย (แต่เหมือน Visual Studio ยังไม่ Support สำหรับ Node.js มั้งครับ ผมหาไม่เจอ 55)