Docker构建Node.js应用镜像

简介: Docker构建Node.js应用镜像

Docker构建Node.js应用镜像

构建Node.js应用

$ node -v
v16.14.0
$ npm init -y
$ pnpm i express -S
$ pnpm i nodemon -D

package.json

{
  "type": "module",
  "scripts": {
    "dev": "nodemon app.js"
  },
  "dependencies": {
    "express": "^4.18.2"
  },
  "devDependencies": {
    "nodemon": "^2.0.20"
  }
}

app.js

import express from "express";
const PORT = 3000;
const app = express();
app.get("/", (req, res) => {
  res.send("<h1>Hello</h1>");
});
app.listen(PORT, () => {
  console.log(`server start: http://127.0.0.1:${PORT}`);
});

运行 node app.js

查看:http://127.0.0.1:3000/

构建Docker镜像

  • 镜像 image
  • 容器 container
  • 定制镜像文件 Dockerfile

关系:

Dockerfile 
    -> build 构建image
        -> push 推送到DockerHub
        -> pull 拉取从DockerHub
        -> run 运行在container中

VS Code 插件:Docker

搜索镜像:

https://hub.docker.com/

alpine是linux的轻量级发行版

.dockerignore 忽略文件,类似.gitignore

Dockerfile

# 引用基础镜像
FROM node:18-alpine3.15
# 指定工作目录
WORKDIR /app
# 拷贝文件
COPY . .
# 安装依赖
RUN npm install
# 声明暴露端口号
EXPOSE 3000
# 运行镜像里的程序,用数组表示
CMD [ "node", "app.js" ]
# 开发
# CMD [ "npm", "run", "dev" ]

docker指令

# 构建镜像
$ docker build .
# 指定名字
$ docker build -t mouday/express-app:v1.0 .
# 查看镜像
docker images
# 命名格式:用户名/镜像名:版本
# 版本标签默认是latest
docker tag <id> <name>
eg: docker tag 45fe mouday/express-app:v1.0
# 登录
docker login
# 推送镜像到dockerHub
# 在仓库中查看镜像
docker push mouday/express-app:v1.0
# 删除本地镜像 remove image
# -f force强制执行
docker rmi -f mouday/express-app:v1.0
# 从远端拉取镜像
docker pull mouday/express-app:v1.0
# 运行镜像
# -d 后台运行
docker run -d  mouday/express-app:v1.0
# 端口映射
docker run -d  -p 3000:3000 mouday/express-app:v1.0
# 指定名字
docker run -d  -p 3000:3000 --name express-app mouday/express-app:v1.0
# 查看运行中的镜像 process status
docker ps
# 包括暂停运行的容器
docker ps -a
# 关机
docker stop 容器id
# 移除容器
docker rm -f 容器id
# 同时移除volume
docker rm -fv 容器id
# 移除所有容器
$ docker ps -a | grep -v CONTAINER |awk '{print "docker rm -f " $1}' | sh
# 以终端方式运行
docker exec -it 容器id /bin/sh
# 退出
$ exit

本地文件夹和容器文件夹绑定

# 命令行方式需要使用绝对路径
# -v volume
docker run -d -v /path/app:/app -p 3000:3000 --name app mouday/express-app:v1.0
# 不同步node_modules文件夹
# ro本地只读 read only
docker run -d -v /path/app:/app:ro -v /app/node_modules -p 3000:3000 --name app mouday/express-app:v1.0

docker-compose

docker-compose.yml

version: "3.8"
services:
    app:
        build: . 
        ports:
            - "3000:3000"
        volumes:
            - ./:/app:ro
            - /app/node_modules

docker-compose命令

# 启动
docker-compose up -d --build
# 停止
docker-compose down -v

使用CentOS 镜像

# 拉取指定版本的 CentOS 镜像
docker pull centos:centos7
# 查看本地镜像
docker images
# 运行容器
docker run -itd --name centos-test --privileged centos:centos7
# 查看容器的运行信息
docker ps
# 进入容器
docker exec -it <容器id> /bin/sh
cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)

参考 🐳Docker概念,工作流和实践 - 入门必懂


相关文章
|
5天前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
|
8天前
|
JSON JavaScript 测试技术
【Docker项目实战】使用Docker部署PPTist在线演示文稿应用
【10月更文挑战第9天】使用Docker部署PPTist在线演示文稿应用
15 1
【Docker项目实战】使用Docker部署PPTist在线演示文稿应用
|
8天前
|
运维 JavaScript 虚拟化
探索容器化技术:Docker的实践与应用
【10月更文挑战第9天】探索容器化技术:Docker的实践与应用
33 3
|
8天前
|
JavaScript 前端开发 API
Vue.js:打造高效前端应用的最佳选择
【10月更文挑战第9天】Vue.js:打造高效前端应用的最佳选择
11 2
|
8天前
|
设计模式 JavaScript 前端开发
探索JavaScript中的闭包:从基础概念到实际应用
在本文中,我们将深入探讨JavaScript中的一个重要概念——闭包。闭包是一种强大的编程工具,它允许函数记住并访问其所在作用域的变量,即使该函数在其作用域之外被调用。通过详细解析闭包的定义、创建方法以及实际应用场景,本文旨在帮助读者不仅理解闭包的理论概念,还能在实际开发中灵活运用这一技巧。
|
9天前
|
缓存 JavaScript 前端开发
深入了解JavaScript的闭包:概念与应用
【10月更文挑战第8天】深入了解JavaScript的闭包:概念与应用
|
5天前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript中的闭包:原理、应用与代码演示
【10月更文挑战第12天】深入理解JavaScript中的闭包:原理、应用与代码演示
|
6天前
|
监控 JavaScript 前端开发
深入了解Vue.js:构建现代前端应用的利器
【10月更文挑战第11天】深入了解Vue.js:构建现代前端应用的利器
10 0
|
6天前
|
前端开发 JavaScript 开发者
深入了解Webpack:现代JavaScript应用的打包利器
【10月更文挑战第11天】 深入了解Webpack:现代JavaScript应用的打包利器
|
6天前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript闭包:原理与应用
【10月更文挑战第11天】深入理解JavaScript闭包:原理与应用
9 0