1.docker介绍
1.1 简介
- Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。
- Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。
- 容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
1.2 Docker的应用场景
- Web 应用的自动化打包和发布。
- 自动化测试和持续集成、发布。
- 在服务型环境中部署和调整数据库或其他的后台应用。
- 从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。
1.3 Docker 的优点
Docker 是一个用于开发,交付和运行应用程序的开放平台。Docker 使您能够将应用程序与基础架构分开,从而可以快速交付软件。借助 Docker,您可以与管理应用程序相同的方式来管理基础架构。通过利用 Docker 的方法来快速交付,测试和部署代码,您可以大大减少编写代码和在生产环境中运行代码之间的延迟。
1、快速,一致地交付您的应用程序
Docker 允许开发人员使用您提供的应用程序或服务的本地容器在标准化环境中工作,从而简化了开发的生命周期。
容器非常适合持续集成和持续交付(CI / CD)工作流程,请考虑以下示例方案:
- 您的开发人员在本地编写代码,并使用 Docker 容器与同事共享他们的工作。
- 他们使用 Docker 将其应用程序推送到测试环境中,并执行自动或手动测试。
- 当开发人员发现错误时,他们可以在开发环境中对其进行修复,然后将其重新部署到测试环境中,以进行测试和验证。
- 测试完成后,将修补程序推送给生产环境,就像将更新的镜像推送到生产环境一样简单。
2、响应式部署和扩展
Docker 是基于容器的平台,允许高度可移植的工作负载。Docker 容器可以在开发人员的本机上,数据中心的物理或虚拟机上,云服务上或混合环境中运行。
Docker 的可移植性和轻量级的特性,还可以使您轻松地完成动态管理的工作负担,并根据业务需求指示,实时扩展或拆除应用程序和服务。
3、在同一硬件上运行更多工作负载
Docker 轻巧快速。它为基于虚拟机管理程序的虚拟机提供了可行、经济、高效的替代方案,因此您可以利用更多的计算能力来实现业务目标。Docker 非常适合于高密度环境以及中小型部署,而您可以用更少的资源做更多的事情。
2.Docker 架构
Docker 包括三个基本概念:
- 镜像(Image):Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
- 容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和实例一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
- 仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。
Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。
Docker 容器通过 Docker 镜像来创建。
容器与镜像的关系类似于面向对象编程中的对象与类。
Docker | 面向对象 |
---|---|
容器 | 对象 |
镜像 | 类 |
概念 | 说明 |
---|---|
Docker 镜像(Images) | Docker 镜像是用于创建 Docker 容器的模板,比如 Ubuntu 系统。 |
Docker 容器(Container) | 容器是独立运行的一个或一组应用,是镜像运行时的实体。 |
Docker 客户端(Client) | Docker 客户端通过命令行或者其他工具使用 Docker SDK (https://docs.docker.com/develop/sdk/) 与 Docker 的守护进程通信。 |
Docker 主机(Host) | 一个物理或者虚拟的机器用于执行 Docker 守护进程和容器。 |
Docker Registry | Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用。一个 Docker Registry 中可以包含多个仓库(Repository);每个仓库可以包含多个标签(Tag);每个标签对应一个镜像。通常,一个仓库会包含同一个软件不同版本的镜像,而标签就常用于对应该软件的各个版本。我们可以通过 <仓库名>:<标签> 的格式来指定具体是这个软件哪个版本的镜像。如果不给出标签,将以 latest 作为默认标签。 |
Docker Machine | Docker Machine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBox、 Digital Ocean、Microsoft Azure。 |
3.Docker安装
3.1 Alpine
apk add docker
service docker start
docker version # 查看docker版本
3.2 Ubuntu
# 使用官方脚本自动安装
curl -fsSL https://test.docker.com -o test-docker.sh
sudo sh test-docker.sh
3.3 CenterOS
curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
4.Docker常用命令
4.1 镜像操作 / Image Operation
- 查看镜像列表
# 查看最新创建的镜像,以下两个命令等价
docker images
docker image ls
# 查看所有镜像
docker images --all
docker images -a
# 查看与Redis相关的镜像
docker images redis
# 只显示镜像ID,可以与docker rmi命令结合使用
docker images -q
- 搜索当前配置的远程仓库中的可用镜像
docker search redis
- 从镜像仓库拉取镜像
# 拉取最新版,相当于docker pull redis:latest
docker pull redis
# 拉取指定版本
docker pull redis:7.0.5
- 删除镜像(一个或多个)
# 删除指定镜像
docker rmi redis:7.0.5
# 删除所有符合过滤条件的镜像
docker rmi $(docker images -f "dangling=true" -aq)
# 删除所有Redis镜像
docker rmi $(docker images redis -aq)
4.2 容器操作 / Container Operation
- 查看容器列表
docker ps
# 查看所有容器,包含已停止的
docker ps -a
# 查看容器ID, -q 等价于 --quiet
docker ps -q
- 根据某个镜像创建容器但不启动
# 语法:docker create [OPTIONS] IMAGE [COMMAND] [ARG...]
docker create -d --name redis-demo -p 6379:6379 redis:7.0.5
- 根据某个镜像创建容器并启动
# -d 让容器在后台运行,其实就是一个进程
# --name 指定容器名称
# -p 将容器的端口映射到宿主机的端口
# --cpus CPU核心数
# -m 等价于 --memory 指定最大内存
# -e 等价于 --env,设置环境变量
docker run -d \
--name redis-demo -p 6379:6379 \
--cpus 1 -m 100m \
-e REDIS_NAME=my-redis-demo \
redis:7.0.5
- 以交互式的方式进入容器
# docker exec -it containerId /bin/bash
docker exec -it redis-demo /bin/bash
- 启动/停止/暂停/重启容器
# 启动容器,语法:docker start containerId / containerName
docker start redis-demo
# 停止容器,语法:docker stop containerId / containerName
docker stop redis-demo
# 暂停容器,语法:docker pause CONTAINER [CONTAINER...]
docker pause redis-demo
# 运行状态下重启容器,语法:docker restart containerId / containerName
docker restart redis-demo
- 删除容器(一个或多个)
# 语法 docker rm [OPTIONS] CONTAINER [CONTAINER...]
# 删除redis-demo,前提是redis-demo已停止
docker rm redis-demo
# 删除redis-demo及其匿名Volume
docker rm -v redis-demo
# 删除所有已停止的容器
docker rm $(docker ps -f status=exited -q)
- 根据容器的当前变更反向生成镜像
# 语法 docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
# -m 等价于 --comment,备注
docker commit -m 'Image from Container' redis-demo local-redis-image:1.0.0
# 查看新建镜像的提交信息
docker image inspect local-redis-image:1.0.0 | grep Comment
# 或者
docker inspect local-redis-image:1.0.0 | grep Comment
- 查看容器详细信息
# 语法 docker inspect [OPTIONS] NAME|ID [NAME|ID...]
docker inspect redis-demo
- 查看容器资源使用情况
# 语法:docker stats [OPTIONS] [CONTAINER...]
# 以流式的方式展示所有运行中的容器资源使用数据
docker stats
# 所有容器资源使用数据
docker stats -a
# 指定容器(redis-demo)资源使用数据
docker stats redis-demo
# 资源使用快照
docker stats --no-stream redis-demo
- 查看容器日志
# 语法:docker logs [OPTIONS] CONTAINER
docker logs redis-demo
# 实时日志, -f 等价于 --follow,-n 等价于 --tail,显示倒数多少行日志
docker logs -f -n 12 redis-demo
4.3 存储操作 / Storage Operation
- 列举 Volume
docker volume ls
- 创建 Volume
# 语法:docker volume create [OPTIONS] [VOLUME]
# 创建数据卷时,指定名称:v-redis
docker volume create v-redis
# 创建数据卷时,不指定名称,Docker会创建64位的随机名称
docker volume create
- 查看 Volume 详情
# 语法:docker volume inspect [OPTIONS] VOLUME [VOLUME...]
docker volume inspect v-redis
- 删除 Volume
# 语法:docker volume rm [OPTIONS] VOLUME [VOLUME...]
docker volume rm v-redis
- 清理未使用的Volume
docker volume prune
- 创建容器时挂载 Volume
# 将数据卷v-redis挂载到容器内的/usr/local/redis目录
docker run -d --name redis-demo -p 6379:6379 \
-v v-redis:/usr/local/redis \
redis:7.0.5
4.4 网络操作 / Network Operation
- 查看网络列表
# 语法:docker network ls [OPTIONS]
docker network ls
- 创建 Docker 网络
# 语法:docker network create [OPTIONS] NETWORK
# -d 等价于 --driver
docker network create -d bridge nw-redis-b
- 创建容器时指定 Network
docker run -d --name redis-demo-nw -p 6378:6379 \
--network nw-redis-b \
redis:7.0.5
- 运行中的容器连接 Docker 网络
# 语法:docker network connect [OPTIONS] NETWORK CONTAINER
docker network connect nw-redis-b redis-demo
- 运行中的容器断开Docker网络
# 语法:docker network disconnect [OPTIONS] NETWORK CONTAINER
docker network disconnect nw-redis-b redis-demo
- 删除Docker网络
# 语法:docker network rm NETWORK [NETWORK...]
docker network rm nw-redis-b
- 清理未使用的 Docker 网络
# 语法:docker network prune [OPTIONS]
docker network prune
5.使用 Dockerfile 定制镜像
TODO
评论 (0)