from Hacker News

Ask HN: Why does Node.js start so slow?

by FreeHugs on 5/24/22, 8:03 AM with 6 comments

time php -r 'echo 123;'

outputs:

    123
    real 0m0.031s
    user 0m0.023s
    sys 0m0.008s


time python3 -c 'print (123)'

outputs:

    123
    
    real 0m0.022s
    user 0m0.019s
    sys 0m0.004s


time node -e 'console.log(123);'

outputs:

    123

    real 0m0.578s
    user 0m0.551s
    sys 0m0.028s


Why is the node version more than 10 times slower than the PHP and Python versions?
  • by efortis on 5/24/22, 8:16 AM

    What's your output for: `which node` and `node -v`

    On my M1 Pro:

        python3 -c 'print (123)'    0.02s user 0.01s system 86% cpu 0.036 total
        node -e 'console.log(123)'  0.04s user 0.01s system 88% cpu 0.053 total
  • by raxxorraxor on 5/24/22, 8:50 AM

    I guess the reason is that the runtime of node is so much larger than that of Python and PHP. I think the Node runtime is already at > 50MB as a binary.

    I don't know how large Python and PHP runtimes are, but I know python is often stripped down to a few kilobytes for embedded systems.

    I guess if you preload the runtimes before executing these commands, the execution should be fairly similar for each one (near zero, more depending on I/O).