一.Docker的应用场景
Web 应用的自动化打包和发布。
自动化测试和持续集成、发布。
在服务型环境中部署和调整数据库或其他的后台应用。
从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。
二.Docker 的优点
Docker 是一个用于开发,交付和运行应用程序的开放平台。Docker 使您能够将应用程序与基础架构分开,从而可以快速交付软件。借助 Docker,您可以与管理应用程序相同的方式来管理基础架构。通过利用 Docker 的方法来快速交付,测试和部署代码,您可以大大减少编写代码和在生产环境中运行代码之间的延迟。
1、快速,一致地交付您的应用程序
Docker 允许开发人员使用您提供的应用程序或服务的本地容器在标准化环境中工作,从而简化了开发的生命周期。
容器非常适合持续集成和持续交付(CI / CD)工作流程,请考虑以下示例方案:
您的开发人员在本地编写代码,并使用 Docker 容器与同事共享他们的工作。
他们使用 Docker 将其应用程序推送到测试环境中,并执行自动或手动测试。
当开发人员发现错误时,他们可以在开发环境中对其进行修复,然后将其重新部署到测试环境中,以进行测试和验证。
测试完成后,将修补程序推送给生产环境,就像将更新的镜像推送到生产环境一样简单。
2、响应式部署和扩展
Docker 是基于容器的平台,允许高度可移植的工作负载。Docker 容器可以在开发人员的本机上,数据中心的物理或虚拟机上,云服务上或混合环境中运行。
Docker 的可移植性和轻量级的特性,还可以使您轻松地完成动态管理的工作负担,并根据业务需求指示,实时扩展或拆除应用程序和服务。
3、在同一硬件上运行更多工作负载
Docker 轻巧快速。它为基于虚拟机管理程序的虚拟机提供了可行、经济、高效的替代方案,因此您可以利用更多的计算能力来实现业务目标。Docker 非常适合于高密度环境以及中小型部署,而您可以用更少的资源做更多的事情。
三.Docker架构
Docker 包括三个基本概念:
- 镜像(Image):Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
- 容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和实例一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
- 仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。
Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。
Docker 容器通过 Docker 镜像来创建。
容器与镜像的关系类似于面向对象编程中的对象与类。
四,核心概念
概念 | 说明 |
Docker 镜像(Images) | Docker 镜像是用于创建 Docker 容器的模板,比如 Ubuntu 系统。 |
Docker 容器(Container) | 容器是独立运行的一个或一组应用,是镜像运行时的实体。 |
Docker 客户端(Client) | Docker 客户端通过命令行或者其他工具使用 Docker SDK (Develop with Docker Engine SDKs | Docker Documentation) 与 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。 |
五,常用命令
docker 管理命令介绍 | builder Manage builds 管理构建 config Manage Docker configs 管理配置 container Manage containers 管理容器 context Manage contexts 管理上下文 engine Manage the docker engine 管理引擎 image Manage images 管理镜像 network Manage networks 管理网络 node Manage Swarm nodes 管理节点(集群) plugin Manage plugins 管理插件 secret Manage Docker secrets 管理密钥 service Manage services 管理服务 stack Manage Docker stacks 管理 swarm Manage Swarm 管理集群 system Manage Docker管理系统 trust Manage trust on Docker images 管理信任 volume Manage volumes 管理数据挂载(数据持久化 === 永久保存) |
镜像管理命令 | 1、镜像管理命令介绍 docker image 2、镜像获取 2.1 先搜索镜像 docker search <镜像> 2.2 然后下载镜像 docker image pull 3、镜像列表 docker image ls 4、镜像列表基本状态解析 各个选项说明: - **REPOSITORY:**表示镜像的仓库源 - **TAG:**镜像的标签 - **IMAGE ID:**镜像ID - **CREATED:**镜像创建时间 - **SIZE:**镜像大小 5、镜像详细 docker image inspect <镜像id> 6、镜像删除 docker image rm <镜像id> 7、镜像删除构建失败的镜像 docker image prune 7.1 清理未使用的镜像 docker image prune -a 8、镜像设置标签,也叫镜像设置版本 docker image tag image:v1 image 9、镜像历史(了解镜像的操作记录) docker image history [OPTIONS] <IMAGEid> 10、导出镜像导入导出 10.1 镜像导入 docker image import [OPTIONS] file|URL|- [REPOSITORY[:TAG]] 10.2 镜像导入 docker image load [OPTIONS] Options: -i, --input string Read from tar archive file, instead of STDIN -q, --quiet Suppress the load output 10.3 镜像导出,备份 docker image save [OPTIONS] IMAGE [IMAGE...] |
容器命令 | 1、容器命令介绍 docker container 容器的修改和增删 2、运行容器rmcore docker run rmcore 3、查看容器列表 docker ps -a 3、后台运行rmcore docker run -d rmcore -d 后台执行 4、暴露rmcore端口 docker run -d -P rmcore 4.1 自定义端口暴露 docker run -d -p 2020:80 2021:443 rmcore 5、进入容器 docker exec -it rmcore /bin/bash -i :交互式操作 t : 终端 /bin/bash 放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 /bin/bash,就好比xshell一样 6、退出容器 exit 7、停止容器 docker stop rmcore 8、启动容器 docker start rmcore nginx /etc/nginx/conf.d/default.conf |