【问题标题】:"This site can’t be reached" Docker container on Digital Ocean“无法访问此站点”Digital Ocean 上的 Docker 容器
【发布时间】: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


【解决方案1】:

您似乎让 docker 在与节点应用程序 (3000) 不同的端口 (5000) 上侦听,这就是节点不会向浏览器返回任何数据的原因。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-08-17
    • 2021-10-26
    • 2021-10-07
    • 2017-02-25
    • 2020-05-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多