![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /proc/self/root/opt/rh/gcc-toolset-11/root/usr/share/systemtap/examples/profiling/ |
#!/opt/rh/gcc-toolset-11/root/usr/bin/stap # usage: fntimes.stp FUNCTIONPROBE # e.g. fntimes.stp 'module("ext4").function("*")' global mincount = 100 # training: beneath this number of hits, only collect data global note_percent = 250 # percent beyond maximum-so-far to generate report for function time() { return gettimeofday_us() } # time measurement function global times function check(t) # t: elapsed time { if (@count(times[ppfunc()]) >= mincount && t >= @max(times[ppfunc()]) * note_percent / 100) { # also consider @avg() printf("function %s well over %s time (%d vs %d), duration variance %d s^2\n", ppfunc(), "maximum", t, @max(times[ppfunc()]), @variance(times[ppfunc()], 3)) # also consider: print_backtrace() } times[ppfunc()] <<< t # (increments @count, updates @max) } probe $1.return { check(time()-@entry(time())) }