{"id":1067,"date":"2019-11-18T01:52:52","date_gmt":"2019-11-17T16:52:52","guid":{"rendered":"https:\/\/took.jp\/?p=1067"},"modified":"2020-06-15T15:05:33","modified_gmt":"2020-06-15T06:05:33","slug":"post-1067","status":"publish","type":"post","link":"https:\/\/took.jp\/tech-blog\/post-1067\/","title":{"rendered":"PHP\u3068nodejs\u306e\u51e6\u7406\u901f\u5ea6 \u3069\u3061\u3089\u304c\u901f\u3044\u306e\u304b\u6bd4\u8f03\u3059\u308b"},"content":{"rendered":"<p>\u79c1\u306f\u666e\u6bb5PHP\u3092\u89e6\u3063\u3066\u3044\u307e\u3059\u304c\u3001nodejs\u306e\u65b9\u304c\u51e6\u7406\u901f\u5ea6\u304c\u901f\u3044\u306e\u3067\u306f\u306a\u3044\u304b\u3068\u611f\u3058\u305f\u305f\u3081\u3001\u51e6\u7406\u901f\u5ea6\u3092\u6bd4\u8f03\u3057\u3066\u307f\u3088\u3046\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u7d50\u679c\u3060\u3051\u78ba\u8a8d\u3057\u305f\u3044\u65b9\u306f\u3001<a href=\"#kekka\">\u3053\u3061\u3089<\/a>\u3092\u3069\u3046\u305e\u3002\uff08\u30b9\u30af\u30ed\u30fc\u30eb\u3057\u307e\u3059\uff09<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<p>\u6bd4\u8f03\u65b9\u6cd5<\/p>\n<p>if\u6587\u3067\u6bd4\u8f03\u3057\u3001echo\uff08console.log\uff09\u3092\u3059\u308b\u51e6\u7406\u3092<\/p>\n<p>for\u6587\u3067100\u4e07\u56de\u5b9f\u884c\u3057\u305f\u5e73\u5747\u5b9f\u884c\u6642\u9593\u3067\u6bd4\u8f03\u3092\u884c\u3044\u307e\u3059\u3002<\/p>\n<p>PHP\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u306f\u30017.3.6<\/p>\n<p>nodejs\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u306f\u30018.16.1<\/p>\n<p>&nbsp;<\/p>\n<p>\u6bd4\u8f03\u306f\u30012\u3064\u306e\u65b9\u6cd5\u3092\u4f7f\u7528\u3057\u307e\u3059\u3002<\/p>\n<p>apache\u30b5\u30fc\u30d0(PHP)\u3001express\u30b5\u30fc\u30d0(nodejs)\u3067web\u30da\u30fc\u30b8\u4e0a\u306b\u8868\u793a\u3055\u308c\u308b\u901f\u5ea6\u3002<\/p>\n<p>\u30b3\u30f3\u30bd\u30fc\u30eb\u4e0a\u304b\u3089php\u30b3\u30de\u30f3\u30c9\u3001node\u30b3\u30de\u30f3\u30c9\u3092\u4f7f\u7528\u3057\u3001\u5b9f\u884c\u3057\u305f\u901f\u5ea6\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u30b5\u30fc\u30d0\u304b\u3089\u8fd4\u3055\u308c\u308b\u901f\u5ea6\u3092\u6bd4\u8f03<\/h2>\n<p><strong>PHP<\/strong><\/p>\n<p>xampp\u3092\u4f7f\u7528\u3057\u3001\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3067\u7d50\u679c\u3092\u53d6\u5f97\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"line-numbers\"><code class=\"language-php\">&lt;?php\r\n$count = 1000000;\r\nfor($i = 0; $i &lt; $count; $i++){\r\n\t$time_start = microtime(true);\r\n\t\tif(\"test\" == \"test\"){\r\n\t\t\techo \"test\";\r\n\t\t}\r\n\t$results[] =  microtime(true) - $time_start;\r\n}\r\necho \"&lt;br&gt;\";\r\necho (array_sum($results) \/ $count) * 10000;<\/code><\/pre>\n<p>&nbsp;<\/p>\n<p>\u5b9f\u884c\u7d50\u679c\u306f\u3001<\/p>\n<p><strong>0.0027450633049011 ms<\/strong><\/p>\n<p>&nbsp;<\/p>\n<p><strong>nodejs<\/strong><\/p>\n<p>\u3053\u3061\u3089\u306f\u3001\u300c127.0.0.1:3000\u300d\u3067\u52d5\u4f5c\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"line-numbers\"><code class=\"language-javascript\">const express = require('express')\r\nconst app = express()\r\nfunction speedTest() {\r\n     var start = new Date();\r\n     var hrstart = process.hrtime();\r\n     if(\"test\" == \"test\"){\r\n       console.log(\"test\");\r\n     }\r\n     var end = new Date() - start;\r\n     hrend = process.hrtime(hrstart);\r\n     return hrend[1] \/ 1000000;\r\n}\r\nvar count = 1000000;\r\nvar results = 0;\r\napp.get('\/', function(req, res){\r\n  for (var i=0; i&lt;count; i++){\r\n    results += speedTest();\r\n  }\r\n  var test = results \/ count;\r\n  res.json(test);\r\n});\r\n\r\napp.listen(3000)<\/code><\/pre>\n<p>&nbsp;<\/p>\n<p>\u5b9f\u884c\u7d50\u679c\u306f\u3001<\/p>\n<p><strong> 0.033410115841632046 ms<\/strong><\/p>\n<p>&nbsp;<\/p>\n<h2>\u30b3\u30f3\u30bd\u30fc\u30eb\u304b\u3089\u306e\u5b9f\u884c\u901f\u5ea6\u3092\u6bd4\u8f03<\/h2>\n<p><strong>PHP<\/strong><\/p>\n<p>\u3053\u3061\u3089\u306f\u3001\u540c\u3058\u30b3\u30fc\u30c9\u3067\u3059\u3002<\/p>\n<pre class=\"line-numbers\"><code class=\"language-php\">&lt;?php\r\n$count = 1000000;\r\nfor($i = 0; $i &lt; $count; $i++){\r\n\t$time_start = microtime(true);\r\n\t\tif(\"test\" == \"test\"){\r\n\t\t\techo \"test\";\r\n\t\t}\r\n\t$results[] =  microtime(true) - $time_start;\r\n}\r\necho \"&lt;br&gt;\";\r\necho (array_sum($results) \/ $count) * 10000;<\/code><\/pre>\n<p>&nbsp;<\/p>\n<p>\u5b9f\u884c\u7d50\u679c\u306f\u3001<\/p>\n<p><strong>0.42082943439484 ms<\/strong><\/p>\n<p>&nbsp;<\/p>\n<p><strong>nodejs<\/strong><\/p>\n<pre class=\"line-numbers\"><code class=\"language-javascript\">var count = 1000000;\r\nvar results = 0;\r\n\r\nfunction speedTest() {\r\n     var start = new Date();\r\n     var hrstart = process.hrtime();\r\n     if(\"test\" == \"test\"){\r\n        console.log(\"test\");\r\n     }\r\n     var end = new Date() - start;\r\n     hrend = process.hrtime(hrstart);\r\n     return hrend[1] \/ 1000000;\r\n}\r\n\r\nfor (var i=0; i&lt;count; i++){\r\n  results += speedTest();\r\n}\r\nconsole.log(results \/ count);<\/code><\/pre>\n<p>&nbsp;<\/p>\n<p>\u5b9f\u884c\u7d50\u679c\u306f\u3001<\/p>\n<p><strong>0.03616859515860955 ms<\/strong><\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<h2>\u7d50\u679c<\/h2>\n<p><strong>\u30b5\u30fc\u30d0<\/strong><\/p>\n<p>PHP\u00a00.0027450633049011 ms<\/p>\n<p>nodejs\u00a00.033410115841632046 ms<\/p>\n<p><strong>\u30b3\u30f3\u30bd\u30fc\u30eb<\/strong><\/p>\n<p>PHP\u00a00.42082943439484 ms<\/p>\n<p>nodejs\u00a00.03616859515860955 ms<\/p>\n<p>&nbsp;<\/p>\n<p>\u30b3\u30f3\u30bd\u30fc\u30eb\u4e0a\u304b\u3089\u30b3\u30de\u30f3\u30c9\u3092\u53e9\u3044\u3066\u5b9f\u884c\u3059\u308b\u3068\u3001nodejs\u306e\u65b9\u304c10\u500d\u307b\u3069\u901f\u3044\u3067\u3059\u304c\u3001<\/p>\n<p>\u30b5\u30fc\u30d0\u306b\u8868\u793a\u3055\u308c\u308b\u901f\u5ea6\u3060\u3068PHP\u306e\u65b9\u304c10\u500d\u307b\u3069\u901f\u3044\u3088\u3046\u3067\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u79c1\u306f\u666e\u6bb5PHP\u3092\u89e6\u3063\u3066\u3044\u307e\u3059\u304c\u3001nodejs\u306e\u65b9\u304c\u51e6\u7406\u901f\u5ea6\u304c\u901f\u3044\u306e\u3067\u306f\u306a\u3044\u304b\u3068\u611f\u3058\u305f\u305f\u3081\u3001\u51e6\u7406\u901f\u5ea6\u3092\u6bd4\u8f03\u3057\u3066\u307f\u3088\u3046\u3068\u601d\u3044\u307e\u3059\u3002 \u7d50\u679c\u3060\u3051\u78ba\u8a8d\u3057\u305f\u3044\u65b9\u306f\u3001\u3053\u3061\u3089\u3092\u3069\u3046\u305e\u3002\uff08\u30b9\u30af\u30ed\u30fc\u30eb\u3057\u307e\u3059\uff09 &nbsp; &nbsp; \u6bd4\u8f03\u65b9\u6cd5 if\u6587\u3067\u6bd4\u8f03\u2026<\/p>\n","protected":false},"author":3,"featured_media":1889,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[62,64,67,68],"tags":[],"class_list":["post-1067","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-it","category-nodejs","category-php","category-68"],"_links":{"self":[{"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/posts\/1067","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/comments?post=1067"}],"version-history":[{"count":0,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/posts\/1067\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/media\/1889"}],"wp:attachment":[{"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/media?parent=1067"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/categories?post=1067"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/took.jp\/tech-blog\/wp-json\/wp\/v2\/tags?post=1067"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}