- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
所以我开始在我正在做的项目中使用 node.js。
当客户端发出请求时,我的 node.js 服务器从另一台服务器获取一个 json,然后将其重新格式化为一个新的 json,并提供给该客户端。然而, Node 服务器从其他服务器获得的 json 可能非常大,因此数据“按摩”非常占用 CPU。
过去几个小时我一直在阅读 node.js 不适合 cpu 任务,我看到的主要响应是生成一个子进程(基本上是一个 .js 文件运行在不同的进程中) Node 实例)处理任何可能阻塞主事件循环的 CPU 密集型任务。
假设我有 20,000 个并发用户,这意味着它会在运行这些子进程时生成 20,000 个操作系统级别的作业。
这听起来是个好主意吗? (不同的 Web 服务器只会在同一进程上创建 20,000 个线程。)
我不确定我是否应该运行一个子进程。但我确实需要进行非阻塞 cpu 密集型任务。我应该做什么有什么想法吗?
最佳答案
说这种话的人不知道如何设计解决方案。
NodeJS 正是它所说的,它是一个 Node ,应该这样对待。
在您的示例中,您的 Node 实例连接到外部 api 并获取 json 进行处理并发回。
即1.获取//server.com/getJSON2.处理json3. 发布//server.com/postJSON
那你是做什么的?问问自己时间是个问题吗?如果是这样,那么 Node 不是解决方案但是,如果您对原始处理能力更感兴趣,那么不要在 4 秒内完成 1 个请求
您对在 10 秒内完成的 200 个请求感兴趣,但每个请求都花费了大约整整 10 秒。
诊断您的 JSON 需要多长时间才能进行按摩(如果少于 1 秒)。只需运行 4 个 Node 实例而不是 1 个。
但是,如果它比这更复杂,请将 json 分成多个部分进行处理。并使用异步回调处理每个段
process.nextTick(function( doprocess(segment1); process.nextTick(function() {doprocess(segment2)
每个doProcess调用下一个doProcess
Node js 将在请求之间交换时间。
现在采用该解决方案并将其扩展为每台服务器 4 个 Node 实例,以及 2-5 个服务器
突然之间,您拥有了一个极具可扩展性和成本效益的解决方案。
关于node.js - CPU 密集型任务的子进程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17956692/
需要帮助将这些给定的数字打印成星号,但我是编程新手;我该怎么做? #include int main(void) { int a[5]={20,1,5,15,12}; int i=0
使用 Delphi XE 2 我试图确定缩放方向以将缩放效果应用于图像(TImage),但没有找到执行此操作的函数,并且图像的 OnGesture 事件中的 EventInfo 属性没有此信息. 我见
我不知道制服在内存中是如何表示的。 制服似乎会占用宝贵的寄存器空间,但它们最终会传入/通过/传出到全局内存中,对吗? 制服不用时情况会发生变化吗?编译器可以将它们优化掉吗?--在这种情况下,我已经将无
我正在尝试在名为“timeclock”的模型上记录“time_in”和“time_out”记录。这是我想做但无法开始工作的事情! 检查最后一个时钟条目,看看它是否同时填充了“time_in”和“tim
我想听听您如何解决这种编程任务!?每种类型(OPER = 1 类型)对应一种特定的信息。 这只是大约 10 个具有相同结构的规范之一。首选创建这些“转换器”(协议(protocol))的通用方法。 最
我正在使用 Rest API(NodeJS、Express)和 PostgreSQL 制作 React-Native 应用。 在我的本地机器上托管时一切正常。当 API 托管在我的机器上并且 Post
我是一名优秀的程序员,十分优秀!