"This site can’t be reached" Docker Digital Ocean 上的容器

"This site can’t be reached" Docker container on Digital Ocean

我有这个 React/Nodejs 应用程序,我正尝试使用 Docker 将它部署到 Digital Ocean 上。我创建了一个 Docker 具有 2GB RAM 的 Droplet,克隆了该项目并尝试 运行 它。

到目前为止,我在构建映像和 运行ning 时没有收到任何错误日志。但是,当我尝试访问它时,浏览器出现错误 "This site can’t be reached"。

我正在这样构建我的形象:docker build -t myImage .

然后 运行nig 它并像这样传递我的环境变量:

docker run -p 80:3000 -e NODE_ENV="production" -e MONGO_URI="URI" -e SECRET_OR_KEY="KEY" myImage

一切似乎都工作正常(构建和 运行ning)。我得到了我的 mongodb 已连接的日志,并且服务器正在 运行ning。但是我实际上看不到该应用程序。

这是我的Docker文件:

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) 不同的端口 (5000) 上侦听,这就是节点不会 return 向浏览器发送任何数据的原因。