Singed ซึ่งเป็น Profiler Front-End สำหรับแอปพลิเคชัน Ruby และ Rails
คุณเคยพบว่าตัวเองต้องการที่จะเข้าใจว่าเหตุใดบล็อกของรหัส Ruby คำขอเว็บเฉพาะ หรือการดำเนินการของคอนโทรลเลอร์บางอย่างจึงทำงานช้ามาก? คุณอาจเคยใช้เครื่องมือสร้างโปรไฟล์บางอย่าง เช่น speedscope แต่พบว่ามันยุ่งยาก หรือคุณเคยลองแล้วแต่ไม่เข้าใจวิธีใช้งาน
ขอแนะนำSingedส่วนหน้าโปรไฟล์ใหม่จาก Gusto ที่เขียนโดย Josh Nichols (หรือที่รู้จัก กันในชื่อ @technicalpickles) Singed ถูกสร้างขึ้นเพื่อเป็นฟรอนท์เอนด์ของมีดทหารสวิสสำหรับเครื่องมือต่างๆ ( stackprof , rbspyและspeedscope ) ช่วยให้คุณจับภาพและดูกราฟเปลวเพลิงได้อย่างง่ายดาย โดยที่ก่อนที่คุณจะต้องเขียนสำเร็จรูปจำนวนมากหรือโค้ดชั่วคราวเพื่อเริ่มต้น .
ทำไมต้องใช้เครื่องมือทำโปรไฟล์อื่น
Singed เพิ่มวิธีการใหม่บน Kernel ซึ่งใช้ได้ทุกที่:
flamegraph {
# your code here
}
โดยพื้นฐานแล้ว นักพัฒนา Ruby ส่วนใหญ่ที่ต้องการดู Flamegraphs ใช้ rack- mini -profilerซึ่งเป็นส่วนหน้าที่ยอดเยี่ยมและใช้งานง่ายสำหรับstackprof เพียงเพิ่ม?pp=flamegraphต่อท้าย URL และ whiz-bang เท่านี้คุณก็เปิด Flamegraph ได้ในเบราว์เซอร์ของคุณแล้ว
อย่างไรก็ตาม เรามักจะต้องการสร้างโปรไฟล์ที่ไม่ใช่เพียง URL ปัจจุบันในแถบการนำทางของเบราว์เซอร์ของเรา
ตัวอย่างเช่น เราอาจต้องการสร้างโปรไฟล์คำขอ GraphQL ซึ่งทำผ่านเกตเวย์เช่น Apollo เราอาจไม่สามารถค้นหา URL ที่Apollo Gatewayใช้ในการส่งคำขอได้อย่างง่ายดาย ดังนั้นจึงเป็นการยากที่จะทำซ้ำและใช้ rack-mini-profiler เพื่อจับภาพเฟลมกราฟ
หรือเราอาจต้องการเพียงแค่โปรไฟล์บล็อกของรหัส Ruby หรืองานเบื้องหลัง หรือแม้แต่การทดสอบ คุณสามารถเขียนโค้ดของคุณเองเพื่อทำสิ่งนี้และเรียกใช้ stackprof ด้วยตัวคุณเอง แต่การใช้สำเร็จรูปไม่กี่บรรทัดที่ดีในการเปลี่ยนเส้นทางเอาต์พุตไปยังไฟล์ จากนั้นคุณยังคงต้องเปิดในเบราว์เซอร์ด้วยตนเอง
ทำไมต้องใช้ Speedscope, Stackprof และ rbspy
โดยพื้นฐานแล้ว Singed นั้นเป็นการห่อหุ้มด้วยเครื่องมือที่แตกต่างกันสามอย่าง:
- Speedscopeวิชวลไลเซอร์แบบเฟลมกราฟ
- stackprofโปรไฟล์สุ่มตัวอย่างสำหรับ Ruby
- rbspyอีกหนึ่งตัวสร้างโปรไฟล์ตัวอย่างสำหรับ Ruby เขียนด้วยภาษา Rust
stackprof เป็นตัวสุ่มตัวอย่างสำหรับ Ruby เป็นส่วนขยาย C สำหรับ Ruby VM ซึ่งหมายความว่าจะต้อง "เริ่มต้น" กับกระบวนการ Ruby ของคุณพร้อมกัน rbspy ทำงานแตกต่างออกไป — มันใช้สิทธิ์ sudo เพื่ออ่านหน่วยความจำของกระบวนการ Ruby จากภายนอก ดังนั้นจึงสามารถแนบกับกระบวนการ Ruby ได้ตลอดเวลา ซึ่งเป็นสาเหตุที่ Singed ใช้มันเพื่อกำหนดโปรไฟล์กระบวนการ Ruby จาก CLI
เครื่องมือสร้างโปรไฟล์ตัวอย่างเช่น stackprof และ rbspy เป็นตัวเลือกที่ดี เนื่องจากปรับขนาดได้ค่อนข้างดีสำหรับโค้ดเบสที่ใหญ่ขึ้น การติดตามผู้สร้างโปรไฟล์ เช่นruby-profมักจะล้มเหลวในระดับ Gusto เนื่องจากมีโค้ดจำนวนมากที่เกี่ยวข้องกับการเรียกใช้แอปพลิเคชันของเรา
ในที่สุด stackprof และ rbspy ได้รับการสนับสนุนมากมายในชุมชน ตัวอย่างเช่น เราไม่ต้องทำการปรับรุ่น Profiler ของเราเองเพื่อให้รองรับ Ruby เวอร์ชันใหม่
ทัวร์ชมคุณลักษณะฉบับย่อ
มาดูกันอย่างรวดเร็วว่า Singed สามารถทำอะไรได้บ้าง วิธีหนึ่งที่ฉันโปรดปรานในการใช้ Singed คือการทำโปรไฟล์บล็อกโค้ดง่ายๆ ในแอพ Rails ของเรา
ตัวอย่างเช่น สมมติว่าฉันต้องการโปรไฟล์งานเบื้องหลัง MyWorker ฉันจะสร้างไฟล์ชื่อ myprofile.rb วางไว้ในรูทแอปพลิเคชัน Rails ของเรา แล้วเพิ่ม:
user = User.first
flamegraph { MyWorker.new.perform(user) }
bin/rails runner myprofile.rb
สิ่งที่พบได้ทั่วไปอีกประการหนึ่งที่ฉันพบเจอกับโปรไฟล์คือบางครั้งการตั้งค่าสถานะที่จำเป็นสำหรับโปรไฟล์ชิ้นส่วนของโค้ดนั้นค่อนข้างซับซ้อนในบางครั้ง บางทีคุณอาจต้องการสถานะฐานข้อมูลที่เฉพาะเจาะจงมาก หรือต้องเรียกใช้โค้ดจำนวนมากก่อน บ่อยครั้งที่การตั้งค่านี้มีอยู่แล้วในการทดสอบของเรา
Singed ทำให้การจัดทำโปรไฟล์การทดสอบเป็นเรื่องง่าย ซึ่งหมายความว่าคุณสามารถกำหนดโปรไฟล์และเพิ่มประสิทธิภาพชุดทดสอบของคุณได้ แต่จริงๆ แล้วฉันพบว่ามีประโยชน์มากกว่าสำหรับโค้ดการทำโปรไฟล์ที่ต้องการการตั้งค่าเฉพาะจำนวนมาก:
require 'singed/rspec'
RSpec.describe YourClass do
it "is slow :(", flamegraph: true do
# your code here
end
end
กรณีการใช้งานอื่นสำหรับ Singed คือคำขอการทำโปรไฟล์ ที่ Gusto เรามีเกตเวย์ GraphQL (Apollo) ที่ส่งคำขอไปยังแบ็กเอนด์ Rails ของเรา บางครั้งฉันต้องการสร้างโปรไฟล์คำขอเหล่านั้น แต่ค่อนข้างยากที่จะทำกับ rack-mini-profiler เพราะฉันไม่ทราบ URL และเนื้อหาคำขอที่แบ็กเอนด์ของ Apollo ส่งไปยัง Rails แต่กับ Singed สิ่งที่ฉันทำคือ:
- ทริกเกอร์คำขอส่วนหลัง GraphQL จากส่วนหน้า
- ใน Chrome DevTools ฉันคัดลอกคำขอนั้น "เป็นการดึงข้อมูล" สิ่งนี้ทำให้ฉันสามารถวางลงในคอนโซล Javascript และเรียกใช้คำขอ GraphQL นี้ตามความต้องการ
- ฉันหยุดและรีสตาร์ทเซิร์ฟเวอร์ส่วนหลัง ครั้งนี้เพิ่มตัวแปรสภาพแวดล้อม SINGED_MIDDLEWARE_ALWAYS_CAPTURE=1
- ฉันทริกเกอร์คำขออีกครั้งในคอนโซล Javascript
คุณยังสามารถโปรไฟล์การบูตแอปพลิเคชัน Rails ได้อย่างง่ายดาย:
bundle binstub singed
bin/singed -- bin/rails runner 'true'
ส่วนหน้า Profiler พร้อมการใช้งานมากมาย
หวังว่าฉันจะโน้มน้าวให้คุณลองใช้ Singed ฉันใช้มันเกือบทุกวันที่ Gusto
หากคุณพบว่าสิ่งนี้น่าสนใจลองดูที่ GitHub