- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
假设我正在构建一个 3 层网站,在后端使用 Mongo DB,在浏览器中使用一些非常轻量级的 javascript(假设只是对表单进行验证,也许是一些可以触发 AJAX 的精美控件请求)。
我需要为“中间”层选择一种技术(我们可以将其分割为子层,但这里不关注细节,只是整体技术选择),我想在其中处理一些原始数据从数据库中取出,并将其呈现为一些我推送到浏览器的 HTML。一个相当典型的瘦客户端 Web 架构。
我的安全选择是在 Java 中实现这个中间层,使用 Jongo 之类的库与 Mongo DB 对话,也许 Jackson 在他们发出 AJAX 请求时编码/取消编码 JSON 与我的花哨的控件对话。还有一些用于在服务器上呈现我的 HTML 的 Java 模板框架。
但是,我对将所有这些都抛在脑后并在这个中间层使用 Node.js 的想法很感兴趣,原因如下:
我喜欢 javascript(好的部分),假设这个应用程序的业务逻辑比 Java 更具表现力。
到处都是javascript。在堆栈上的任何位置工作时,无需在语言之间切换,实际上也无需在 OO 和功能范式之间切换。层之间没有翻译管道,JSON 在所有地方都得到原生支持。
我可以在客户端和服务器上重用验证逻辑。
如果将来我决定在浏览器中进行 HTML 渲染客户端,我可以使用 Backbone 之类的东西重用现有模板,只需极少的重构/重新测试工作。
如果您在这一点上并且喜欢 Node,那么以上所有内容都会显得很明显。那我应该选择Node吧?
但是...这就是我失败的地方:众所周知,Node 基于单线程异步 I/O Web 服务器模型。这对我在服务数据请求方面的可扩展性和性能非常有用,但是我的业务逻辑呢?我的模板渲染呢?这东西不会对单线程上的所有请求造成巨大的瓶颈吗?
想到了两个明显的解决方案,但都不是正确的:
保留“阻塞”业务逻辑,只需使用 Node 实例集群和负载均衡器,即可真正并行地为请求提供服务。好的,那么为什么 Node 一开始就不是多线程的呢?或者这始终是一个想法,保持简单愚蠢并避免在基本情况下出现多线程复杂性的可能性,如果需要多核处理能力,让程序员在此基础上进行额外的设置工作?
保持单个 Node 实例,并通过调用在其他多线程应用服务器上运行的我的业务逻辑的一些 java 实现来保持它的非阻塞。好的,除了对数据库的 CRUD 请求在性能和可扩展性方面可能获得的 yield 之外,这个选项完全抵消了我列出的所有使用 Node 的专业人士(实际上它比仅使用 Java 增加了复杂性)。
这最终让我想到了我的问题——我是否遗漏了 Node 难题的一些重要部分,我只是完全错误地理解了事实,还是 Node 不适合在服务器上处理业务逻辑?换句话说,与其他阻塞 I/O 的实现相比,Node 是否仅对坐在数据库上并以更高效和可扩展的方式服务许多 CRUD 请求有用?而且您必须在下面的某个层甚至客户端执行所有业务逻辑,以保持任何合理水平的性能和可扩展性?
考虑到 Node 上的所有热议,我宁愿希望它带来比这更多的东西。我很乐意被说服!
最佳答案
在任何给定系统上,您都有 N 个可用的 cpu(1-64,或任何 N 恰好是)。在任何 CPU 密集型应用程序中,您都会遇到 N cpus 的吞吐量。没有神奇的方法可以通过添加超过 N 个线程/进程/任何东西来解决这个问题。要么你的代码必须更高效,要么你需要更多的 CPU。更多线程无济于事。
关于多 CPU 性能的一个鲜为人知的事实是,如果您需要同时运行 N+1 个 CPU 密集型操作,则每个 CPU 的吞吐量会下降很多. CPU 密集型进程在放弃它之前往往会在该 CPU 上挂起很长一段时间,从而使其他任务严重挨饿。在大多数情况下,阻塞 I/O 和伴随的任务切换使现代操作系统的多任务工作和它一样好。如果我们的日常常见任务中有更多受 CPU 限制,我们会发现我们的机器需要比目前更多的 CPU。
Node.js 在效率方面为服务器方带来的好处是对每个线程的彻底使用。理想情况下,您最终会 reduce task 切换。这不是一个巨大的胜利,但是让 N 个线程异步处理 N*C 个连接将比 具有性能优势N*C 阻塞线程在相同数量的 CPU 上运行。但是 CPU 的底线是一样的:如果你有超过 N 值(value)的实际 CPU 工作要做,你会感到有些痛苦。
我上次查看 Node.js API 时,有一种方法可以使用一个监听器和每个 CPU 一个工作线程来启动服务器。如果你能做到这一点,我会倾向于使用 Node.js,前提是满足一些注意事项:
我可以看到一个缺点:
最后,请记住,程序员的时间通常比服务器或带宽更昂贵。
关于javascript - Node.js 是否应该用于密集处理?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13351462/
我在为 MacOSX 构建的独立包中添加 DMG 背景的自定义图标时遇到问题。我在项目的根目录中添加了一个包。正在从中加载自定义图标,但没有加载 DMG 背景图标。我正在使用 Java fx 2.2.
Qt for Symbian 和 Qt for MeeGo 有什么区别?我知道 Qt 是一个交叉编译平台。这是否意味着如果我使用来自 Qt 的库,完全相同的库可以在所有支持 Qt 的设备(例如 Sym
我正在尝试使用 C# .NET 3.5/4.0 务实地运行 SQL Server 数据库的备份。我已经找到了如何完成此操作,但是我似乎找不到用于备份的命名空间库。 我正在寻找 Microsoft.Sq
我最近在疯狂学习 Java,但我通常是一名 .NET 开发人员。 (所以请原谅我的新手问题。) 在 .Net 中,我可以在不使用 IIS 的情况下开发 ASP.Net 页面,因为它有一个简化的 Web
这post仅当打印命令中有字符串时才有用。现在我有大量的源代码,其中包含一条声明,例如 print milk,butter 应该格式化为 print(milk,butter) 用\n 捕获行尾并不成功
所以我的问题是: https://gist.github.com/panSarin/4a221a0923927115584a 当我保存这个表格时,我收到了标题中的错误 NoMethodError (u
如何让 Html5 音频在点击时播放声音? (ogg 用于 Firefox 等浏览器,mp3 用于 chrome 等浏览器) 到目前为止,我可以通过 onclick 更改为单个文件类型,但我无法像在普
如果it1和it2有什么区别? std::set s; auto it1 = std::inserter(s, s.begin()); auto it2 = std::inserter(s, s.en
4.0.0 com.amkit myapp SpringMVCFirst
我目前使用 Eclipse 作为其他语言的 IDE,而且我习惯于不必离开 IDE 做任何事情 - 但是我真的很难为纯 ECMAScript-262 找到相同或类似的设置。 澄清一下,我不是在寻找 DO
我想将带有字符串数组的C# 结构发送到C++ 函数,该函数接受void * 作为c# 结构和char** 作为c# 结构字符串数组成员。 我能够将结构发送到 c++ 函数,但问题是,无法从 c++ 函
我正在使用动态创建的链接: 我想为f:param附加自定义转换器,以从#{name}等中删除空格。 但是f:param中没有转换器
是否可以利用Redis为.NET创建后写或直写式缓存?理想情况下,透明的高速缓存是由单个进程写入的,并且支持从数据库加载丢失的数据,并每隔一段时间持久保存脏块? 我已经搜查了好几个小时,也许是goog
我正在通过bash执行命令的ssh脚本。 FILENAMES=( "export_production_20200604.tgz" "export_production_log_2020060
我需要一个正则表达式来出现 0 到 7 个字母或 0 到 7 个数字。 例如:匹配:1234、asdbs 不匹配:123456789、absbsafsfsf、asf12 我尝试了([a-zA-Z]{0
我有一个用于会计期间的表格,该表格具有期间结束和开始的开始日期和结束日期。我使用此表来确定何时发生服务交易以及何时在查询中收集收入,例如... SELECT p.PeriodID, p.FiscalY
我很难为只接受字符或数字的 Laravel 构建正则表达式验证。它是这样的: 你好<-好的 123 <- 好的 你好123 <-不行 我现在的正则表达式是这样的:[A-Za-z]|[0-9]。 reg
您实际上会在 Repeater 上使用 OnItemDataBound 做什么? 最佳答案 “此事件为您提供在客户端显示数据项之前访问数据项的最后机会。引发此事件后,数据项将被清空,不再可用。” ~
我有一个 fragment 工作正常的项目,我正在使用 jeremyfeinstein 的 actionbarsherlock 和滑动菜单, 一切正常,但是当我想自定义左侧抽屉列表单元格时,出现异常
最近几天,我似乎平均分配时间在构建我的第一个应用程序和在这里发布问题!! 这是我的第一个应用程序,也是我们的设计师完成的第一个应用程序。我试图满足他所做的事情的外观和感觉,但我认为他没有做适当的事情。
我是一名优秀的程序员,十分优秀!