轻量容器如何改变开发世界?Docker 基本概念与架构详解
wptr33 2025-05-28 20:45 19 浏览
开篇导读
还记得你第一次接触 Docker 的感觉吗?是不是觉得它“跑起来比虚拟机快多了”,“一条命令就能部署服务”?但你是否真正搞清楚:
- Docker 和传统虚拟机到底有什么本质区别?
- 容器和镜像有什么不同?
- Docker 的整体架构是怎么协同工作的?
- 我们日常用的命令到底背后发生了什么?
本文将用清晰的结构和图示,带你理解 Docker 最核心的技术概念和架构原理,为后续深入 Kubernetes 打好基础。
一、Docker 是什么?为什么它重要?
Docker 是一种容器化技术,用于构建、打包、分发和运行应用。
核心价值:
- 快速交付:一条命令就能启动服务
- 一致环境:开发、测试、生产完全一致
- 节省资源:多个容器共享同一内核,比虚拟机轻得多
- 易于扩展:容器天然适合微服务架构
Docker 并不是第一个容器技术,但它将容器做成了“开发者友好”的工具(来自 Solomon Hykes,Docker 创始人)
二、镜像 vs 容器:常被混淆的两个核心概念
概念 | 类比 | 作用 |
镜像 | 软件安装包 | 包含应用及其运行环境 |
容器 | 软件实例 | 镜像的运行态 |
简单说:
- 镜像(Image) 是只读的模板
- 容器(Container) 是基于镜像创建的可运行实例
运行流程:
docker run nginx
↓
拉取 nginx 镜像(如不存在)
↓
创建容器 → 启动进程
提示:容器删除后,数据也会一起销毁(除非挂载数据卷)
三、Docker 架构组成:三个核心组件
一张图理解 Docker 架构:
+-------------------+
| Docker Client | ← 命令行、API
+-------------------+
↓
+-------------------+
| Docker Daemon | ← 负责核心逻辑:镜像、容器管理
+-------------------+
↓
+-------------------+
| Container Runtime | ← runC / containerd,负责真正运行容器
+-------------------+
1. Docker Client(客户端)
开发者常用的命令行工具:
docker run
docker build
docker exec
通过 REST API 与 Docker Daemon 通信。
2. Docker Daemon(守护进程)
真正执行容器创建、启动、构建镜像等操作,监听端口 /var/run/docker.sock。
它负责:
- 管理容器生命周期
- 管理镜像和网络
- 调用底层容器运行时(runC)
3. Container Runtime(运行时)
底层的容器引擎,Docker 默认使用 containerd(内部调用 runC),符合 OCI 容器规范。
四、Docker 镜像分层结构:为什么拉镜像这么快?
Docker 镜像采用 联合文件系统(UnionFS) 叠加构建,每一层都是前一层的只读快照。
构建示意:
FROM python:3.9 ← 第1层:基础镜像
COPY . /app ← 第2层:复制代码
RUN pip install -r... ← 第3层:安装依赖
每层都有唯一 Layer ID,Docker 会缓存这些层,实现高效构建与复用。
镜像存储:默认存储在 /var/lib/docker/overlay2 下
五、Docker 仓库:镜像的发布与下载中心
默认仓库:
- Docker Hub(https://hub.docker.com)
私有仓库:
- Harbor(企业级)
- Registry(官方轻量版)
镜像名结构:
[registry]/[namespace]/[repo]:[tag]
例如:
mycompany.com/devops/nginx:v1
通过 docker push 上传,docker pull 拉取
六、运行容器到底做了什么?一条命令全解剖
docker run -d -p 80:80 nginx
执行过程:
- 查找本地镜像 nginx(无则从远端拉取)
- 基于镜像创建只读层 + 可写层
- 设置网络、挂载 volume(可选)
- 启动容器内的默认命令(nginx)
容器默认运行在隔离的命名空间中(namespace):
隔离类型 | 含义 |
PID | 进程隔离 |
NET | 网络设备隔离 |
MNT | 文件系统隔离 |
UTS | 主机名、域名隔离 |
IPC | 进程间通信隔离 |
这些隔离能力由 Linux 内核提供,Docker 只是封装为易用工具。
七、Docker vs 虚拟机:对比更清晰
对比项 | 容器(Docker) | 虚拟机(VM) |
启动速度 | 秒级 | 分钟级 |
资源占用 | 轻量,共享内核 | 重,多内核/系统冗余 |
系统隔离 | 共享主机内核 | 完全独立系统 |
运维难度 | 容器命令统一,简单 | 系统复杂,多种依赖 |
用途 | 微服务、CI/CD、测试环境 | 数据库、单体系统等 |
Docker 更适合弹性扩缩、快速部署的微服务场景。
总结
这一讲,我们完整梳理了 Docker 的基本知识体系:
- 容器 ≠ 镜像,镜像是模板,容器是实例
- Docker 架构分三层:Client、Daemon、Runtime
- 镜像由多层构成,可复用、易分发
- Docker 用 Linux 内核提供的 namespace 和 cgroup 实现轻量隔离
相关推荐
- redis的八种使用场景
-
前言:redis是我们工作开发中,经常要打交道的,下面对redis的使用场景做总结介绍也是对redis举报的功能做梳理。缓存Redis最常见的用途是作为缓存,用于加速应用程序的响应速度。...
- 基于Redis的3种分布式ID生成策略
-
在分布式系统设计中,全局唯一ID是一个基础而关键的组件。随着业务规模扩大和系统架构向微服务演进,传统的单机自增ID已无法满足需求。高并发、高可用的分布式ID生成方案成为构建可靠分布式系统的必要条件。R...
- 基于OpenWrt系统路由器的模式切换与网页设计
-
摘要:目前商用WiFi路由器已应用到多个领域,商家通过给用户提供一个稳定免费WiFi热点达到吸引客户、提升服务的目标。传统路由器自带的Luci界面提供了工厂模式的Web界面,用户可通过该界面配置路...
- 这篇文章教你看明白 nginx-ingress 控制器
-
主机nginx一般nginx做主机反向代理(网关)有以下配置...
- 如何用redis实现注册中心
-
一句话总结使用Redis实现注册中心:服务注册...
- 爱可可老师24小时热门分享(2020.5.10)
-
No1.看自己以前写的代码是种什么体验?No2.DooM-chip!国外网友SylvainLefebvre自制的无CPU、无操作码、无指令计数器...No3.我认为CS学位可以更好,如...
- Apportable:拯救程序员,IOS一秒变安卓
-
摘要:还在为了跨平台使用cocos2d-x吗,拯救objc程序员的奇葩来了,ApportableSDK:FreeAndroidsupportforcocos2d-iPhone。App...
- JAVA实现超买超卖方案汇总,那个最适合你,一篇文章彻底讲透
-
以下是几种Java实现超买超卖问题的核心解决方案及代码示例,针对高并发场景下的库存扣减问题:方案一:Redis原子操作+Lua脚本(推荐)//使用Redis+Lua保证原子性publicbo...
- 3月26日更新 快速施法自动施法可独立设置
-
2016年3月26日DOTA2有一个79.6MB的更新主要是针对自动施法和快速施法的调整本来内容不多不少朋友都有自动施法和快速施法的困扰英文更新日志一些视觉BUG修复就不翻译了主要翻译自动施...
- Redis 是如何提供服务的
-
在刚刚接触Redis的时候,最想要知道的是一个’setnameJhon’命令到达Redis服务器的时候,它是如何返回’OK’的?里面命令处理的流程如何,具体细节怎么样?你一定有问过自己...
- lua _G、_VERSION使用
-
到这里我们已经把lua基础库中的函数介绍完了,除了函数外基础库中还有两个常量,一个是_G,另一个是_VERSION。_G是基础库本身,指向自己,这个变量很有意思,可以无限引用自己,最后得到的还是自己,...
- China's top diplomat to chair third China-Pacific Island countries foreign ministers' meeting
-
BEIJING,May21(Xinhua)--ChineseForeignMinisterWangYi,alsoamemberofthePoliticalBureau...
- 移动工作交流工具Lua推出Insights数据分析产品
-
Lua是一个适用于各种职业人士的移动交流平台,它在今天推出了一项叫做Insights的全新功能。Insights是一个数据平台,客户可以在上面实时看到员工之间的交流情况,并分析这些情况对公司发展的影响...
- Redis 7新武器:用Redis Stack实现向量搜索的极限压测
-
当传统关系型数据库还在为向量相似度搜索的性能挣扎时,Redis7的RedisStack...
- Nginx/OpenResty详解,Nginx Lua编程,重定向与内部子请求
-
重定向与内部子请求Nginx的rewrite指令不仅可以在Nginx内部的server、location之间进行跳转,还可以进行外部链接的重定向。通过ngx_lua模块的Lua函数除了能实现Nginx...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)