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概念,工作流和实践 - 入门必懂


相关文章
|
29天前
|
Web App开发 JavaScript 前端开发
构建高效后端服务:Node.js与Express框架的实战指南
【9月更文挑战第6天】在数字化时代的潮流中,后端开发作为支撑现代Web和移动应用的核心,其重要性不言而喻。本文将深入浅出地介绍如何使用Node.js及其流行的框架Express来搭建一个高效、可扩展的后端服务。通过具体的代码示例和实践技巧,我们将探索如何利用这两个强大的工具提升开发效率和应用性能。无论你是后端开发的新手还是希望提高现有项目质量的老手,这篇文章都将为你提供有价值的见解和指导。
|
7天前
|
Web App开发 JavaScript 前端开发
构建高效Web应用:Node.js与Express框架的深度整合
【9月更文挑战第28天】在现代Web开发领域,Node.js和Express框架的结合已成为打造高性能、易扩展应用的黄金组合。本文将深入探讨如何利用这一技术栈优化Web应用架构,提供具体实践指导,并分析其性能提升的内在机制。通过代码示例,我们将展示从基础搭建到高级功能的实现过程,旨在为开发者提供一条清晰的学习路径,以实现技术升级和项目效率的双重提升。
20 3
|
9天前
|
JavaScript 开发者
深入理解Node.js事件循环及其在后端开发中的应用
【8月更文挑战第57天】本文将带你走进Node.js的事件循环机制,通过浅显易懂的语言和实例代码,揭示其背后的工作原理。我们将一起探索如何高效利用事件循环进行异步编程,提升后端应用的性能和响应速度。无论你是Node.js新手还是有一定经验的开发者,这篇文章都能给你带来新的启发和思考。
|
17天前
|
缓存 监控 JavaScript
构建高效后端服务:Node.js与Express框架的完美结合
【9月更文挑战第18天】在数字化时代的浪潮中,后端服务的效率和稳定性成为了企业竞争力的关键。本文将深入探讨如何使用Node.js和Express框架来构建一个既高效又稳定的后端服务,同时通过实际代码示例,展示如何优化性能并确保服务的高可用性。
|
24天前
|
Web App开发 缓存 JavaScript
构建高效后端服务:Node.js与Express框架的完美结合
【9月更文挑战第11天】本文将引导开发者探索如何利用Node.js和Express框架搭建一个高效的后端服务。文章不仅深入讲解了这两个工具的核心概念,还通过实际示例展示了它们的强大功能和易用性。读者将学会如何处理HTTP请求、设计RESTful API以及优化应用性能。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的知识,帮助你在后端开发领域更进一步。
|
6天前
|
C++ Windows
HTML+JavaScript构建C++类代码一键转换MASM32代码平台
HTML+JavaScript构建C++类代码一键转换MASM32代码平台
|
6天前
|
C++
HTML+JavaScript构建一个将C/C++定义的ANSI字符串转换为MASM32定义的DWUniCode字符串的工具
HTML+JavaScript构建一个将C/C++定义的ANSI字符串转换为MASM32定义的DWUniCode字符串的工具
|
7天前
|
JSON JavaScript 前端开发
构建高效Web应用:Node.js与Express框架的完美结合
【9月更文挑战第28天】在现代Web开发中,Node.js和Express框架的结合为创建高性能、易扩展的应用提供了强有力的支持。本文将深入探讨如何利用这两种技术构建一个简单但功能强大的Web服务,同时提供代码示例以加深理解。
|
9天前
|
JavaScript 前端开发 开发者
深入浅出 Vue.js:构建响应式前端应用
Vue.js 是一个流行的前端框架,以其简洁、高效和易学著称。它采用响应式和组件化设计,简化了交互式用户界面的构建。本文详细介绍 Vue.js 的核心概念、基本用法及如何构建响应式前端应用,包括实例、模板、响应式数据和组件等关键要素,并介绍了项目结构、Vue CLI、路由管理和状态管理等内容,帮助开发者高效地开发现代化前端应用。
|
12月前
|
存储 分布式计算 Hadoop
基于docker的Hadoop环境搭建与应用实践(脚本部署)
本文介绍了Hadoop环境的搭建与应用实践。对Hadoop的概念和原理进行了简要说明,包括HDFS分布式文件系统和MapReduce计算模型等,主要通过脚本的方式进行快捷部署,在部署完成后对HDFS和mapreduce进行了测试,确保其功能正常。
下一篇
无影云桌面