这是我第一次用heroku部署node.js服务器,apis在本地很有趣,但是现在看来heroku不会识别nodemon (sh: 1: nodemon: nothing ),它在论坛上似乎是一个很受欢迎的问题,但是我尝试了所有的评论,什么都没有。
这是我的package.json:
{
"name": "backend",
"version": "1.0.0",
"description": "",
"main": "index.js",
"type": "module",
"scripts": {
"start":"nodemon server",
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC",
"dependencies": {
"cors": "^2.8.5",
"dotenv": "^16.0.1",
"express": "^4.18.1",
"mongodb": "^4.8.0"
},
"engines":{
"node":"14.x"
}
}这是index.js:
import app from "./server.js"
import mongodb from "mongodb"
import dotenv from "dotenv"
import jobsDAO from "./dao/jobsDAO.js"
dotenv.config()
const MongoClient = mongodb.MongoClient
const port = process.env.PORT || 5000
MongoClient.connect(
process.env.JOBSFINDER_DB_URI,
{
wtimeoutMS: 2500,
}
)
.catch(err => {
console.error(err.stack)
process.exit(1)
})
.then(async client =>{
await jobsDAO.injectDB(client)
app.listen(port, () => {
console.log("listening on port",port)
})
})这是server.js:
import express from "express"
import cors from "cors"
import jobs from "./api/jobs.route.js"
const app = express()
app.use(cors())
app.use(express.json())
app.use("/api/v1/jobs", jobs)
app.use("*",(req,res)=>res.status(404).json({ error: "Not Found"}))
export default app 2022-08-24T20:58:55.624084+00:00 heroku[web.1]: Starting process with command `npm start`
2022-08-24T20:58:57.160097+00:00 app[web.1]:
2022-08-24T20:58:57.160109+00:00 app[web.1]: > backend@1.0.0 start /app
2022-08-24T20:58:57.160109+00:00 app[web.1]: > nodemon server
2022-08-24T20:58:57.160109+00:00 app[web.1]:
2022-08-24T20:58:57.170277+00:00 app[web.1]: sh: 1: nodemon: not found
2022-08-24T20:58:57.174407+00:00 app[web.1]: npm ERR! code ELIFECYCLE
2022-08-24T20:58:57.174655+00:00 app[web.1]: npm ERR! syscall spawn
2022-08-24T20:58:57.174717+00:00 app[web.1]: npm ERR! file sh
2022-08-24T20:58:57.174792+00:00 app[web.1]: npm ERR! errno ENOENT
2022-08-24T20:58:57.177522+00:00 app[web.1]: npm ERR! backend@1.0.0 start: `nodemon server`
2022-08-24T20:58:57.177629+00:00 app[web.1]: npm ERR! spawn ENOENT
2022-08-24T20:58:57.177682+00:00 app[web.1]: npm ERR!
2022-08-24T20:58:57.177719+00:00 app[web.1]: npm ERR! Failed at the backend@1.0.0 start script.
2022-08-24T20:58:57.177754+00:00 app[web.1]: npm ERR! This is probably not a problem with npm. There is likely additional logging output above.
2022-08-24T20:58:57.182613+00:00 app[web.1]:
2022-08-24T20:58:57.182689+00:00 app[web.1]: npm ERR! A complete log of this run can be found in:
2022-08-24T20:58:57.182729+00:00 app[web.1]: npm ERR! /app/.npm/_logs/2022-08-24T20_58_57_178Z-debug.log
2022-08-24T20:58:57.299986+00:00 heroku[web.1]: Process exited with status 1发布于 2022-08-24 21:21:23
您的依赖关系中缺少了任何恶魔。运行npm install nodemon将其添加到package.json中
发布于 2022-08-24 22:01:00
依赖项中缺少任何依赖项,需要使用npm install nodemon -D添加( -D是将其保存到dev依赖项)
Nodemon通常用于开发环境,而不是部署的应用程序。
看起来您是用index.js而不是server.js启动服务器的。
我建议如下
npm install nodemon -D"scripts": { "start":"node index.js", "start:dev": "nodemon index.js" "test": "echo \"Error: no test specified\" && exit 1" },要在本地运行该应用程序,可以使用:
npm run start:dev --这将在保存更改时使用nodemon并刷新服务器。npm start --这将运行服务器(对于生产有用)https://stackoverflow.com/questions/73479537
复制相似问题