ขณะนี้มีปัญหาเล็กน้อยเกี่ยวกับเซิร์ฟเวอร์ของเราซึ่งในตอนนี้ดูเหมือนว่าเราจะได้รับกระบวนการ apache ที่เพิ่งรันและรันโดยใช้ CPU 100%
เมื่อวิ่งขึ้นไปด้านบนเราจะเห็นสิ่งต่อไปนี้:
PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
20788 www-data  20   0  318m  18m 3984 R  100  0.0  40:29.21 /usr/sbin/apache2 -k start
23523 www-data  20   0  319m  20m 4684 R  100  0.0   4:12.36 /usr/sbin/apache2 -k start
ฉันต้องการลองและค้นหาว่าสคริปต์ (หรืออะไรก็ตามที่เป็น) ก่อให้เกิดสิ่งนี้ดังนั้นฉันจึงลอง:
 strace -p 20788
แต่นั่นไม่ได้แสดงผลลัพธ์ใด ๆ เลย (ฉันทิ้งไว้ประมาณ 10 นาทีและไม่แสดงอะไรเลย) จากความเข้าใจของฉันนี่อาจหมายความว่ามันติดอยู่ในวงวนไม่สิ้นสุดและไม่มี "การเรียกของระบบ" ที่จะแสดง
มีอะไรอีกบ้างที่ฉันสามารถทำได้เพื่อแสดงว่าเกิดอะไรขึ้น?
ขอบคุณ
แก้ไข -ลืมพูดถึงนี่เป็นเซิร์ฟเวอร์จริงที่มีผู้ใช้ไม่กี่ร้อยคนในคราวเดียว! ดังนั้นฉันไม่สามารถลองเปลี่ยนตัวเลือกการตั้งค่าและรีสตาร์ท apache ได้อย่างอิสระ
แก้ไข 2 - backtrace (bt) จาก gdb ดูเหมือนจะไม่ทั้งหมดที่มีประโยชน์เมื่อ PHP ไม่ได้กำหนดค่าด้วย --enable-debug - แสดงเฉพาะ "execute ()" แต่ฉันต้องรู้ว่าสคริปต์ PHP คืออะไร ใช้งานจริง .. มีวิธีอื่นอีกไหม?
#0  0x00007f6c143fb0c5 in ?? () from /usr/lib/apache2/modules/libphp5.so
#1  0x00007f6c143b040b in execute () from /usr/lib/apache2/modules/libphp5.so
#2  0x00007f6c1438b970 in zend_execute_scripts () from     /usr/lib/apache2/modules/libphp5.so
#3  0x00007f6c14337fe3 in php_execute_script () from     /usr/lib/apache2/modules/libphp5.so
#4  0x00007f6c1441ae7d in ?? () from /usr/lib/apache2/modules/libphp5.so
#5  0x00007f6c18912508 in ap_run_handler ()
#6  0x00007f6c1891297e in ap_invoke_handler ()
#7  0x00007f6c18922570 in ap_process_request ()
#8  0x00007f6c1891f398 in ?? ()
#9  0x00007f6c18918fa8 in ap_run_process_connection ()
#10 0x00007f6c189271d0 in ?? ()
#11 0x00007f6c1892793a in ?? ()
#12 0x00007f6c189284e7 in ap_mpm_run ()
#13 0x00007f6c188fd4a4 in main ()