我已经构建了几个应用程序,并决定在Heroku上托管一个。我已经将Express服务器配置为运行构建文件夹中的文件: server/server.js:
const path = require('path');
const express = require('express');
const app = express();
const publicPath = path.join(__dirname, '..', 'build');
const port = process.env.PORT || 3000;
app.use(express.static(publicPath));
app.get('*', (req, res) => {
res.sendFile(path.join(publicPath, 'index.html'));
});
app.listen(port, () => {
console.log('Server is up!');
});当我尝试在本地运行服务器时,一切工作正常。我已经在GitHub上托管了整个项目(通过文件上传,因为我需要的端口被阻止),并设置Heroku从那里获取项目。我已将Procfile设置为:
web: node server/server.js我希望Heroku运行服务器,服务器从项目的build文件夹中获取文件。但是,Heroku CLI显示以下错误:
2019-11-01T20:14:22.015987+00:00 heroku[web.1]: Starting process with command `node app.js`
2019-11-01T20:14:23.648922+00:00 heroku[web.1]: Process exited with status 1
2019-11-01T20:14:23.687276+00:00 heroku[web.1]: State changed from starting to crashed
2019-11-01T20:14:23.691982+00:00 heroku[web.1]: State changed from crashed to starting
2019-11-01T20:14:23.607228+00:00 app[web.1]: internal/modules/cjs/loader.js:638
2019-11-01T20:14:23.607245+00:00 app[web.1]: throw err;
2019-11-01T20:14:23.607246+00:00 app[web.1]: ^
2019-11-01T20:14:23.607247+00:00 app[web.1]:
2019-11-01T20:14:23.607248+00:00 app[web.1]: Error: Cannot find module '/app/app.js'
2019-11-01T20:14:23.607253+00:00 app[web.1]: at Function.Module._resolveFilename (internal/modules/cjs/loader.js:636:15)
2019-11-01T20:14:23.607254+00:00 app[web.1]: at Function.Module._load (internal/modules/cjs/loader.js:562:25)
2019-11-01T20:14:23.607255+00:00 app[web.1]: at Function.Module.runMain (internal/modules/cjs/loader.js:831:12)
2019-11-01T20:14:23.607259+00:00 app[web.1]: at startup (internal/bootstrap/node.js:283:19)
2019-11-01T20:14:23.60726+00:00 app[web.1]: at bootstrapNodeJSCore (internal/bootstrap/node.js:623:3)package.json:
"name": "ai",
"version": "0.9.0",
"private": true,
"engines": {
"npm": "^6.9.0",
"node": "^v10.15.3"
},
"dependencies": {
"bootstrap": "^4.3.1",
"emailjs-com": "^2.4.0",
"express": "^4.17.1",
"i18next": "^17.0.11",
"i18next-browser-languagedetector": "^3.0.3",
"react": "^16.9.0",
"react-bootstrap": "^1.0.0-beta.11",
"react-dom": "^16.9.0",
"react-i18next": "^10.12.2",
"react-image-gallery": "^0.9.1",
"react-scripts": "3.1.1"
},
"scripts": {
"start": "node server/server.js",
"build": "react-scripts build",
"test": "react-scripts test",
"eject": "react-scripts eject"
},
"eslintConfig": {
"extends": "react-app"
},
"browserslist": {
"production": [
">0.2%",
"not dead",
"not op_mini all"
],
"development": [
"last 1 chrome version",
"last 1 firefox version",
"last 1 safari version"
]
}
}构建进行得很顺利,但是app.js找不到了。错误日志中的路径对我没有多大意义-它不应该在build文件夹中查找不同的(缩小的)文件吗?除此之外,我的项目中没有任何应用程序/文件夹。我遗漏了什么?
发布于 2019-11-02 04:49:56
默认情况下,您的项目可能正在查找app.js文件。如果server.js是主项目文件,则可能需要找到指定应用程序/app.js的位置,并将其更改为服务器/server.js
https://stackoverflow.com/questions/58665429
复制相似问题