当前位置: 首页 > article >正文

Dockerfile从零入门:手把手教你打包Node.js应用,解决镜像构建的常见坑

代码写完了在本地跑得好好的怎么把它打包成Docker镜像部署到服务器上答案就是Dockerfile。今天这篇文章我们用Node.js应用做例子从零开始写一个Dockerfile把应用打包成镜像顺便把常见的坑都踩一遍。一、Dockerfile是什么Dockerfile是一个文本文件里面写着“如何构建这个镜像”的所有指令。它就像一张蓝图Docker按照这张蓝图把应用打包成镜像。重要文件名必须叫Dockerfile首字母大写没有后缀名。二、写一个最简单的Dockerfile我们的Node.js应用需要运行在Node环境里所以第一件事是找一个带Node的基础镜像dockerfileFROM node:20-alpineFROM是所有Dockerfile的第一行指定基础镜像。这里用了node:20-alpine——一个轻量级的Node镜像体积小适合生产环境。三、复制代码并安装依赖把代码复制进镜像然后安装依赖dockerfile# 创建应用目录 RUN mkdir -p /home/app # 复制所有文件 COPY . /home/app # 设置工作目录 WORKDIR /home/app # 安装依赖 RUN npm install注意几点RUN是在构建镜像时执行的命令COPY是从宿主机复制文件到镜像里WORKDIR设置工作目录后面的命令都会在这个目录下执行一个常见错误不要把本地的node_modules复制进镜像。因为本地依赖可能是旧版本应该在镜像里重新npm install保证依赖是最新的。四、指定启动命令最后告诉容器启动时运行什么dockerfileCMD [node, server.js]CMD是容器启动时执行的命令。一个Dockerfile只能有一个CMD。完整的DockerfiledockerfileFROM node:20-alpine ENV MONGO_DB_USERNAMEadmin \ MONGO_DB_PWDpassword RUN mkdir -p /home/app COPY . /home/app WORKDIR /home/app RUN npm install CMD [node, server.js]五、构建镜像在Dockerfile所在目录执行bashdocker build -t my-app:1.0 .-t my-app:1.0给镜像起名字和版本号.Dockerfile所在的路径当前目录构建完成用docker images就能看到新镜像。六、运行容器bashdocker run my-app:1.0如果一切正常你会看到app listening on port 3000!。如果报错用docker logs查看日志。七、踩坑与解决坑1找不到server.js现象启动容器报错Error: Cannot find module /server.js。原因没有设置WORKDIRCMD里的相对路径找不到文件。解决加上WORKDIR /home/app。坑2进入容器报错bash: not found现象docker exec -it 容器ID /bin/bash报错。原因Alpine基础镜像没有安装bash。解决用/bin/sh代替/bin/bash。bashdocker exec -it 容器ID /bin/sh坑3修改Dockerfile后镜像没变现象改了Dockerfile重新构建后还是老样子。原因Docker不会自动删除旧镜像你还在用旧的。解决先删旧容器再删旧镜像最后重新构建。bash# 查看所有容器包括已停止的 docker ps -a # 删除旧容器 docker rm 容器ID # 删除旧镜像 docker rmi my-app:1.0 # 重新构建 docker build -t my-app:1.0 .八、优化只复制需要的文件上面的例子把整个项目目录都复制进了镜像包括Dockerfile、README等不需要的文件。可以这样优化dockerfile# 只复制app目录下的文件 COPY ./app /home/app或者用.dockerignore文件排除不需要的文件类似.gitignore。写在最后Dockerfile的核心就几条指令FROM选基础镜像COPY复制代码RUN装依赖CMD定启动命令。记住几个关键点文件名必须是DockerfileRUN是构建时执行CMD是启动时执行修改Dockerfile后要先删旧镜像再重新构建轻量镜像用/bin/sh而不是/bin/bash掌握了这些你就能把任何应用打包成Docker镜像了。

相关文章:

Dockerfile从零入门:手把手教你打包Node.js应用,解决镜像构建的常见坑

代码写完了,在本地跑得好好的,怎么把它打包成Docker镜像,部署到服务器上?答案就是Dockerfile。今天这篇文章,我们用Node.js应用做例子,从零开始写一个Dockerfile,把应用打包成镜像,顺…...

AI显微镜-Swin2SR惊艳效果展示:JPG噪点去除+边缘重构真实案例

AI显微镜-Swin2SR惊艳效果展示:JPG噪点去除边缘重构真实案例 1. 引言:当模糊图片遇见AI“脑补” 你有没有遇到过这种情况?翻出多年前的老照片,却发现它模糊不清,布满了马赛克和噪点;或者从网上下载了一张…...

从0到1学会使用PageHelper

本文的思维导图为什么我们需要PageHelper?想象一下,你经营着一家餐厅,有顾客要点菜了,就比如:“鱼香肉丝”,你要把菜端给顾客。这时候,你要怎么把菜给顾客呢(如何把数据展示给前端)?你有三个解…...

iOS / SwiftUI 输入法(键盘)布局处理总结(AI版)

文章目录📘 iOS / SwiftUI 输入法(键盘)处理总结一、问题背景二、输入框切换闪烁问题❌ 错误原因解决办法键盘动画(类似 Android Insets)uikitswiftUI📘 iOS / SwiftUI 输入法(键盘)…...

解锁Windows 10的Android生态:3大革新功能让跨设备体验无缝融合

解锁Windows 10的Android生态:3大革新功能让跨设备体验无缝融合 【免费下载链接】WSA-Windows-10 This is a backport of Windows Subsystem for Android to Windows 10. 项目地址: https://gitcode.com/gh_mirrors/ws/WSA-Windows-10 副标题:WS…...

直播录制从未如此简单:StreamCap 40+平台自动录制全攻略

直播录制从未如此简单:StreamCap 40平台自动录制全攻略 【免费下载链接】StreamCap Multi-Platform Live Stream Automatic Recording Tool | 多平台直播流自动录制客户端 基于FFmpeg 支持监控/定时/转码 项目地址: https://gitcode.com/gh_mirrors/st/StreamCa…...

IDEA中使用Claude Code

1、先安装好node.js 安装好之后验证是否安装成功 nodejs下载安装地址https://nodejs.p2hp.com/安装结束后,执行以下命令查看安装结果,若显示版本号则安装成功。 node --version 2、使用npm安装Claude Code ​​​​​​​npm install -g anthropic-ai…...

农旅电商运营必备:初级认证考试中的5大高频考点与避坑指南

农旅电商运营必备:初级认证考试中的5大高频考点与避坑指南 农旅电商作为乡村振兴战略下的新兴业态,正在经历从粗放式增长到精细化运营的关键转型期。对于准备参加初级认证考试的从业者而言,系统掌握核心运营逻辑远比死记硬背更重要。根据近三…...

正点原子lwIP实战解析——PHY芯片LAN8720A与YT8512C的配置与应用

1. 认识PHY芯片:网络通信的"翻译官" 当你用网线连接开发板时,数据究竟是如何从物理信号变成单片机可处理的数字信号的?这个关键角色就是PHY芯片。简单来说,PHY就像个精通多国语言的翻译官——它把网线里的模拟信号&…...

超高效!这款音视频转文字神器,让你告别手动输入!

今天给大家推荐一款非常实用的软件——“Whisper”,它是一款功能强大的音视频转文字工具。这款软件是绿色版,双击打开后,会弹出一个黑色的界面框,请不要关闭它。使用这款软件非常简单。首先,点击【选择文件】按钮&…...

科技企业如何借助智能工具加快技术研发与市场推广?

观点作者:科易网-国家科技成果转化(厦门)示范基地现状概述:科技成果转化与市场推广的双重困境 在数智时代,技术转移与成果转化正经历深刻变革。一方面,海量数据成为创新的核心要素,但传统科技企…...

Dify开发AI智能体的费用

Dify 的计费逻辑与 Coze 有显著不同,它最大的特点是“开源免费”与“云端订阅”并存。由于它不强制绑定大模型,你的总支出通常由“平台费 模型流量费”两部分组成。以下是截至 2026 年 4 月的详细费用拆解:1. 部署模式决定基础费用开源社区版…...

模力方舟:国内AI开发者的全流程加速平台

模力方舟:国内AI开发者的全流程加速平台 在AI技术快速发展的当下,如何让开发者更高效地将创意转化为实际应用成为行业关键命题。由Gitee推出的模力方舟(MoArk)平台,通过整合模型体验、微调训练、推理部署到应用变现的全流程能力,为…...

小电脑4种主流连接方案全解:直连屏/采集卡/网卡网线/NoMachine

在使用嵌入式开发板、迷你主机、机器人机载小电脑等设备时,如何高效连接、显示画面、远程控制是入门第一步。很多同学容易混淆“直连网线、网卡、采集卡、远程桌面”的区别,本文一次性讲清楚四种常用连接方式,包含用途、所需硬件、详细操作、…...

基于51单片机的太阳能追光系统设计与仿真:包含光敏控制、电机调速及两种模式的太阳跟踪系统

基于51单片机的太阳能追光系统设计,太阳跟踪系统设计,光敏控制系统protues仿真设计。 有仿真,程序,AD图,原文,相关资料。 本系统可以通过光敏电阻调节电机转速,有手动模式和我自动模式。 适用于…...

为什么你的STM32 DMA传输失败了?__HAL_LINKDMA宏的隐藏陷阱与解决方案

为什么你的STM32 DMA传输失败了?__HAL_LINKDMA宏的隐藏陷阱与解决方案 在STM32开发中,DMA(直接内存访问)传输是提升外设数据吞吐效率的关键技术。然而,许多开发者在实际项目中都会遇到DMA传输失败的问题,而…...

k8s与docker compose的思考

1.稍微复杂2.ip会漂移,各种端口转发性能有所损失。3.占用一定的资源4.master需要高可用5.更适合web无状态docker-compose则比较简单,搭建本地环境就一个配置文件的事情,简直是本地test环境神器。...

为什么又来学习C语言?

我是一名来自民办二本院校的大三学生,早在大一上时学校就安排了C语言的课程,但是当时我很是浮躁,心不在学习,甚至想着回去复读,所以并没有吸纳多少C语言的知识。现在大三,有了考研想法,想重拾C语…...

课堂笔记4月2日

1、计算机核心资源 CPU: 计算(lscpu)内存: 缓存数据(掉电丢失)硬盘: 持久化存储数据网络: 传播数据 2、查看 CPU 信息# 查看CPU[rootC001 ~]# lscpu Architecture: x86_64 CPU op-mod…...

杨氏矩阵找第N大(小)的O(N)线性算法 LeetCode 378. Kth Smallest Element in a Sorted Matrix 373. Find K Pairs 钓鱼问题

杨氏矩阵&#xff1a;一个N*N的矩阵&#xff0c;它的每行每列都单调递增(或者宽松一些,单调不减)&#xff0c;即a[i][j]<a[i1][j], a[i][j]<a[i][j1]。遇到的两道面试题&#xff1a; 1. 输出杨氏矩阵中最小的N个数。 2. 两个升序数组A和B&#xff0c;长度都是N。从两个数…...

我用AI替换了高级工程师,结果...

周二下午 2:47&#xff0c;我们的 CFO 在 Slack 上发了一条消息。 “你团队的年薪是 120 万美元。我们能谈谈优化吗&#xff1f;” 我知道要发生什么了。我们刚刚完成了 A 轮融资。风投想要"运营效率"。翻译&#xff1a;削减成本、更快交付、展示增长。 我们的高级…...

【等保合集】800余份等保三级、等保2.0、等保二级、等保测评作业指导、全套信息安全管理体系文件、标准规范方案报告合集(PPT+WORD+PDF)

等保2.0以GB/T 22239-2019为核心&#xff0c;二级&#xff08;指导保护级&#xff09;与三级&#xff08;监督保护级&#xff09;在身份认证、数据加密、备份恢复及管理制度上差异显著。测评作业指导书依据GB/T 28448编制&#xff0c;覆盖十大安全类&#xff1b;信息安全管理体…...

MBTI职业性格测试

...

【GIS操作指南】ArcMap界面坐标单位一键切换:从平面到经纬度的实战设置

1. 为什么需要切换坐标单位&#xff1f; 刚接触ArcMap的朋友可能会发现&#xff0c;软件右下角默认显示的坐标单位往往是米或千米这类平面单位。但在处理带有地理坐标的数据时&#xff0c;比如气象数据、GPS轨迹或者行政区划边界&#xff0c;我们更习惯使用经纬度来定位。这就好…...

手把手教你为RK3568(arm64)交叉编译BlueZ:利用Buildroot已有环境快速出包

手把手教你为RK3568&#xff08;arm64&#xff09;交叉编译BlueZ&#xff1a;利用Buildroot已有环境快速出包 在嵌入式Linux开发中&#xff0c;蓝牙协议栈BlueZ的交叉编译一直是让开发者头疼的问题。特别是当目标平台采用arm64架构时&#xff0c;依赖库的复杂性和工具链的配置难…...

从零搭建PX4无人机仿真环境:Gazebo场景构建与Offboard模式初探

1. 环境准备&#xff1a;从零搭建PX4开发基础 第一次接触PX4无人机开发的朋友&#xff0c;往往会被复杂的工具链吓到。其实只要跟着正确的步骤走&#xff0c;半小时内就能搭建好完整的仿真环境。我用的是一台装好Ubuntu 20.04的笔记本&#xff0c;建议至少预留30GB磁盘空间。 关…...

海康工业相机——Python二次开发实战:构建实时条形码识别系统

1. 环境准备与硬件选型 第一次接触海康工业相机时&#xff0c;我被它金属外壳下的精密光学元件震撼到了。这种工业级设备和我们平时用的消费级摄像头完全不同&#xff0c;它的稳定性、帧率和图像质量完全是为生产线环境设计的。如果你手头正好有台海康相机&#xff0c;跟着我的…...

别再只盯着输入了!时间序列预测中,被忽视的‘标签自相关’问题与FreDF解法

时间序列预测的盲区&#xff1a;标签自相关性如何悄悄破坏你的模型精度 想象一下&#xff0c;你花费数周时间调整模型架构、优化超参数&#xff0c;甚至尝试了最新的Transformer变体&#xff0c;但预测结果始终差强人意。问题可能并不出在你精心设计的输入特征工程上&#xff0…...

ESP32定时器深度解析:从基础API到低功耗场景实战

1. ESP32定时器基础入门 第一次接触ESP32的硬件定时器时&#xff0c;我被它强大的功能和灵活的配置选项深深吸引。相比常见的软件定时器&#xff0c;ESP32的硬件定时器能提供微秒级精度和64位计时范围&#xff0c;这在物联网设备开发中简直是神器。 举个生活中的例子&#xff0…...

Pyinstaller:打包Python文件成exe可执行文件

1、pyinstaller安装pip install pyinstaller -i https://pypi.tuna.tsinghua.edu.cn/simple2、打包单个文件如果所有代码是写在一个.py文件里的&#xff0c;可以尝试使用这种方式pyinstaller -F filesname.py成功运行后会在桌面生成三个文件&#xff1a;可执行文件.exe就在dist…...