ขณะนี้มีปัญหาเล็กน้อยเกี่ยวกับเซิร์ฟเวอร์ของเราซึ่งในตอนนี้ดูเหมือนว่าเราจะได้รับกระบวนการ 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 ()