"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 向浏览器发送任何数据的原因。
我有这个 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 向浏览器发送任何数据的原因。