当我在IO操作上对它们进行基准测试时,为什么PHP在Node.js上占据优势?(Why does PHP come out on top over Node.js when I benchmark them on a IO operation?)
我正在运行基于PHP和Node.js,端口80和端口8000的apache基准测试工具的基准测试。 下面的节点基准测试命令,在PHP上运行测试时交换端口:
ab -n 100 -c 100 http://localhost:8000/
我在程序中所做的只是读取10MB的文本文件,然后将其发送回客户端。 令我惊讶的是,PHP基准测试大约需要6秒,Node.js需要大约13秒。
这是文本文件:
https://github.com/jamesward/play-load-tests/blob/master/public/10mb.txt
这是每个的代码:
Node.js的
var http = require("http"); var fs = require("fs"); var s = http.createServer(function(req, res) { res.writeHead(200, {"content-type": "text/plain"}); fs.readFile("./10mb.txt", "utf8", function(err, data) { res.end(data); }); }); s.listen(8000);
PHP
<?php echo file_get_contents("./10mb.txt");
我在Node代码中做错了吗? 否则我很困惑,Node的主要卖点之一就是它在OI操作中很快。 我错过了什么?
I'm running an benchmark with the apache benchmarking tool on PHP and Node.js, port 80 and port 8000 respectively. Node benchmark command below, swapping out the port when running tests on PHP:
ab -n 100 -c 100 http://localhost:8000/
What I'm doing in the programs is simply reading in a 10MB text file and then send that back to the client. To my surprise the PHP benchmark takes around 6 seconds and Node.js is way up at 13 seconds.
This is the text file:
https://github.com/jamesward/play-load-tests/blob/master/public/10mb.txt
This is the code for each:
Node.js
var http = require("http"); var fs = require("fs"); var s = http.createServer(function(req, res) { res.writeHead(200, {"content-type": "text/plain"}); fs.readFile("./10mb.txt", "utf8", function(err, data) { res.end(data); }); }); s.listen(8000);
PHP
<?php echo file_get_contents("./10mb.txt");
Am I doing something wrong in the Node code? Otherwise I'm pretty confused, one of the main selling points of Node was that it was fast in OI operations. What point am I missing?
原文:https://stackoverflow.com/questions/40645731
最满意答案
这是因为你正在使用
document.write()
清除页面上的其他内容,包括你的处理程序。在隐式加载文档后调用
document.write()
调用document.open()
,它清除文档。因此,要解决此问题,您需要使用
innerHTML
之类的内容来仅更新页面中元素的内容。看这个例子 :
<html> <head> </head> <body onmousedown="create(event)" onkeydown="type(event)"> <div id="foo"></div> <script> function create(event) { var x=event.clientX-14; var y=event.clientY-33; var output = document.getElementById("foo").innerHTML = "<p id=\"text\" style=\"background-color: white; position: absolute; top:" + y + "px;left:" + x + "px;\";>You're Text, your M@jesty!</p>"; } function type(event) { var letter_in = event.keyCode; var letter = String.fromCharCode(letter_in); //var shift = event.shiftKey; //if (shift === false) {letter = String.toLowerCase;} document.getElementById("foo").innerHTML = letter; } </script> </body> </html>
It's because you're using
document.write()
which clears everything else on the page, including your handlers.Calling
document.write()
after the document has been loaded implicitly callsdocument.open()
, which clears the document.So to fix this, you want to use something like
innerHTML
to only update the contents of an element within your page.See this example:
<html> <head> </head> <body onmousedown="create(event)" onkeydown="type(event)"> <div id="foo"></div> <script> function create(event) { var x=event.clientX-14; var y=event.clientY-33; var output = document.getElementById("foo").innerHTML = "<p id=\"text\" style=\"background-color: white; position: absolute; top:" + y + "px;left:" + x + "px;\";>You're Text, your M@jesty!</p>"; } function type(event) { var letter_in = event.keyCode; var letter = String.fromCharCode(letter_in); //var shift = event.shiftKey; //if (shift === false) {letter = String.toLowerCase;} document.getElementById("foo").innerHTML = letter; } </script> </body> </html>
相关问答
更多-
var image ="" var image =""
-
这是因为你正在使用document.write()清除页面上的其他内容,包括你的处理程序。 在隐式加载文档后调用document.write()调用document.open() ,它清除文档。 因此,要解决此问题,您需要使用innerHTML之类的内容来仅更新页面中元素的内容。 看这个例子 :...这一切都取决于您希望在应用程序中实现的结构以及您正在使用的javascript框架的原理。 例如,当您在页面中使用大量jQuery时,您可能更喜欢使用编程方式向事件注册事件处理程序,使您的html清除任何行为。 在其他场景中,您可能希望使用像骨干,emberjs或angularjs这样的框架,它们使用html模板来自动化和简化DOM操作。 这种方法更喜欢将数据和事件处理程序绑定到DOM元素的声明方式,以避免在javascript代码中放置太多行为。 It all depends on the arquite ...
JavaScript - 在指定的时间段内侦听多个事件(JavaScript - Listen for multiple events in a specified period of time)[2022-09-21]
此方法不需要任何Jquery或使用任何计时器,这作为额外的奖励,使其更准确。 var clicks = 0, firstClickTime = 0, clicksNeeded = 3, timeSpan = 1000; //time in milliseconds var myEvent = function(){ document.getElementById("myLabel").innerHTML="TRIGGERED!"; } document.ge ...是的,您可以使用off()删除元素上的所有事件: 文档 。 $(document).off().on("click",".foldandunfold i", function (e) { $(this).toggleClass("fa-chevron-right"); $(this).toggleClass("fa-chevron-down"); $(this).parents("tbody:first").find("tr:not(:first)").tog ...使用.animate()的危险在于,您不能确保元素已返回到其原始状态或结束状态,从而导致动画队列相互堆叠。 因此,链接.stop(true,true)通常可以缓解这个问题,即.stop(true,true).animate(...) 。 而且,你的功能看起来很臃肿 - 如果要将所有元素调整到相同的尺寸,你可以使用多个选择器,甚至更好,只需选择#home的兄弟姐妹。 $('#home').hover( function(){ $(this).siblings().stop(true,t ...我希望它会有所帮助 http://support.microsoft.com/kb/812935 http://support.microsoft.com/kb/316431 i hope it will help http://support.microsoft.com/kb/812935 http://support.microsoft.com/kb/316431您可以执行此操作以清除事件: // get all img elements var imgElements = document.getElementsByTagName('img'); // loop elements for (var i = 0; i < imgelements.length; i++) { // clear handler imgElements[i].onclick = null; // add other handlers here // imgElement ...您可以使用辅助函数 // events and args should be of type Array function addMultipleListeners(element,events,handler,useCapture,args){ if (!(events instanceof Array)){ throw 'addMultipleListeners: '+ 'please supply an array of eventstrings '+ ...快速进行谷歌搜索,我找到了这些库:(我没有使用过,也没有认可过这些库) docx2html 长毛象 docx2html基本功能: var docx2html=require('docx2html') docx2html(fileInput.files[0],{container:document.getElementById('a')}).then(function(html){ html.toString() }) 庞大的基本功能: var mammoth = require("mammoth" ...相关文章
更多- 《MLDN出品 魔乐科技Node.JS + MongoDB(JSP、HTML 、XML、JavaScript、Servlet、Struts、Ajax)视频汇总》(Node.JS + MongoDB\JSP、HTML 、XML、JavaScript、Servlet、Struts、Ajax nodejs)V2013[压缩包]
- Node.js视频教程
- python top project of 2013
- The Top 40 iPhone Apps of 2010
- Becoming a data scientist
- Java 流(Stream)、文件(File)和IO
- [转]Top 20 Programming Lessons I've Learned in 20 Years
- iotop命令实时监听磁盘IO
- Drupal Forums instead of phpBB or vBulletin: A casestudy
- Hadoop core之IO
最新问答
更多- 获取MVC 4使用的DisplayMode后缀(Get the DisplayMode Suffix being used by MVC 4)
- 如何通过引用返回对象?(How is returning an object by reference possible?)
- 矩阵如何存储在内存中?(How are matrices stored in memory?)
- 每个请求的Java新会话?(Java New Session For Each Request?)
- css:浮动div中重叠的标题h1(css: overlapping headlines h1 in floated divs)
- 无论图像如何,Caffe预测同一类(Caffe predicts same class regardless of image)
- xcode语法颜色编码解释?(xcode syntax color coding explained?)
- 在Access 2010 Runtime中使用Office 2000校对工具(Use Office 2000 proofing tools in Access 2010 Runtime)
- 从单独的Web主机将图像传输到服务器上(Getting images onto server from separate web host)
- 从旧版本复制文件并保留它们(旧/新版本)(Copy a file from old revision and keep both of them (old / new revision))
- 西安哪有PLC可控制编程的培训
- 在Entity Framework中选择基类(Select base class in Entity Framework)
- 在Android中出现错误“数据集和渲染器应该不为null,并且应该具有相同数量的系列”(Error “Dataset and renderer should be not null and should have the same number of series” in Android)
- 电脑二级VF有什么用
- Datamapper Ruby如何添加Hook方法(Datamapper Ruby How to add Hook Method)
- 金华英语角.
- 手机软件如何制作
- 用于Android webview中图像保存的上下文菜单(Context Menu for Image Saving in an Android webview)
- 注意:未定义的偏移量:PHP(Notice: Undefined offset: PHP)
- 如何读R中的大数据集[复制](How to read large dataset in R [duplicate])
- Unity 5 Heighmap与地形宽度/地形长度的分辨率关系?(Unity 5 Heighmap Resolution relationship to terrain width / terrain length?)
- 如何通知PipedOutputStream线程写入最后一个字节的PipedInputStream线程?(How to notify PipedInputStream thread that PipedOutputStream thread has written last byte?)
- python的访问器方法有哪些
- DeviceNetworkInformation:哪个是哪个?(DeviceNetworkInformation: Which is which?)
- 在Ruby中对组合进行排序(Sorting a combination in Ruby)
- 网站开发的流程?
- 使用Zend Framework 2中的JOIN sql检索数据(Retrieve data using JOIN sql in Zend Framework 2)
- 条带格式类型格式模式编号无法正常工作(Stripes format type format pattern number not working properly)
- 透明度错误IE11(Transparency bug IE11)
- linux的基本操作命令。。。