76

I launched a node.js server with the following line to set the port:

app.set('port', process.env.PORT || 8080);

This means that, it should either read the PORT env variable or default to 8080, as it does when it's run locally. Neither of them is happening on Heroku, and the server always uses the default port 80. Any idea how to change it?

heroku config
PORT: 8080
Crocodile
  • 5,724
  • 11
  • 41
  • 67
  • what does `heroku config:get PORT`gives you ? Also, you can try `heroku config:unset PORT`and see if your hardcoded default gets picked up. – tgo Feb 24 '15 at 21:21
  • 1
    'heroku config:get PORT' gives me 8080, yet the app is served on 80. After 'heroku config:unset' no change – Crocodile Feb 24 '15 at 21:27
  • Hey you accepted an answer, yet it doesn't really look like an answer, in my case process.env.PORT is undefined on heroku and I'm kinda stuck here. – Mathijs Segers Jan 09 '19 at 13:04

8 Answers8

102

You can't. Heroku sets the PORT variable that you are supposed to bind, and listens on tcp/80.

punund
  • 4,321
  • 3
  • 34
  • 45
  • So, in the app.js (or the start script), what do I use for port? `var server = http.createServer(sendSMSHandler); server.listen(PORT);` –  Aug 30 '15 at 15:28
  • 23
    @broderickga You can use something like this:var port = process.env.PORT || 3000; app.listen(port, function() { – metatron Nov 06 '16 at 16:29
40

You should use the port opened by heroku like so:

port = process.env.PORT || 80

It sets the port to 80 if it has somehow not been set already

Community
  • 1
  • 1
E. Murimi
  • 509
  • 4
  • 4
21

All the answers are great! Wanted to touch on the theory a bit so people can understand why Heroku sets it port to 80 or 443.

Computers had to create a convention to communicate with each other with a different protocol. For example HTTP, HTTPS, SSH, FTP , etc.

As a result, there was an agreement that computers will communicate HTTP with port 80, https will communicate on port 443, and so on with the other protocol. Below is a table displaying all the protocol's conventional reserve port number.

enter image description here

Now some of you people may be thinking well if these are reserve port number how come my computer lets me use port number 80 and 443 (ex localhost:80). You can use any port number (in fact you can choose up to 65,535 port number) but once you want to deploy to live and want others to use your application then you will have to start using the convention of port 80 (HTTP) or port 443 (https).

Heroku makes it nice and easy for you by providing an environment variable process.env.PORT to apply for the correct conventional port number so others can access your app.

Saiansh Singh
  • 583
  • 5
  • 16
ousecTic
  • 1,895
  • 11
  • 20
11

Heroku treats web apps just like any other app and doesn't allow you to assign listening ports directly. Your web server will be assigned a dynamic port by Heroku but to ACCESS it, you will need to use the default port (80).

On Heroku, apps are completely self-contained and do not rely on runtime injection of a webserver into the execution environment to create a web-facing service. Each web process simply binds to a port, and listens for requests coming in on that port. The port to bind to is assigned by Heroku as the PORT environment variable.

The contract with Heroku is for the process to bind to a port to serve requests. Heroku’s routers are then responsible for directing HTTP requests to the process on the right port.

Reference: Heroku Runtime Principles - Web Servers

gomisha
  • 2,587
  • 3
  • 25
  • 33
  • This works. If desired it's also possible to see the assigned port in the log and the app is accessible via the same. –  Apr 08 '19 at 02:20
8

You can do for example:

const PORT = process.env.PORT || 5001;

app.listen(PORT, () => console.log(`Server is listening on port ${PORT}...`));
mkupiniak
  • 129
  • 1
  • 11
4

In my case, heroku was listening on the default HTTPS port: 443 and it was not visible via heroku config:get PORT.

wscourge
  • 10,657
  • 14
  • 59
  • 80
  • 2
    Same here. I set the Config Vars to port 5000 and It took me 4 hours to figure out that it didn't care. It was using ports 80 (for HTTP) and 443 (for HTTPS) no matter what. I actually found this post after finding out and see if there was any documentation at all. – Juanu Jun 02 '20 at 02:30
2

80 is the default port so use 80 instead of 3000 or 8000

const PORT = process.env.PORT || 80;
var server = app.listen(PORT, function() {
    var host = server.address().address;
    var port = server.address().port;
    console.log("server is listening at http://%s:%s", host, port);
});
Rashid Iqbal
  • 1,123
  • 13
  • 13
0

Different ports on Heroku can be used, as long as the main $PORT is also used. See https://stackoverflow.com/a/43911373/9646899