Docker的简介
Docker的简介
项目组件运行环境复杂
大型项目组件较多,运行环境也较为复杂,部署时会碰到如下问题:
- 依赖关系复杂,容易出现兼容性问题
- 开发、测试、生产环境有差异

Docker技术解决依赖兼容性问题
- 将应用的Libs(函数库)、Deps(依赖)、配置与应用一起打包
- 将每个应用放到一个隔离容器去运行,避免互相干扰

Docker技术解决不同系统的影响
- Docker将用户程序与所需要调用的系统(比如Ubuntu)函数库一起打包
- Docker运行到不同操作系统时,直接基于打包的库函数,借助于操作系统的内核运行。
Docker技术解决大型项目不同组件的依赖兼容性问题
- Docker允许开发中将应用、依赖、函数库、配置一起打包,形成可移植镜像
- Docker应用运行在容器中,使用沙箱机制,相互隔离
Docker解决开发、测试和生产环境的差异
Docker镜像中包含完整运行环境,包括系统函数库,仅依赖系统的Linux内核,因此可以在任意Linux操作系统上运行
什么是Docker
Docker是一个快速交付应用、运行应用的技术:
- 可以将程序及其依赖、运行环境一起打包为一个镜像,可以迁移到任意Linux操作系统
- 运行时利用沙箱机制形成隔离容器,各个应用互不干扰
- 启动、移除都可以通过一行命令完成,方便快捷。
核心概念(最小集合)
- 镜像(Image):应用 + 依赖 + 环境的“只读模板”(见 镜像与容器)
- 容器(Container):镜像的运行实例,带有自己的进程、网络、文件系统视图
- 仓库(Registry):存放镜像的服务(公共/私有),常见是 DockerHub
典型工作流
- 编写 Dockerfile(描述如何构建镜像)
- 构建镜像:创建镜像 / Dockerfile创建全新镜像
- 运行容器:Docker容器的使用(端口映射见 容器端口的映射)
- 联网与联调:Docker网络 / Docker容器的连接
- 发布与复用:为镜像创建新标签 → 推送/拉取(见 拉取镜像)
相关笔记
- 基础:Docker的架构 / Docker的安装 / Docker的基本操作
- 镜像:Docker镜像的操作 / 查看所有本地镜像 / 删除镜像