【发布时间】:2019-01-08 21:56:10
【问题描述】:
我是第一次运行 docker,我的容器在 docker run 命令后立即退出。 docker ps 向我展示了一个空列表。当我运行docker ps -a 时,我得到了我在退出状态下推送的所有容器的结果。
我尝试过使用-ti 命令,但容器处于退出状态。
我正在使用以下命令来运行文件:$ sudo docker build -t test_api3 . 和 $ sudo docker run -p 8080:3000 -ti test_api3 或 ($ sudo docker run -p 8080:3000 -d test_api3)
Dockerfile
FROM node:8
WORKDIR /usr/src/app
COPY package*.json ./
RUN npm install
COPY . .
EXPOSE 3000
CMD [ "npm","start" ]
package.json
{
"name": "firstapp",
"version": "1.0.0",
"description": "first demo app",
"main": "http-server.js",
"scripts": {
"start": "node http-server.js"
},
"keywords": [
"S"
],
"author": "test",
"license": "ISC"
}
http-server.js
const http = require('http');
const hostname = '127.0.0.1';
const port = 3000;
const server = http.createServer((req, res) => {
res.statusCode = 200;
res.setHeader('Content-Type', 'text/plain');
res.end('Hello World\n');
});
server.listen(port, hostname, () => {
console.log(`Server running at http://${hostname}:${port}/`);
});
【问题讨论】:
-
日志说什么?你可以在它退出后立即运行
docker logs $(docker ps -lq)以获取上次运行容器的日志。 -
我的问题已解决,但不知何故我无法运行该命令。
docker logs给我的错误是“docker logs”需要正好 1 个参数。我无法获取容器的日志。
标签: node.js docker docker-compose dockerfile port