Как разместить приложение nodejS + postgres в цифровом океане?

Я следовал учебному пособию по обходу мультимедиа, чтобы развернуть приложение nodejs в цифровом океане. Я использую базу данных postgres цифрового океана. Однако при запуске команды node app.js я получаю сообщение об ошибке

Я пытался следовать многим ответам на stackoverflow, но они не решили проблему.

app.js

const express = require('express')
const bodyParser = require('body-parser')
const cors = require('cors')
const morgan = require('morgan')
const db = require('./queries') // contains all query functions
const port = 3000

const app = express()
app.use(morgan('combined'))
app.use(bodyParser.json()) 
app.use(
    bodyParser.urlencoded({
        extended: true,
    })
)
app.use(cors())

app.get('/runs', db.getPlayers)

app.post('/year', db.getByYear)

//Handle production


    app.use(express.static(__dirname+'/public/'))

    //Handle SPA
    app.get(/.*/, (request, response) => response.sendFile(__dirname+'/public/index.html') );


app.listen(port, () => {
    console.log(`App running on port ${port}.`)
})

Ошибка, которую я получаю: -

events.js:183
      throw er; // Unhandled 'error' event
      ^

Error: listen EADDRINUSE :::3000
    at Object._errnoException (util.js:1022:11)
    at _exceptionWithHostPort (util.js:1044:20)
    at Server.setupListenHandle [as _listen2] (net.js:1367:14)
    at listenInCluster (net.js:1408:12)
    at Server.listen (net.js:1492:7)
    at Function.listen (/home/vineet/IPL-Stats-Analysis-Dashboard/node_modules/express/lib/application.js:618:24)
    at Object.<anonymous> (/home/vineet/IPL-Stats-Analysis-Dashboard/app.js:63:5)
    at Module._compile (module.js:652:30)
    at Object.Module._extensions..js (module.js:663:10)
    at Module.load (module.js:565:32)

person Vineet    schedule 07.04.2019    source источник
comment
Я думаю, что madflow, вероятно, прав, но мой вопрос к вам, Винит, вы вообще тестировали это приложение? Всегда тестируйте свое приложение по ходу дела, особенно с помощью учебных пособий, которые просто ускорят процесс создания приложения без тщательного изучения того, что вы делаете и почему.   -  person Daniel    schedule 17.05.2019


Ответы (2)


Я не знаком с указанным руководством, но ошибка означает, что другой процесс (вероятно, то же экспресс-приложение) уже прослушивает порт 3000.

В Linux вы можете просмотреть список всех запущенных процессов с помощью команды ps aux. Найдите другой процесс node. Если его нет — вы можете узнать, какие процессы прослушивают какие порты, запустив lsof -Pnl +M -i4 для адресов ipv4 и lsof -Pnl +M -i6 для ipv6.

Или просто выполните curl http://localhost:3000 в дроплете Digitalocean.

person madflow    schedule 07.04.2019

Если бы ваша ОС была Linux, просто введите на своем терминале killall -9 node

person PJK    schedule 07.07.2019