- 建立一个文件夹
- 用管理员身份打开powershell.
- 在文件夹下面运行npm init, 根据提示填入信息,以便产生一个package.json文件。
- 在文件中加入需要的dependencies,例如:
- {
- "name": "docker_web_app",
- "version": "1.0.0",
- "description": "Node.js on Docker",
- "author": "First Last <first.last@example.com>",
- "main": "server.js",
- "scripts": {
- "start": "node server.js"
- },
- "dependencies": {
- "express": "^4.13.3"
- }
- }
4. 创建一个app.js文件,例如:
const express = require('express') const app = express()
app.get('/', function (req, res) { res.send('Hello World!') })
app.listen(3000, function () { console.log('Example app listening on port 3000!') }) |
5. 创建一个空文件名字为Dockerfile,填入如下内容:
FROM node:boron
# Create app directory WORKDIR /app
# Install app dependencies COPY package.json . # For npm@5 or later, copy package-lock.json as well # COPY package.json package-lock.json ./
RUN npm install
# Bundle app source COPY . .
EXPOSE 3000 CMD [ "node", "app.js" ] |
6. 创建名为.dockerignore的文件,并输入如下的内容:
node_modules npm-debug.log |
这是为了防止本地的module和debug log被拷贝进docker image.
(我这一步无法做,因为没有办法创建这样的文件,总是要求必须有文件名。需要进一步调查)
7. Build image
docker build -t nodehello . |
8. 运行image.
docker run -p 3000:3000 -d nodehello |
如果运行成功,会出现Example app listening on port 3000的字样。
这时访问http://localhhost:3000 就可以访问app.js中定义的内容了。
参考文章:
https://nodejs.org/en/docs/guides/nodejs-docker-webapp/
https://www.distelli.com/docs/tutorials/build-and-deploy-nodejs-with-docker/
https://expressjs.com/en/starter/hello-world.html
https://docs.docker.com/get-started/part2/#build-the-app
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
2016-10-20 ATL开发 ActiveX控件的 inf文件模板