Docker的介绍和架构
总是听说docker是一个轻量高效率的工具,那么到底docker是个什么东西,它又有着什么样的优点和使用场景呢?
docker介绍
是什么?docker是一个应用容器引擎,基于Go语言。
可以做什么?可以让开发者将应用以及依赖包打包放到一个轻量级、可移植容器里面,然后发布到任意的linux机器上,也可以实现虚拟化。【为了方便理解,你可以想象成一个桶,所有的工具都放在这个桶里了。桶很轻,你可以提着到处走,当然别人也可以提走】
采用什么机制?采用沙箱机制,独立运行,相互之间没有任何接口,更重要的是容器开销极低。
docker应用场景
利用docker,我们可以
- 实现web应用的自动化打包与发布
- 实现自动化测试和持续集成、发布
- 在服务器型环境中部署和调整数据库或者其它的后台应用
- 从头编译或者扩展现有的Openshift或Cloud Foundry平台来搭建自己的PaaS环境
docker的优点
-
简化程序
Docker 让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,便可以实现虚拟化。Docker改变了虚拟化的方式,使开发者可以直接将自己的成果放入Docker中进行管理。方便快捷已经是 Docker的最大优势,过去需要用数天乃至数周的 任务,在Docker容器的处理下,只需要数秒就能完成
-
包容
当很多个应用和包同时可用,你不知道该选择哪个,使用 Docker 打包你的纠结!比如 Docker 镜像;Docker 镜像中包含了运行环境和配置,所以 Docker 可以简化部署多种应用实例工作。比如 Web 应用、后台应用、数据库应用、大数据应用比如 Hadoop 集群、消息队列等等都可以打包成一个镜像部署
-
节省开支
云计算时代到来,使开发者不必为了追求效果而配置高额的硬件,Docker 改变了高性能必然高价格的思维定势。Docker 与云的结合,让云空间得到更充分的利用。不仅解决了硬件管理的问题,也改变了虚拟化的方式。
docker的架构
采用c/s(客户端/服务端)架构模式,使用远程API来管理和创建docker容器【这里为了与已有的知识链接,我们采用了面向对象里的类和对象来类比】
面向对象 | Docker |
---|---|
类 | 镜像 |
对象 | 容器 |
Docker 镜像(Images) | Docker 镜像是用于创建 Docker 容器的模板。 |
---|---|
Docker 容器(Container) | 容器是独立运行的一个或一组应用。 |
Docker 客户端(Client) | Docker 客户端通过命令行或者其他工具使用 Docker API (https://docs.docker.com/reference/api/docker_remote_api) 与 Docker 的守护进程通信。 |
Docker 主机(Host) | 一个物理或者虚拟的机器用于执行 Docker 守护进程和容器。 |
Docker 仓库(Registry) | Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用。 |
Docker Machine | Docker Machine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBox、 Digital Ocean、Microsoft Azure。 |
这里的local host和remote host 都是守护进程。
联系方式
好啦!关于docker的基础介绍大概就到这里啦!对此文档有任何意见或者建议都可以联系我!
联系方式:psywency@foxmail.com