【Docker 从入门到实战全攻略(二):核心概念 + 命令详解 + 部署案例】
5. Docker Compose
Docker Compose 是一个用于定义和运行多容器 Docker 应用的工具。通过一个 YAML 文件来配置应用服务,然后使用一个命令即可创建并启动所有服务。
- 基本命令
docker-compose up
# 创建并启动所有服务
docker-compose down
# 停止并移除容器、网络等
docker-compose ps
# 查看运行状态
docker-compose logs
# 查看服务日志 - 示例配置文件
version: '3'
services:web:build: . # 使用当前目录的Dockerfile构建镜像ports:- "5000:5000" # 映射端口volumes:- .:/code # 挂载当前目录到容器内/code目录depends_on:- redis # 依赖redis服务redis:image: redis:alpine # 使用官方redis镜像volumes:- redis-data:/data # 挂载数据卷volumes:redis-data: # 定义数据卷
6. Dockerfile
6.1 Dockerfile
Dockerfile 是一个文本文件,用于定义 Docker 镜像的构建过程。通过编写 Dockerfile,可以自动化创建自定义镜像,确保镜像内容的一致性和可重复性。
- Dockerfile 的基本结构:
--------------创建镜像运行----------------------
# 基础镜像
FROM ubuntu:20.04# 维护者信息
LABEL maintainer="your@email.com"# 安装依赖
RUN apt-get update && apt-get install -y \python3 \python3-pip# 复制应用代码
COPY . /app
WORKDIR /app# 安装应用依赖
RUN pip3 install -r requirements.txt# 暴露端口
EXPOSE 8080
-------------执行容器运行-----------------------
# 定义启动命令
CMD ["python3", "app.py"]
6.2 指令
Dockerfile是一堆指令,在docker build的时候,按照该指令进行操作,最终生成我们期望的镜像
- FROM 指定基础镜像,必须为第一个命令
格式:
FROM <image>:<tag>
示例:
FROM mysql:5.7
注意:
tag是可选的,如果不使用tag时,会使用latest版本的基础镜像 - MAINTAINER 镜像维护者的信息
格式:
MAINTAINER <name>
示例:
MAINTAINER wupeiqi
MAINTAINER wupeiqi@live.com
MAINTAINER wupeiqi <wupeiqi@live.com>
- ENV 设置环境变量
格式:
ENV <key> <value>
ENV <key>=<value>
示例:
ENV myName John
ENV myCat=fluffy
- COPY|ADD 添加本地文件到镜像中 app.py /data/www/info/app.py
格式:
COPY <src>... <dest>
示例:
ADD hom* /mydir/
# 添加所有以"hom"开头的文件
ADD test relativeDir/
# 添加 “test” 到 $WORKDIR/relativeDir/
ADD test /absoluteDir/
# 添加 “test” 到 /absoluteDir/
注意:针对压缩包使用ADD的话,会自动解压。
- WORKDIR 工作目录
格式:
WORKDIR /path/to/workdir
示例:
WORKDIR /a
(这时工作目录为/a)
注意:
通过WORKDIR设置工作目录后,Dockerfile中其后的命令RUN、CMD、ENTRYPOINT、ADD、COPY等命令都会在该目录下执行 - RUN 构建镜像过程中执行命令
格式:
RUN <command>
示例:
RUN yum install nginx
RUN pip install django
RUN mkdir test && rm -rf /var/lib/unusedfiles
注意:
RUN指令创建的中间镜像会被缓存,并会在下次构建中使用。如果不想使用这些缓存镜像,可以在构建时指定--no-cache
参数,如:docker build --no-cache
- CMD 构建容器后调用,也就是在容器启动时才进行调用
格式:
CMD ["executable","param1","param2"]
(执行可执行文件,优先)
CMD ["param1","param2"]
(设置了ENTRYPOINT,则直接调用ENTRYPOINT添加参数)
CMD command param1 param2
(执行shell内部命令)
示例:
CMD ["/usr/bin/wc","--help"]
CMD ping www.baidu.com
注意:
CMD不同于RUN,CMD用于指定在容器启动时所要执行的命令,而RUN用于指定镜像构建时所要执行的命令。 - ENTRYPOINT 设置容器初始化命令,使其可执行化
格式:
ENTRYPOINT ["executable", "param1", "param2"]
(可执行文件, 优先)
ENTRYPOINT command param1 param2
(shell内部命令)
示例:
ENTRYPOINT ["/usr/bin/wc","--help"]
注意:
ENTRYPOINT与CMD非常类似,不同的是通过docker run执行的命令不会覆盖ENTRYPOINT,
而docker run命令中指定的任何参数,都会被当做参数再次传递给ENTRYPOINT。
Dockerfile中只允许有一个ENTRYPOINT命令,多指定时会覆盖前面的设置,而只执行最后的ENTRYPOINT指令
CMD 与 ENTRYPOINT 区别
- 使用以下dockerfile构建镜像后执行docker run 镜像id -l会发生报错,因为 docker run 执行的 -l 会覆盖 CMD ,而 -l 不是命令所以报错
- 使用以下dockerfile构建镜像后执行docker run 镜像id -l会正常运行,因为 docker run 执行的 -l 会作为参数传给 ENTRYPOINT
- EXPOSE 暴漏端口
格式:
EXPOSE <port> [<port>...]
示例:
EXPOSE 80 443
EXPOSE 8080
EXPOSE 11211/tcp 11211/udp
注意:
就是一个端口的标识,实际开发时,没什么意义。因为端口的映射会在run命令时进行指定。
6.3 构建镜像与运行容器
- 编写 Dockerfile:创建一个名为 Dockerfile 的文件,定义镜像构建步骤。
- 构建镜像:使用 docker build 命令构建镜像:
docker build -t myapp:1.0 -f Dockerfile --no-cache
.
其中,-t
指定镜像标签,.
表示使用当前目录的 Dockerfile。–no-cache表示无缓存 docker image ls
或者docker images
查看所创建的镜像- 运行容器:使用 docker run 命令基于镜像创建并运行容器:
docker run -d -p 8080:8080 myapp:1.0
其中,-d
表示后台运行,-p 8080:8080
表示将容器的 8080 端口映射到主机的 8080 端口。
实操:
- 创建一个 Dockerfile1 , 并修改文件内容,定义一个简单镜像构建步骤:
- docker build 构建镜像
docker build -f /data1/lsr/dockerfile_test/dockerfile1 -t test/centos:1.0 .
# . 表示当前目录作为构建上下文,注意不要忘记
- 启动容器,可以看到生成容器时挂载的两个数据卷目录 volume01 和 volume02
- 查看该容器的详细信息,可以看到挂载的两个匿名挂载的数据卷(生成在随机目录里)
- 重新进入该容器的其中一个数据卷文件夹中,创建一个新文件
- 退出容器并转到第4步中查询到的数据卷挂载目录下,发现数据被同步
6.3.1 练习:构建自己的 ubantu
-
编写 dockerfile 的文件
-
通过该文件构建镜像
docker build -f /data1/lsr/dockerfile_test/dockerfile1 -t myubuntu:0.1 .
docker build -f dockerfile文件路径 -t 镜像名:版本号 .
构建成功 -
启动容器并验证 vim 是否安装成功,发现 vim 可正常使用,且工作目录更改为 /usr/local
6.3.2 Docker history 查看镜像构建历史信息
6.4 拉取镜像与运行容器
docker pull [用户名/DockerHub镜像名称]
docker run [镜像名]
7. 容器数据卷(Volume)
容器数据卷(Container Data Volume)是容器技术(如 Docker)中用于实现数据持久化存储、跨容器共享数据的核心机制。它允许将容器内的数据独立存储在宿主机或外部存储中,避免因容器重启、删除导致数据丢失,同时支持多个容器之间的数据同步。
docker volume COMMAND
Commands:
create
创建一个卷
inspect
展示卷的细节
ls
卷列表
prune
移除当地未使用的卷
rm
移除卷
7.1 命名卷 / 命名挂载
- 特点:
- 由 Docker 自动管理宿主机存储路径(默认位于 /var/lib/docker/volumes/),无需手动指定宿主机路径。
- 支持卷驱动(Volume Driver),可扩展至云存储(如 AWS EBS、阿里云 OSS)或分布式存储(如 NFS)。
- 数据隔离性好,适合生产环境,便于统一备份和迁移。
- 操作示例
# 创建命名卷
docker volume create my-vol# 运行容器并挂载命名卷(容器内路径:/app/data)
docker run -d -v my-vol:/app/data nginx# 查看命名卷详情(宿主机实际存储路径)
docker volume inspect my-vol
7.2 匿名卷 / 匿名挂载
- 特点:由 Docker 自动生成随机名称,通常用于临时存储或一次性数据。
docker run -v /container/path ...
# 匿名卷(省略名称)
命名挂载
匿名挂载
7.3 命名卷 VS 匿名卷
7.4 绑定挂载(Bind Mount)
- 特点:
- 直接挂载宿主机本地路径或文件到容器中,灵活性高但依赖宿主机文件系统。
- 适合开发场景(如本地代码实时同步到容器),但不支持跨主机共享,且需手动管理宿主机路径权限。
- 操作示例:
- #挂载宿主机路径 /data1/lsr/test 到容器的 /home 路径
docker run -it -v /data1/lsr/test:/home nginx
# -v 参数绑定挂载- 查看容器进程
docker inspect 02ba2d57f12e
# 查看该容器源数据,发现已经完成容器与主机的绑定挂载
- 测试,在容器中添加新文件,发现同一时间主机中也会增加该新增的文件
同样的,在主机中添加或修改文件,也可同步到容器中去,不管容器是否在运行
- 设置容器权限
容器内只读,只能通过宿主机修改:docker run -it -v /data1/lsr/test:/home:ro nginx
容器可读也可写:docker run -it -v /data1/lsr/test:/home:rw nginx
7.5 练习 Mysql 数据持久化
-
docker run -d -p 3310:3306 -v /data1/lsr/mysql/conf:/etc/mysql/conf.d -v /data1/lsr/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=2020 --name mysql01 mysql
#-d 后台运行、-p 暴露端口将3310和容器内3306映射、-v 绑定挂载数据卷,可挂载多个 、-e 配置环境,设置数据库密码
-
去数据库中检验连接成功,
-
新建一个数据库ronghaha,可分别从容器中以及主机中查看到相关数据
8. 数据卷容器
多个容器间如何同步数据
实战
- 创建一个新容器 docker01,创建后 ctrl + P + Q 容器不停止退回到主机
- 再创建一个 新容器 docker02 并于 docker01 进行挂载
- 在 docker01 的 volume1 目录中添加一个新文件 docker01,发现 docker02 的 volume1 的数据也会同步,反之在 修改 docker02 的 volume2 2,发现 docker01 的 volume2 的数据也会同步
docker02 中新增 docker02 文件
docker01 同步更新数据
- 删掉容器 docker01,发现 docker02 中的数据不变
多个 mysql 实现数据共享(两种方法)
docker run -d -p 3310:3306 -v /etc/mysql/conf.d -v /var/lib/mysql -e MYSQL_ROOT_PASSWORD=2020 --name mysql01 mysql
docker run -d -p 3310:3306 -e MYSQL_ROOT_PASSWORD=2020 --name mysql02 --volumes-from mysql01 mysql
创作不易,求点赞,求收藏呀|ू・ω・` )
相关文章:

【Docker 从入门到实战全攻略(二):核心概念 + 命令详解 + 部署案例】
5. Docker Compose Docker Compose 是一个用于定义和运行多容器 Docker 应用的工具。通过一个 YAML 文件来配置应用服务,然后使用一个命令即可创建并启动所有服务。 基本命令 docker-compose up # 创建并启动所有服务 docker-compose down # 停止并移除容器、网络等…...
Elasticsearch索引(Index)介绍,它与数据库中的表有什么区别?
在Elasticsearch(ES)中,索引(Index)是存储和组织文档(Document)的逻辑容器,类似于关系型数据库(如MySQL)中的“数据库(Database)”或“表(Table)”,但设计理念和实现机制有显著差异。以下从定义、核心特性、与数据库表的对比三方面详细解析。 一、索引的定义与…...
Elasticsearch中什么是分析器(Analyzer)?它由哪些组件组成?
在Elasticsearch(ES)中,分析器(Analyzer)是处理文本的核心组件,负责将原始文本转换为适合索引和搜索的词项(Term)。它直接影响搜索的准确性和性能,是构建高效搜索系统的关键。 一、分析器的核心作用 1. 分词(Tokenization):将文本拆分为独立的词(Token)。 例如…...
使用 SseEmitter 实现 Spring Boot 后端的流式传输和前端的数据接收
1.普通文本消息的发送和接收 GetMapping("/stream")public SseEmitter streamResponse() {SseEmitter emitter new SseEmitter(0L); // 0L 表示永不超时Executors.newSingleThreadExecutor().execute(() -> {try {for (int i 1; i < 5; i) {emitter.send(&q…...
.net Avalonia 在centos部署
.NET Avalonia 在 CentOS 部署指南 在跨平台应用开发中,.NET Avalonia 凭借其强大的功能和灵活性受到了广泛关注。而将基于 .NET Avalonia 开发的应用程序部署到 CentOS 系统上,是很多开发者会面临的任务。下面就为大家详细介绍在 CentOS 上部署 .NET A…...
MyBatis深度解析:XML/注解配置与动态SQL编写实战
引言 在现代Java企业级应用开发中,MyBatis作为一款优秀的持久层框架,因其灵活性和易用性广受开发者喜爱。相比Hibernate等全自动ORM框架,MyBatis提供了更接近SQL的开发体验,同时又不失面向对象的优雅。本文将深入探讨MyBatis的核…...
面试经验 对常用 LLM 工具链(如 LlamaFactory)的熟悉程度和实践经验
面试场景: 你正在面试一个大型语言模型(LLM)工程师或研究员的职位,面试官想了解你对常用 LLM 工具链(如 LlamaFactory)的熟悉程度和实践经验。 面试经验分享:LlamaFactory-CLI 工具实践 面试官…...

【conda配置深度学习环境】
好的!我们从头开始配置一个基于Conda的虚拟环境,覆盖深度学习(如PyTorch)和传统机器学习(如XGBoost),并适配你的显卡(假设为NVIDIA,若为AMD请告知)。以下是完…...

力扣4.寻找两个正序数组的中位数
文章目录 题目介绍题解 题目介绍 题解 题解链接:题解 核心思路:通过二分查找的确定分割点使左右两部分元素数量相等。 class Solution {public double findMedianSortedArrays(int[] nums1, int[] nums2) {int n1 nums1.length;int n2 nums2.length…...

【相机基础知识与物体检测】更新中
参考: 黑马机器人 | 相机标定&物体检测https://robot.czxy.com/docs/camera/ 01-相机基础 相机基础概述 相机是机器视觉的基础,相机直接产生了相机数据。所有视觉算法都是作用在相机数据上的。相机数据的好坏,或者对相机数据的理解方式…...

【前端】性能优化和分类
本页知识点参考:https://zhuanlan.zhihu.com/p/514222781 1. 加载性能优化 1.1 网站性能优化 content方法: 1)减少HTTP请求:合并文件,CSS精灵,inline Image 2)减少DNS查询:DNS缓存&…...

PPO和GRPO算法
verl 是现在非常火的 rl 框架,而且已经支持了多个 rl 算法(ppo、grpo 等等)。 过去对 rl 的理解很粗浅(只知道有好多个角色,有的更新权重,有的不更新),也曾硬着头皮看了一些论文和知…...
ceph 对象存储用户限额满导致无法上传文件
查看日志 kl logs -f rook-ceph-rgw-my-store-a-5cc4c4d5b5-26n6j|grep -i error|head -1Defaulted container "rgw" out of: rgw, log-collector, chown-container-data-dir (init) debug 2025-05-30T19:44:11.573+0000 7fa7b7a6d700...

rk3588 上运行smolvlm-realtime-webcam,将视频转为文字描述
smolvlm-realtime-webcam 是一个开源项目,结合了轻量级多模态模型 SmolVLM 和本地推理引擎 llama.cpp,能够在本地实时处理摄像头视频流,生成自然语言描述, 开源项目地址 https://github.com/ngxson/smolvlm-realtime-webcamhttps…...
某航参数逆向及设备指纹分析
文章目录 1. 写在前面2. 接口分析3. 加密分析4. 算法还原5. 设备指纹风控分析与绕过【🏠作者主页】:吴秋霖 【💼作者介绍】:擅长爬虫与JS加密逆向分析!Python领域优质创作者、CSDN博客专家、阿里云博客专家、华为云享专家。一路走来长期坚守并致力于Python与爬虫领域研究…...
SQL思路解析:窗口滑动的应用
目录 🎯 问题目标 第一步:从数据中我们能直接得到什么? 第二步:我们想要的“7天窗口”长什么样? 第三步:SQL 怎么表达“某一天的前六天”? 🔍JOIN 比窗口函数更灵活 第四步&am…...

Rust 学习笔记:Box<T>
Rust 学习笔记:Box Rust 学习笔记:Box<T\>Box\<T> 简介使用 Box\<T\> 在堆上存储数据启用带有 box 的递归类型关于 cons 列表的介绍计算非递归类型的大小使用 Box\<T\> 获取大小已知的递归类型 Rust 学习笔记:Box<…...
C# 从 ConcurrentDictionary 中取出并移除第一个元素
C# 从 ConcurrentDictionary 中取出并移除第一个元素 要从 ConcurrentDictionary<byte, int> 中取出并移除第一个元素,需要结合 遍历 和 原子移除操作。由于 ConcurrentDictionary 是无序集合,"第一个元素" 通常是指最早添加的元素&…...

操作系统学习(十三)——Linux
一、Linux Linux 是一种类 Unix 的自由开源操作系统内核,由芬兰人 Linus Torvalds 于 1991 年首次发布。如今它广泛应用于服务器、桌面、嵌入式设备、移动设备(如 Android)等领域。 设计思想: 原则描述模块化与可移植性Linux 内…...

NLP学习路线图(二十二): 循环神经网络(RNN)
在自然语言处理(NLP)的广阔天地中,序列数据是绝对的核心——无论是流淌的文本、连续的语音还是跳跃的时间序列,都蕴含着前后紧密关联的信息。传统神经网络如同面对一幅打散的拼图,无法理解词语间的顺序关系,…...

每日一C(1)C语言的内存分布
目录 代码区 常量区 全局/静态区 初始化数据段(.data) 未初始化数据段(.bss) 堆区 栈区 总结 今天我们学习的是C语言的内存分布,以及这些分区所存储的内容和其特点。今天的思维导图如下。 C语言作为一款直接处…...

Photoshop使用钢笔绘制图形
1、绘制脸部路径 选择钢笔工具,再选择“路径”。 基于两个点绘制一个弯曲的曲线 使用Alt键移动单个点,该点决定了后续的曲线方向 继续绘制第3个点 最后一个点首尾是同一个点,使用钢笔保证是闭合回路。 以同样的方式绘制2个眼睛外框。 使用椭…...

应用层协议:HTTP
目录 HTTP:超文本传输协议 1.1 HTTP报文 1.1.1 请求报文 1.1.2 响应报文 1.2 HTTP请求过程和原理 1.2.1 请求过程 1、域名(DNS)解析 2、建立TCP连接(三次握手) 3、发送HTTP请求 4、服务器处理请求 5、返回H…...

复习——C++
1、scanf和scanf_s区别 2、取地址,输出 char ba; char* p&b; cout<<*p; cout<<p; p(char*)"abc"; cout<<*p; cout<<p; cout<<(void*)p; 取地址,把b的地址给p 输出*p,是输出p的空间内的值…...

SPI通信协议(软件SPI读取W25Q64)
SPI通信协议 文章目录 SPI通信协议1.SPI通信2.SPI硬件和软件规定2.1SPI硬件电路2.2移位示意图2.3SPI基本时序单元2.3.1起始和终止条件2.3.2交换一个字节(模式1) 2.4SPI波形分析(辅助理解)2.4.1发送指令2.4.2指定地址写2.4.3指定地…...
PostgreSQL-基于PgSQL17和11版本导出所有的超表建表语句
最新版本更新 https://code.jiangjiesheng.cn/article/368?fromcsdn 推荐 《高并发 & 微服务 & 性能调优实战案例100讲 源码下载》 1. 基于pgsql 17.4 研究 查询psql版本:SELECT version(); 查看已知1条建表语句和db中数据关系 SELECT create_hypert…...

JavaWeb:前后端分离开发-部门管理
今日内容 前后端分离开发 准备工作 页面布局 整体布局-头部布局 Container 布局容器 左侧布局 资料\04. 基础文件\layout/index.vue <script setup lang"ts"></script><template><div class"common-layout"><el-containe…...
ArcGIS计算多个栅格数据的平均栅格
3种方法计算多个栅格数据的平均栅格 1->使用“ 栅格计算器”工具 原理就是把多幅影像数据相加,然后除以个数,就能得到平均栅格。 2-> 使用“像元统计数据”工具,如果是ArcGIS pro,则是“像元统计”工具。使用这个工具可以…...

字节开源FlowGram:AI时代可视化工作流新利器
字节终于开源“扣子”同款引擎了!FlowGram:AI 时代的可视化工作流利器 字节FlowGram创新性地融合图神经网络与多模态交互技术,构建了支持动态拓扑重构的可视化流程引擎。该系统通过引入 f ( G ) ( V ′ , E ′ ) f(\mathcal{G})…...
如何选择合适的分库分表策略
选择合适的分库分表策略需要综合考虑业务特点、数据规模、访问模式、技术成本等多方面因素。以下是系统性的选择思路和关键决策点: 一、核心决策因素 业务需求分析 数据规模:当前数据量(如亿级)、增长速度(如每日新增百…...