mirror of https://github.com/nodejs/node.git
6ebd85e105
Reduce the overhead of the CPU profiler by replacing sched_yield() with nanosleep() in V8's tick event processor thread. The former only yields the CPU when there is another process scheduled on the same CPU. Before this commit, the thread would effectively busy loop and consume 100% CPU time. By forcing a one nanosecond sleep period rounded up to the task scheduler's granularity (about 50 us on Linux), CPU usage for the processor thread now hovers around 10-20% for a busy application. PR-URL: https://github.com/joyent/node/pull/8789 Ref: https://github.com/strongloop/strong-agent/issues/3 Reviewed-by: Trevor Norris <trev.norris@gmail.com> |
||
---|---|---|
.. | ||
gcmole | ||
gyp | ||
oom_dump | ||
testrunner | ||
visual_studio | ||
android-build.sh | ||
android-ll-prof.sh | ||
android-run.py | ||
android-sync.sh | ||
bash-completion.sh | ||
check-static-initializers.sh | ||
codemap.js | ||
common-includes.sh | ||
consarray.js | ||
csvparser.js | ||
disasm.py | ||
freebsd-tick-processor | ||
fuzz-harness.sh | ||
gc-nvp-trace-processor.py | ||
gdb-v8-support.py | ||
gen-postmortem-metadata.py | ||
generate-ten-powers.scm | ||
grokdump.py | ||
js2c.py | ||
jsmin.py | ||
linux-tick-processor | ||
ll_prof.py | ||
logreader.js | ||
mac-nm | ||
mac-tick-processor | ||
merge-to-branch.sh | ||
presubmit.py | ||
process-heap-prof.py | ||
profile.js | ||
profile_view.js | ||
push-to-trunk.sh | ||
run-tests.py | ||
run-valgrind.py | ||
splaytree.js | ||
stats-viewer.py | ||
status-file-converter.py | ||
test-server.py | ||
test-wrapper-gypbuild.py | ||
test.py | ||
tickprocessor-driver.js | ||
tickprocessor.js | ||
utils.py | ||
windows-tick-processor.bat |