質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Q&A

解決済

1回答

569閲覧

herokuにおけるnode.jsのデプロイ時に発生したエラー

ShoSakata

総合スコア20

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

0グッド

0クリップ

投稿2019/03/07 01:59

度々お世話になります。node.jsのデプロイをしているのですが、エラーが発生している状況です。
ローカル環境では以下のファイルの「const hostname = '◯◯◯.herokuapp.com';」をコメントアウトし、「const hostname = '127.0.0.1';」のコメントアウトを外した場合、正常に動作します。
知見のある方よりアドバイスを頂きたいです。

コードは以下になります。ファイル名は「server.js」としています。

const http = require('http'); const hostname = '◯◯◯.herokuapp.com';//herokuより与えらたホスト名です。 //const hostname = '127.0.0.1';(ローカルではこちらを使用し、正常に動作します。) const port = process.env.PORT || 8080; var server = http.createServer(); server.on('request', doRequest); function doRequest(req, res) { res.writeHead(200, {'Content-Type': 'text/plain'}); res.write('Hello World\n'); res.end(); } server.listen(port, hostname, () => { console.log(`Server running at http://${hostname}:${port}/`); }); var express = require('express'); var bodyParser = require('body-parser'); var app = express(); app.use(bodyParser.urlencoded({extended: false})); app.use(bodyParser.json()); app.use(function(req, res, next){ res.header("Access-Control-Allow-Origin","*"); res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept"); next(); }) app.post('/server.js',function(req, res){//DBに接続するnode.jsのファイルに接続 var sql = require(js_url); sql.sqlSelect(req.body, res); }); app.listen(process.env.PORT || 8080);

エラー内容

2019-03-07T01:46:33.100732+00:00 heroku[web.1]: State changed from crashed to starting 2019-03-07T01:46:37.658216+00:00 heroku[web.1]: Starting process with command `node server.js` 2019-03-07T01:46:40.684899+00:00 heroku[web.1]: State changed from starting to crashed 2019-03-07T01:46:40.666211+00:00 heroku[web.1]: Process exited with status 1 2019-03-07T01:46:40.582838+00:00 app[web.1]: events.js:173 2019-03-07T01:46:40.582880+00:00 app[web.1]: throw er; // Unhandled 'error' event 2019-03-07T01:46:40.582882+00:00 app[web.1]: ^ 2019-03-07T01:46:40.582883+00:00 app[web.1]: 2019-03-07T01:46:40.582886+00:00 app[web.1]: Error: listen EADDRNOTAVAIL: address not available 34.225.219.245:31733 2019-03-07T01:46:40.582888+00:00 app[web.1]: at Server.setupListenHandle [as _listen2] (net.js:1238:19) 2019-03-07T01:46:40.582890+00:00 app[web.1]: at listenInCluster (net.js:1303:12) 2019-03-07T01:46:40.582892+00:00 app[web.1]: at GetAddrInfoReqWrap.doListen [as callback] (net.js:1442:7) 2019-03-07T01:46:40.582893+00:00 app[web.1]: at GetAddrInfoReqWrap.onlookup [as oncomplete] (dns.js:62:10) 2019-03-07T01:46:40.582895+00:00 app[web.1]: Emitted 'error' event at: 2019-03-07T01:46:40.582897+00:00 app[web.1]: at emitErrorNT (net.js:1282:8) 2019-03-07T01:46:40.582899+00:00 app[web.1]: at process.internalTickCallback (internal/process/next_tick.js:72:19) 2019-03-07T01:46:40.223477+00:00 app[web.1]: 31733

フォルダの構成と上記の「server.js」以外でherokuのデプロイに必要と思われるファイルを記載します。
・フォルダ構成
app -.git
|-node_modules
|-.gitignore
|-package-lock.json
|-package.json
|-Procfile
|-server.js

・「server.js」以外でherokuのデプロイに必要と思われるファイル
package.json

{ "name": "tutorlinerweb", "version": "1.0.0", "description": "", "main": "index.js", "dependencies": { "browser-sync": "^2.26.3", "express": "^4.16.4", "mysql": "^2.16.0", "nodemailer": "^5.1.1", "require": "^2.4.20" }, "devDependencies": {}, "scripts": { "test": "echo \"Error: no test specified\" && exit 1", "start": "node server.js" }, "engines": { "node": "11.6.0", "npm": "6.5.0" }, "author": "", "license": "ISC" }

Procfile

1web: node server.js

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

サーバー実装が2つあります。

js

1var server = http.createServer(); 2server.on('request', doRequest); 3 4function doRequest(req, res) { 5 res.writeHead(200, {'Content-Type': 'text/plain'}); 6 res.write('Hello World\n'); 7 res.end(); 8} 9server.listen(port, hostname, () => { 10 console.log(`Server running at http://${hostname}:${port}/`); 11});

ホスト名の指定はしなくてよいはずなので、こちらは削除してよいのではないでしょうか?

投稿2019/03/07 02:12

mather

総合スコア6753

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ShoSakata

2019/03/07 06:00

ご指摘の削除対象を消すことでエラーがなくなりました!!!! ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問