Node.js CPU load balancing

后端 未结 3 1772
时光说笑
时光说笑 2021-02-10 03:09

I created test with JMeter to test performance of Ghost blogging platform. Ghost written in Node.js and was installed in cloud server with 1Gb RAM, 1 CPU.

I noticed aft

相关标签:
3条回答
  • 2021-02-10 03:44

    Are you using cluster module to load-balance and Node 0.10.x?

    If that's so, please update your node.js to 0.11.x.

    Node 0.10.x was using balancing algorithm provided by an operating system. In 0.11.x the algorithm was changed, so it will be more evenly distributed from now on.

    0 讨论(0)
  • 2021-02-10 03:51

    Use cluster core and for load balancing nginx. Thats bad part about node.js. Fantastic framework, but developer has to enter into load balancing mess. While java and other runtimes makes is seamless. Anyway, nothing is perfect.

    0 讨论(0)
  • 2021-02-10 04:02

    Node.js is famously single-threaded (see this answer): a single node process will only use one core (see this answer for a more in-depth look), which is why you see that your program fully uses one core, and that all other cores are idle.

    The usual solution is to use the cluster core module of Node, which helps you launch a cluster of Node processes to handle the load, by allowing you to create child processes that all share the same server ports.

    However, you can't really use this without fixing Ghost's code. An option is to use pm2, which can wrap a node program, by using the cluster module for you. For instance, with four cores:

    $ pm2 start app.js -i 4
    

    In theory this should work, except if Ghost relies on some global variables (that can't be shared by every process).

    0 讨论(0)
提交回复
热议问题