【发布时间】:2019-02-27 12:56:09
【问题描述】:
我有这个 React/Nodejs 应用程序,我正在尝试使用 Docker 将它部署在 Digital Ocean 上。我创建了一个 2GB RAM 的 Docker Droplet,克隆了项目并尝试运行它。
到目前为止,我在构建和运行映像时没有收到任何错误日志。但是,当我尝试访问它时,我在浏览器中收到错误“无法访问此站点”。
我正在像这样构建我的图像:docker build -t myImage .
然后运行它并像这样传递我的环境变量:
docker run -p 80:3000 -e NODE_ENV="production" -e MONGO_URI="URI" -e SECRET_OR_KEY="KEY" myImage
一切似乎都运行良好(构建和运行)。我得到了我的 mongodb 连接的日志并且服务器正在运行。但我实际上看不到应用程序。
这是我的 Dockerfile:
FROM node:11.10.0
WORKDIR /usr/src
RUN git clone https://github.com/repo.git
WORKDIR /usr/src/project
RUN npm install
WORKDIR /usr/src/project/client
RUN npm install
RUN npm run build
WORKDIR /usr/src/project
EXPOSE 80 3000
ENTRYPOINT npm run server
我是基于另一个在 Digital Ocean 上运行的应用程序创建的。
这是我的 server.js:
const express = require('express');
const mongoose = require('mongoose');
const bodyParser = require('body-parser');
const passport = require('passport');
const path = require('path');
//Route files
const users = require('./routes/api/users');
const fpsos = require('./routes/api/fpsos');
const bids = require('./routes/api/bids');
const news = require('./routes/api/news');
const app = express();
//Body parser middlewares
app.use(bodyParser.urlencoded({extended: false}));
app.use(bodyParser.json ());
//DB config
const db = require('./config/keys').mongoURI;
//Connect to MongoDB
mongoose
.connect(db)
.then(() => console.log('MongoDB connected'))
.catch(err => console.log(err));
//Passport middleware
app.use(passport.initialize());
//Passport Config
require('./config/passport')(passport);
app.use('/api/users', users);
app.use('/api/news', news);
app.use('/api/fpso', fpsos);
app.use('/api/bid', bids);
// Server static assets if in production
if (process.env.NODE_ENV === 'production') {
// Set static folder
app.use(express.static('client/build'));
app.get('*', (req, res) => {
res.sendFile(path.resolve(__dirname, 'client', 'build', 'index.html'));
});
}
const port = process.env.PORT || 5000;
app.listen(port, () => console.log(`Server running on port ${port}`))
我在这里缺少什么?我很感激任何帮助。提前致谢!
【问题讨论】:
-
您有 docker 监听端口 3000,但您的 NodeJS 应用程序似乎在监听端口 5000,除非您在某处传递 PORT 环境变量。
-
感谢您的回复@CoolestNerdIII。确实,它在 5000 上运行(我想我在尝试运行它时考虑了反应端口)。我更改了运行命令的参数,现在当我尝试访问该页面时,我在容器中看到了错误日志。但我现在收到此错误:
'/usr/src/project/client/build/index.html'。你知道它可能是什么吗? -
此错误似乎基于您返回 index.html 文件的
res.sendFile。我建议您尝试在本地运行 docker 容器以确认路径,或者您可以尝试放置一个绝对路径以查看是否可以解决问题,但实际上似乎找不到该文件。跨度> -
是的,我的构建实际上并没有在镜像构建过程中运行。我对此进行了调整,现在一切都在服务器中正常运行。非常感谢@CoolestNerdIII
-
太棒了!我会在答案中提供我的 cmets,以便其他人知道是什么解决了它。
标签: node.js reactjs docker digital-ocean