{"id":1228,"date":"2020-12-06T01:56:13","date_gmt":"2020-12-05T16:56:13","guid":{"rendered":"https:\/\/dalomo.net\/blog\/?p=1228"},"modified":"2020-12-06T01:56:13","modified_gmt":"2020-12-05T16:56:13","slug":"%e3%83%81%e3%83%a3%e3%83%83%e3%83%88%e3%82%92%e4%bd%9c%e3%82%8a%e3%81%9f%e3%81%84%e2%91%a2-node-jssocket-io","status":"publish","type":"post","link":"https:\/\/dalomo.net\/blog\/2020\/12\/06\/1228\/","title":{"rendered":"\u30c1\u30e3\u30c3\u30c8\u3092\u4f5c\u308a\u305f\u3044\u2462 Node.js+Socket.IO"},"content":{"rendered":"<h1>Node.js+Socket.IO<\/h1>\n<p>\u3058\u3083\u30fc\u30c1\u30e3\u30c3\u30c8\u3092\u4f5c\u3063\u3066\u3053\u30fc\u3002\u516c\u5f0f\u304c\u63d0\u4f9b\u3057\u3066\u308b\u306e\u304c\u3042\u308b\u306e\u3067<\/p>\n<p><a href=\"https:\/\/socket.io\/get-started\/chat\/\">https:\/\/socket.io\/get-started\/chat\/<\/a><\/p>\n<p>\u3053\u308c\u898b\u306a\u304c\u3089\u3084\u3063\u3066\u307f\u308b\u3002<\/p>\n<h2>Socket.IO\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h2>\n<p>\/home\/dalomo\/node-chat\u3063\u3066\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u4f5c\u3063\u3066<\/p>\n<pre>$ npm init<\/pre>\n<p>\u3063\u3066\u3059\u308b\u3068\u8272\u3005\u805e\u304b\u308c\u308b\u306e\u3067<\/p>\n<pre>{\r\n\"name\": \"node-chat\",\r\n\"version\": \"1.0.0\",\r\n\"description\": \"\",\r\n\"main\": \"app.js\",\r\n\"scripts\": {\r\n\"test\": \"echo \\\"Error: no test specified\\\" &amp;&amp; exit 1\"\r\n},\r\n\"author\": \"dalomo\",\r\n\"license\": \"ISC\"\r\n}<\/pre>\n<p>\u3053\u3093\u306a\u611f\u3058\u306b\u3057\u305f(\u3088\u304f\u5206\u304b\u3063\u3066\u306a\u3044)\u3002\u305d\u3057\u305f\u3089<\/p>\n<pre>$ npm install socket.io\r\n$ npm install express<\/pre>\n<p>\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3002express\u306e\u65b9\u3082\u5fc5\u8981\u307f\u305f\u3044\u3002<\/p>\n<h2>express\u3092\u5229\u7528\u3057\u305fHelloWorld<\/h2>\n<p>\u516c\u5f0f\u306e\u6d41\u308c\u304c\u3053\u3046\u3060\u304b\u3089\u307e\u305a\u3053\u308c\u3092\u3084\u308b\u3067\u3054\u3056\u308b\u3002\u30d5\u30a9\u30eb\u30c0\u5185\u306b<\/p>\n<pre>$ vi app.js<\/pre>\n<p>\u3067<\/p>\n<pre><span class=\"line\"><span class=\"keyword\">var<\/span> app = <span class=\"built_in\">require<\/span>(<span class=\"string\">'express'<\/span>)();<\/span>\r\n<span class=\"line\"><span class=\"keyword\">var<\/span> http = <span class=\"built_in\">require<\/span>(<span class=\"string\">'http'<\/span>).createServer(app);<\/span>\r\n\r\n<span class=\"line\">app.get(<span class=\"string\">'\/'<\/span>, <span class=\"function\">(<span class=\"params\">req, res<\/span>) =&gt;<\/span> {<\/span>\r\n<span class=\"line\">  res.send(<span class=\"string\">'&lt;h1&gt;Hello world&lt;\/h1&gt;'<\/span>);<\/span>\r\n<span class=\"line\">});<\/span>\r\n\r\n<span class=\"line\">http.listen(4<span class=\"number\">000<\/span>, <span class=\"function\">() =&gt;<\/span> {<\/span>\r\n<span class=\"line\">  <span class=\"built_in\">console<\/span>.log(<span class=\"string\">'listening on *:4000'<\/span>);<\/span>\r\n<span class=\"line\">});<\/span><\/pre>\n<p>3000\u756a\u306f\u4f7f\u7528\u4e2d\u306a\u306e\u30674000\u756a\u306b\u5909\u3048\u3066\u307f\u305f\u3002<\/p>\n<p><del>\u81ea\u5206\u306e\u5834\u5408\u3001\u524d\u8ff0\u306e\u74b0\u5883\u304c\u3042\u308b\u306e\u3067\/etc\/nginx\/conf.d\/reverse_proxy.conf\u306b<\/del><\/p>\n<pre><del> location \/node-chat\/ {\r\nproxy_pass http:\/\/127.0.0.1:4000;<\/del>\r\n<del>proxy_redirect off;\r\nproxy_set_header Host $host;\r\nproxy_set_header X-Real-IP $remote_addr;\r\nproxy_set_header X-Forwarded-Host $host;\r\nproxy_set_header X-Forwarded-Server $host;\r\nproxy_set_header X-Forwarded-Proto $scheme;\r\nproxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;\r\n}<\/del><\/pre>\n<p><del>\u3092\u8ffd\u8a18\u3002<\/del><\/p>\n<p>\u3053\u308c\u3058\u3083\u30c0\u30e1\u3060\u3063\u305f\u307f\u305f\u3044\u3002<\/p>\n<p>&nbsp;<\/p>\n<p>\u307e\u305f\u3001\u30c7\u30fc\u30e2\u30f3\u5316\u306e\u305f\u3081\u306b\/etc\/systemd\/system\u4e0b\u306bnode-chat.service\u3092\u4f5c\u308a<\/p>\n<pre>[Unit]\r\nDescription=node-chat\r\nAfter=network.target\r\n\r\n[Service]\r\nType=simple\r\nExecStart=\/usr\/bin\/node \/home\/dalomo\/node-chat\/app.js\r\nRestart=always\r\nWorkingDirectory=\/home\/dalomo\/node-chat\r\n\r\n[Install]\r\nWantedBy=multi-user.target<\/pre>\n<p>\u3068\u8a18\u8f09\u3057\u305f\u3002\u305d\u3093\u3067<\/p>\n<pre>$ systemctl daemon-reload\r\n$ systemctl start node-chat\r\n$ systemctl status node-chat\r\n\u25cf node-chat.service - node-chat\r\nLoaded: loaded (\/etc\/systemd\/system\/node-chat.service; disabled; vendor preset: disabled)\r\nActive: active (running) since Sat 2020-12-05 15:39:28 JST; 8s ago\r\nMain PID: 13123 (node)\r\nCGroup: \/system.slice\/node-chat.service\r\nmq13123 \/usr\/bin\/node \/home\/dalomo\/node-chat\/app.js\r\n\r\nDec 05 15:39:28 1scp2bi4 systemd[1]: Started node-chat.\r\nDec 05 15:39:28 1scp2bi4 node[13123]: listening on *:4000<\/pre>\n<p>\u3046\u3080\u3002\u3058\u3083\u3042http:\/\/dalomo.net\/node-chat\/\u306b\u30a2\u30af\u30bb\u30b9\u3057\u3066\u307f\u307e\u3059\u3068<\/p>\n<p><a href=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node03.png\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-medium wp-image-1229\" src=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node03-300x62.png\" alt=\"\" width=\"300\" height=\"62\" srcset=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node03-300x62.png 300w, https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node03.png 342w\" sizes=\"auto, (max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\u3042\u308c\u2026\uff1f\u3044\u304b\u3093\u3001\u3053\u3053\u3067\u8e93\u304f\u306e\u306f\u3044\u304b\u3093\u305e\u3002<\/p>\n<p><a href=\"https:\/\/stackoverflow.com\/questions\/60368255\/cannot-get-chatroom\">https:\/\/stackoverflow.com\/questions\/60368255\/cannot-get-chatroom<\/a><\/p>\n<p>\u3053\u3053\u898b\u308b\u3068\u30eb\u30fc\u30c8\u306e\u8a2d\u5b9a\u304c\u9055\u3046\u3063\u307d\u3044\uff01app.js\u3092<\/p>\n<pre><span class=\"line\">app.get(<span class=\"string\">'\/'<\/span>, <span class=\"function\">(<span class=\"params\">req, res<\/span>) =&gt;<\/span> {<\/span>\r\n\u2193\r\n<span class=\"line\">app.get(<span class=\"string\">'\/node-chat\/'<\/span>, <span class=\"function\">(<span class=\"params\">req, res<\/span>) =&gt;<\/span> {<\/span><\/pre>\n<p>\u306b\u5909\u3048\u3066restart\u307f\u308b\u3068<\/p>\n<p><a href=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node04.png\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-medium wp-image-1230\" src=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node04-300x84.png\" alt=\"\" width=\"300\" height=\"84\" srcset=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node04-300x84.png 300w, https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node04-320x90.png 320w, https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node04.png 323w\" sizes=\"auto, (max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\u3067\u304d\u305f\u30fc\uff01\u3042\u3076\u306d\u30fc\u3002<\/p>\n<h2>\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u5074HTML\u3092\u4f5c\u6210<\/h2>\n<p>app.js\u306e\u5185\u5bb9\u3092<\/p>\n<pre>app.get('\/node-chat\/', (req, res) =&gt; {\r\n  res.sendFile(__dirname + '\/index.html');\r\n});<\/pre>\n<p>\u3053\u3046\u5909\u66f4\u3002__dirname\u3063\u3066\u3044\u3046\u306e\u306fapp.js\u306e\u30d1\u30b9\u3092\u3068\u3063\u3066\u304d\u3066\u304f\u308c\u308b\u3002\u3053\u3046\u3059\u308b\u3068\u30ec\u30b9\u30dd\u30f3\u30b9\u306b\u4f5c\u6210\u3057\u305findex.html\u3092\u8fd4\u3059\u3088\u30fc\u3063\u3066\u306a\u308b\u3002\u3067\u3001HTML\u306f\u4e38\u30d1\u30af\u308b(\u30bf\u30a4\u30c8\u30eb\u3060\u3051\u5909\u3048\u305f^^)\u3002<\/p>\n<pre><span class=\"line\"><span class=\"meta\">&lt;!doctype <span class=\"meta-keyword\">html<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\"><span class=\"tag\">&lt;<span class=\"name\">html<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">  <span class=\"tag\">&lt;<span class=\"name\">head<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">    <span class=\"tag\">&lt;<span class=\"name\">title<\/span>&gt;<\/span>node-chat<span class=\"tag\">&lt;\/<span class=\"name\">title<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">    <span class=\"tag\">&lt;<span class=\"name\">style<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\"><span class=\"css\">      * { <span class=\"attribute\">margin<\/span>: <span class=\"number\">0<\/span>; <span class=\"attribute\">padding<\/span>: <span class=\"number\">0<\/span>; <span class=\"attribute\">box-sizing<\/span>: border-box; }<\/span><\/span>\r\n<span class=\"line\"><span class=\"css\">      <span class=\"selector-tag\">body<\/span> { <span class=\"attribute\">font<\/span>: <span class=\"number\">13px<\/span> Helvetica, Arial; }<\/span><\/span>\r\n<span class=\"line\"><span class=\"css\">      <span class=\"selector-tag\">form<\/span> { <span class=\"attribute\">background<\/span>: <span class=\"number\">#000<\/span>; <span class=\"attribute\">padding<\/span>: <span class=\"number\">3px<\/span>; <span class=\"attribute\">position<\/span>: fixed; <span class=\"attribute\">bottom<\/span>: <span class=\"number\">0<\/span>; <span class=\"attribute\">width<\/span>: <span class=\"number\">100%<\/span>; }<\/span><\/span>\r\n<span class=\"line\"><span class=\"css\">      <span class=\"selector-tag\">form<\/span> <span class=\"selector-tag\">input<\/span> { <span class=\"attribute\">border<\/span>: <span class=\"number\">0<\/span>; <span class=\"attribute\">padding<\/span>: <span class=\"number\">10px<\/span>; <span class=\"attribute\">width<\/span>: <span class=\"number\">90%<\/span>; <span class=\"attribute\">margin-right<\/span>: <span class=\"number\">0.5%<\/span>; }<\/span><\/span>\r\n<span class=\"line\"><span class=\"css\">      <span class=\"selector-tag\">form<\/span> <span class=\"selector-tag\">button<\/span> { <span class=\"attribute\">width<\/span>: <span class=\"number\">9%<\/span>; <span class=\"attribute\">background<\/span>: <span class=\"built_in\">rgb<\/span>(<span class=\"number\">130<\/span>, <span class=\"number\">224<\/span>, <span class=\"number\">255<\/span>); <span class=\"attribute\">border<\/span>: none; <span class=\"attribute\">padding<\/span>: <span class=\"number\">10px<\/span>; }<\/span><\/span>\r\n<span class=\"line\"><span class=\"css\">      <span class=\"selector-id\">#messages<\/span> { <span class=\"attribute\">list-style-type<\/span>: none; <span class=\"attribute\">margin<\/span>: <span class=\"number\">0<\/span>; <span class=\"attribute\">padding<\/span>: <span class=\"number\">0<\/span>; }<\/span><\/span>\r\n<span class=\"line\"><span class=\"css\">      <span class=\"selector-id\">#messages<\/span> <span class=\"selector-tag\">li<\/span> { <span class=\"attribute\">padding<\/span>: <span class=\"number\">5px<\/span> <span class=\"number\">10px<\/span>; }<\/span><\/span>\r\n<span class=\"line\"><span class=\"css\">      <span class=\"selector-id\">#messages<\/span> <span class=\"selector-tag\">li<\/span><span class=\"selector-pseudo\">:nth-child(odd)<\/span> { <span class=\"attribute\">background<\/span>: <span class=\"number\">#eee<\/span>; }<\/span><\/span>\r\n<span class=\"line\">    <span class=\"tag\">&lt;\/<span class=\"name\">style<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">  <span class=\"tag\">&lt;\/<span class=\"name\">head<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">  <span class=\"tag\">&lt;<span class=\"name\">body<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">    <span class=\"tag\">&lt;<span class=\"name\">ul<\/span> <span class=\"attr\">id<\/span>=<span class=\"string\">\"messages\"<\/span>&gt;<\/span><span class=\"tag\">&lt;\/<span class=\"name\">ul<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">    <span class=\"tag\">&lt;<span class=\"name\">form<\/span> <span class=\"attr\">action<\/span>=<span class=\"string\">\"\"<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">      <span class=\"tag\">&lt;<span class=\"name\">input<\/span> <span class=\"attr\">id<\/span>=<span class=\"string\">\"m\"<\/span> <span class=\"attr\">autocomplete<\/span>=<span class=\"string\">\"off\"<\/span> \/&gt;<\/span><span class=\"tag\">&lt;<span class=\"name\">button<\/span>&gt;<\/span>Send<span class=\"tag\">&lt;\/<span class=\"name\">button<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">    <span class=\"tag\">&lt;\/<span class=\"name\">form<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\">  <span class=\"tag\">&lt;\/<span class=\"name\">body<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\"><span class=\"tag\">&lt;\/<span class=\"name\">html<\/span>&gt;<\/span><\/span><\/pre>\n<p>\u305d\u3046\u3059\u3063\u3068<\/p>\n<p><a href=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node05.png\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-medium wp-image-1232\" src=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node05-300x187.png\" alt=\"\" width=\"300\" height=\"187\" srcset=\"https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node05-300x187.png 300w, https:\/\/dalomo.net\/blog\/wp-content\/uploads\/2020\/12\/node05.png 602w\" sizes=\"auto, (max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\u3053\u3046\u306a\u3063\u305f\u3002CSS\u5168\u7136\u308f\u304b\u3089\u306a\u3044\u306e\u3067\u3001\u306a\u3093\u3067\u3053\u3046\u306a\u308b\u306e\u304b\u5206\u304b\u3093\u306a\u3044\u3002<\/p>\n<h2>Socket.IO\u306e\u51e6\u7406\u3092\u5b9f\u88c5<\/h2>\n<h3>\u63a5\u7d9a\u78ba\u8a8d<\/h3>\n<p>\u3053\u308c\u3082\u3081\u3061\u3083\u3081\u3061\u3083\u30b3\u30d4\u30da\u3067\u3042\u308b\u3002app.js\u306b<\/p>\n<pre>var io = require('socket.io')(http);<\/pre>\n<p>\u3068<\/p>\n<pre><span class=\"line\">io.on(<span class=\"string\">'connection'<\/span>, <span class=\"function\">(<span class=\"params\">socket<\/span>) =&gt;<\/span> {<\/span>\r\n<span class=\"line\">  <span class=\"built_in\">console<\/span>.log(<span class=\"string\">'a user connected'<\/span>);<\/span>\r\n<span class=\"line\">});<\/span><\/pre>\n<p>\u3092\u8ffd\u8a18\u3002index.html\u306e&lt;\/body&gt;\u306e\u524d\u306b<\/p>\n<pre><span class=\"line\"><span class=\"tag\">&lt;<span class=\"name\">script<\/span> <span class=\"attr\">src<\/span>=<span class=\"string\">\"\/socket.io\/socket.io.js\"<\/span>&gt;<\/span><span class=\"tag\">&lt;\/<span class=\"name\">script<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\"><span class=\"tag\">&lt;<span class=\"name\">script<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">  <span class=\"keyword\">var<\/span> socket = io();<\/span><\/span>\r\n<span class=\"line\"><span class=\"tag\">&lt;\/<span class=\"name\">script<\/span>&gt;<\/span><\/span><\/pre>\n<p>\u3092\u8ffd\u8a18\u3002\u305d\u3093\u3067\u30a2\u30af\u30bb\u30b9\u3057\u3066\u307f\u308b\u3068\u3001status\u306b\u51fa\u3066\u3053\u306a\u3044\u3002\u306a\u3093\u3067\u3084\u3002<\/p>\n<p>\u30d6\u30e9\u30a6\u30b6\u5074\u306e\u958b\u767a\u8005\u30c4\u30fc\u30eb\u3092\u958b\u304dconsole\u3092\u898b\u3066\u307f\u308b\u3068<\/p>\n<pre>Uncaught SyntaxError: Unexpected token '&lt;'\u00a0 \u00a0 \u00a0 socket.io.js:1<\/pre>\n<p>\u3068\u306e\u8868\u8a18\u304c\u3042\u308a\u3001socket.io.js:1 \u306eURL\u3092\u78ba\u8a8d\u3057\u3066\u307f\u308b\u3068<\/p>\n<p>!https:\/\/dalomo.net\/socket.io\/socket.io.js<\/p>\n<p>\u306b\u884c\u3053\u3046\u3068\u3057\u3066\u3044\u308b\u3088\u3046\u3060\u3063\u305f\u3002\u305d\u3053\u306b\u30fc\u79c1\u306f\u30fc\u3044\u307e\u305b\u3093\u30fc\u3002\u3066\u3044\u3046\u3053\u3068\u306findex.html\u306e<\/p>\n<pre><span class=\"line\"><span class=\"tag\">&lt;<span class=\"name\">script<\/span> <span class=\"attr\">src<\/span>=<span class=\"string\">\"\/socket.io\/socket.io.js\"<\/span>&gt;<\/span><span class=\"tag\">&lt;\/<span class=\"name\">script<\/span>&gt;<\/span><\/span><\/pre>\n<p>\u3053\u3053\u306esrc\u3092\u660e\u793a\u3057\u3066\u3042\u3052\u308c\u3070\u3044\u3044\u306e\u304b\u306a\u30fc\u3068\u601d\u3063\u3066node_modules\/socket.io-client\/dist\/socket.io.js\u306b\u5909\u66f4\u3057\u305f\u3002\u3067\u3082\u4eca\u5ea6\u306f<\/p>\n<pre>net::ERR_ABORTED 404<\/pre>\n<p>\u3068\u306a\u308b\u3002\u3046\u3080\u3080\u30fc\uff1f<\/p>\n<p><a href=\"https:\/\/blog.fkoji.com\/2012\/06300058.html\">https:\/\/blog.fkoji.com\/2012\/06300058.html<\/a><\/p>\n<p>\u3053\u3061\u3089\u8a66\u3057\u3066\u307f\u305f\u308a\u3057\u305f\u3051\u3069\u3046\u307e\u304f\u3044\u304b\u305a\u3002\u8a66\u3057\u306b<\/p>\n<p><a href=\"https:\/\/cdnjs.com\/libraries\/socket.io\">https:\/\/cdnjs.com\/libraries\/socket.io<\/a><\/p>\n<p>\u306e\u3001package.json\u306b\u8a18\u8f09\u306e\u540c\u30d0\u30fc\u30b8\u30e7\u30f3\u306esocket.io.js\u3092\u6307\u5b9a\u3057\u3066\u307f\u308b\u3068\u3001\u30a8\u30e9\u30fc\u306f\u6d88\u3048\u305f\u3002\u3067\u3082log\u306ba user connected\u3063\u3066\u51fa\u3066\u3053\u306a\u3044\u3002\u306a\u3093\u3067\u3060\u308d\u3002\u305f\u3060\u306a\u3093\u304b\u958b\u767a\u8005\u30c4\u30fc\u30eb\u3067Network\u6b04\u3092\u898b\u3066\u307f\u308b\u3068<\/p>\n<p><iframe loading=\"lazy\" src=\"https:\/\/www.youtube.com\/embed\/Xunqcx-guHY\" width=\"560\" height=\"315\" frameborder=\"0\" allowfullscreen=\"allowfullscreen\"><\/iframe><\/p>\n<p>\u306a\u3093\u304b\u3084\u3063\u3066\u305d\u3046\u3067\u306f\u3042\u308b\u2026\u3002\u308f\u3063\u304b\u3093\u306a\u3044\u306a\u30fc\u3002\u3068\u308a\u3042\u3048\u305a\u9032\u3081\u3066\u307f\u3088\u3046\u3002<\/p>\n<h3>\u9032\u3081\u3066\u307f\u305f\u3051\u3069\u5931\u6557\u3059\u308b<\/h3>\n<p>\u3082\u308d\u30b3\u30d4\u30da\u3067app.js\u306b<\/p>\n<pre><span class=\"line\">io.on(<span class=\"string\">'connection'<\/span>, <span class=\"function\">(<span class=\"params\">socket<\/span>) =&gt;<\/span> {<\/span>\r\n<span class=\"line\">  socket.on(<span class=\"string\">'chat message'<\/span>, <span class=\"function\">(<span class=\"params\">msg<\/span>) =&gt;<\/span> {<\/span>\r\n<span class=\"line\">    io.emit(<span class=\"string\">'chat message'<\/span>, msg);<\/span>\r\n<span class=\"line\">  });<\/span>\r\n<span class=\"line\">});<\/span><\/pre>\n<p>\u3068\u5909\u66f4\u3002index.html\u3092<\/p>\n<pre><span class=\"line\"><span class=\"tag\">&lt;<span class=\"name\">script<\/span>&gt;<\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">  $(<span class=\"function\"><span class=\"keyword\">function<\/span> () <\/span>{<\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">    <span class=\"keyword\">var<\/span> socket = io();<\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">    $(<span class=\"string\">'form'<\/span>).submit(<span class=\"function\"><span class=\"keyword\">function<\/span>(<span class=\"params\">e<\/span>)<\/span>{<\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">      e.preventDefault(); <span class=\"comment\">\/\/ prevents page reloading<\/span><\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">      socket.emit(<span class=\"string\">'chat message'<\/span>, $(<span class=\"string\">'#m'<\/span>).val());<\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">      $(<span class=\"string\">'#m'<\/span>).val(<span class=\"string\">''<\/span>);<\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">      <span class=\"keyword\">return<\/span> <span class=\"literal\">false<\/span>;<\/span><\/span>\r\n<span class=\"line\">    });<\/span>\r\n<span class=\"line\"><span class=\"javascript\">    socket.on(<span class=\"string\">'chat message'<\/span>, <span class=\"function\"><span class=\"keyword\">function<\/span>(<span class=\"params\">msg<\/span>)<\/span>{<\/span><\/span>\r\n<span class=\"line\"><span class=\"javascript\">      $(<span class=\"string\">'#messages'<\/span>).append($(<span class=\"string\">'&lt;li&gt;'<\/span>).text(msg));<\/span><\/span>\r\n<span class=\"line\">    });<\/span>\r\n<span class=\"line\">  });<\/span>\r\n<span class=\"line\"><span class=\"tag\">&lt;\/<span class=\"name\">script<\/span>&gt;<\/span><\/span><\/pre>\n<p>\u3068\u5909\u66f4\u3057\u3066\u307f\u3066\u3001\u8a66\u3057\u305f\u3051\u3069\u30e1\u30c3\u30bb\u30fc\u30b8\u306f\u8868\u793a\u3055\u308c\u306a\u304b\u3063\u305f\u3002\u306a\u3093\u3060\u308d\u306a\u30fc\u3002<\/p>\n<h3>\u4e0a\u624b\u304f\u3044\u3063\u305f\u4f8b<\/h3>\n<p>nginx\u3068Apache\u3092\u6b62\u3081\u3066\u3001app.js\u306e\u30dd\u30fc\u30c8\u309280\u756a\u306b\u5909\u66f4\u3002\u305d\u3093\u3067<\/p>\n<p>!http:\/\/\u30b5\u30fc\u30d0\u30fc\u306eIP\u30a2\u30c9\u30ec\u30b9\/node-chat<\/p>\n<p>\u306b\u30a2\u30af\u30bb\u30b9\u3059\u308b\u3068\u4e0a\u624b\u304f\u3044\u3063\u305f\u3002\u8907\u6570\u30bf\u30d6\u3092\u8868\u793a\u3055\u305b\u3066\u7247\u65b9\u306b\u5165\u529b\u3057\u3001\u3082\u3046\u7247\u65b9\u3067\u898b\u308b\u3068\u3061\u3083\u3093\u3068\u30e1\u30c3\u30bb\u30fc\u30b8\u304c\u8868\u793a\u3055\u308c\u3066\u308b\u3002\u3064\u30fc\u3053\u3068\u306fnginx\u3092\u304b\u307e\u3057\u3066Node.js\u30a2\u30d7\u30ea\u306b\u632f\u308b\u6240\u3067\u306a\u306b\u304b\u304c\u304a\u304b\u3057\u3044\u3093\u3058\u3083\u306a\u3044\u304b\u306a\u30fc\u3068\u601d\u3046\u3002<\/p>\n<h3>nginx\u3092\u8a2d\u5b9a\u3057\u76f4\u3059<\/h3>\n<p><a href=\"https:\/\/www.nginx.com\/blog\/nginx-nodejs-websockets-socketio\/\">https:\/\/www.nginx.com\/blog\/nginx-nodejs-websockets-socketio\/<\/a><\/p>\n<p><a href=\"https:\/\/qiita.com\/StoneDot\/items\/e6c755fc3a6e94cc4d58\">https:\/\/qiita.com\/StoneDot\/items\/e6c755fc3a6e94cc4d58<\/a><\/p>\n<p><a href=\"https:\/\/qiita.com\/YuukiMiyoshi\/items\/d56d99be7fb8f69a751b\">https:\/\/qiita.com\/YuukiMiyoshi\/items\/d56d99be7fb8f69a751b<\/a><\/p>\n<p>\u306a\u3069\u3092\u53c2\u8003\u306b<\/p>\n<pre><code class=\"shell\">upstream websocket {\r\n  ip_hash;\r\n  server 127.0.0.1:4000;\r\n}\r\n\r\nserver {\r\n\r\n\u30fb\u30fb\u30fb\r\n  location \/node-chat\/ {\r\n    proxy_pass http:\/\/websocket;\r\n    proxy_redirect                          off;\r\n    proxy_http_version 1.1;\r\n    proxy_set_header Upgrade $http_upgrade;\r\n    proxy_set_header Connection \"upgrade\";\r\n    proxy_set_header Host                   $host;\r\n    proxy_set_header X-Real-IP              $remote_addr;\r\n    proxy_set_header X-Forwarded-Host       $host;\r\n    proxy_set_header X-Forwarded-Server     $host;\r\n    proxy_set_header X-Forwarded-Proto      $scheme;\r\n    proxy_set_header X-Forwarded-For        $proxy_add_x_forwarded_for;\r\n  }\r\n\r\nserver {\r\n\r\n\u30fb\u30fb\u30fb\r\n\r\n   location \/node-chat\/ {\r\n    proxy_pass http:\/\/websocket;\r\n    proxy_redirect                          off;\r\n    proxy_http_version 1.1;\r\n    proxy_set_header Upgrade $http_upgrade;\r\n    proxy_set_header Connection \"upgrade\";\r\n    proxy_set_header Host                   $host;\r\n    proxy_set_header X-Real-IP              $remote_addr;\r\n    proxy_set_header X-Forwarded-Host       $host;\r\n    proxy_set_header X-Forwarded-Server     $host;\r\n    proxy_set_header X-Forwarded-Proto      $scheme;\r\n    proxy_set_header X-Forwarded-For        $proxy_add_x_forwarded_for;\r\n  }\r\n}<\/code><\/pre>\n<p>\u3042\u305f\u308a\u3092\u5909\u3048\u3066\u307f\u305f\u3002\u3051\u3069\u3084\u3063\u3071\u3064\u306a\u304c\u3089\u306a\u3044\u3002<\/p>\n<h3>Socket.IO\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3092\u6307\u5b9a\u3059\u308b<\/h3>\n<p><a href=\"https:\/\/stackoverflow.com\/questions\/58602908\/how-do-i-use-socket-io-from-a-server-at-a-subfolder\">https:\/\/stackoverflow.com\/questions\/58602908\/how-do-i-use-socket-io-from-a-server-at-a-subfolder<\/a><\/p>\n<p><a href=\"https:\/\/github.com\/socketio\/socket.io\/blob\/master\/examples\/cluster-nginx\/nginx\/nginx.conf\">https:\/\/github.com\/socketio\/socket.io\/blob\/master\/examples\/cluster-nginx\/nginx\/nginx.conf<\/a><\/p>\n<p>\u306a\u3093\u304b\u3092\u53c2\u8003\u306bapp.js\u306e<\/p>\n<pre><code class=\"js\">var io = require('socket.io')(http, {path: \"\/node-chat\/socket.io\"});<\/code><\/pre>\n<p>\u3066\u5909\u3048\u3066\u3001index.html\u3082<\/p>\n<pre><code class=\"js\">var socket = io.connect(\"\/\", {path: \"\/node-chat\/socket.io\"});<\/code><\/pre>\n<p>\u3068\u5909\u3048\u3066\u307f\u305f\u3002\u305d\u3057\u305f\u3089\u30fc<\/p>\n<p><iframe loading=\"lazy\" src=\"https:\/\/www.youtube.com\/embed\/eMpA7HQQ4uM\" width=\"560\" height=\"315\" frameborder=\"0\" allowfullscreen=\"allowfullscreen\"><\/iframe><\/p>\n<p>\u3067\u304d\u307e\u3057\u305f\u30fc\uff01<\/p>\n<p><a href=\"https:\/\/dalomo.net\/node-chat\/\">https:\/\/dalomo.net\/node-chat\/<\/a><\/p>\n<p>\u3082\u3057\u304b\u3057\u305f\u3089\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306e\u6307\u5b9a\u3060\u3051\u3067\u3044\u3051\u305f\u3093\u3060\u3063\u305f\u308a\u3057\u3066\u2026\u3002\u307e\u3041\u691c\u8a3c\u3059\u308b\u6c17\u529b\u304c\u6e67\u3044\u3066\u3053\u306a\u3044\u306e\u3067\u3001\u3068\u308a\u3042\u3048\u305a\u3053\u3053\u307e\u3067\uff01\u3088\u3057\u3063\uff01<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Node.js+Socket.IO \u3058\u3083\u30fc\u30c1\u30e3\u30c3\u30c8\u3092\u4f5c\u3063\u3066\u3053\u30fc\u3002\u516c\u5f0f\u304c\u63d0\u4f9b\u3057\u3066\u308b\u306e\u304c\u3042\u308b\u306e\u3067 https:\/\/socket.io\/get-started\/chat\/ \u3053\u308c\u898b\u306a\u304c\u3089\u3084\u3063\u3066\u307f\u308b\u3002 Socket.IO\u3092\u30a4\u30f3\u30b9\u30c8 &hellip; <a href=\"https:\/\/dalomo.net\/blog\/2020\/12\/06\/1228\/\">\u7d9a\u304d\u3092\u8aad\u3080 <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":1232,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"inline_featured_image":false,"footnotes":""},"categories":[8],"tags":[132,129,130,131,128],"class_list":["post-1228","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-8","tag-express","tag-nginx","tag-node-js","tag-socket-io","tag-128"],"_links":{"self":[{"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/posts\/1228","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/comments?post=1228"}],"version-history":[{"count":4,"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/posts\/1228\/revisions"}],"predecessor-version":[{"id":1235,"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/posts\/1228\/revisions\/1235"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/media\/1232"}],"wp:attachment":[{"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/media?parent=1228"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/categories?post=1228"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dalomo.net\/blog\/wp-json\/wp\/v2\/tags?post=1228"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}