Docker是什么
当我们须要支配一个运用做事时,我还是以支配Zabbix监控系统为例,我们传统的支配办法是一台物理做事器上首先安装操作系统比如Linux系统,然后在支配Zabbix监控系统所须要的依赖环境如LAMP(Linux+Apache+Mysql+PHP)和Zabbix一些运用做事(Zabbix Server、Zabbix Database、Zabbix Web等)。传统运用做事支配办法如下图所示。
这样一种支配办法会存在一些问题,最明显的资源会产生摧残浪费蹂躏,现在的物理做事器动不动便是十几核的CPU,上百G的内存,几个T的硬盘。如果只支配一个运用做事的话完备不须要这么高的配置。每每会存在CPU和内存利用率都不到10%的情形。所往后来我们知道有了虚拟化技能,通过VMware这些虚拟化软件利用Hypervisor虚拟化技能把一台物理做事器划分成多台虚拟机,根据运用做事需求合理分配CPU、内存资源。然后安装不同的操作系统支配不同的运用做事,这样的支配办法资源相对来说得到了有效的利用。
虚拟机实在还是没有充分的利用资源的,纵然你在初始只划分1核CPU,2G内存给一台虚拟机,这物理资源实实在在地就被占用了,但是你运行的运用做事有时候也只须要占用一点点资源就行了。以是我们的目标是能不能把物理资源直接分配给运用做事,运用做事用多少就分配给多少。比如我们支配Zabbix监控系统会包含了许多的依赖和做事,所有这些依赖做事的凑集(LAMP环境+ Zabbix Server、Zabbix Database、Zabbix Web等)就可以理解为一个APP,在Docker中被叫做Container——容器。每个容器相称于运行一个运用做事,相互之间是隔离的互不影响。其余我们传统的运用支配办法是不利于迁移和扩展地,比如说我这个运用做事是在Linux平台之中的,现在想要把它迁移到Windows平台当中,这肯定是不能够迁移的,我们还得基于Windows平台再去搭建一套环境。而如果是Docker Container的话就可以顺利运行于不同的操作系统平台,只须要在新的环境下启动所须要的容器就行了。这就大大节省了我们支配所花费的韶光,并且降落支配过程中涌现问题的风险。这便是Docker最基本的浸染了,更多资料可以查看Docker官方网站www.docker.com。
Docker三大核心观点
我们要学习Docker容器技能,必须要理解它的三个最主要的观点Image(镜像)、Container(容器)和Repository(仓库),大部分的操作都是环绕这三个核心观点进行的。
Image:镜像是创建容器的根本,可以理解为是一个只读模板。例如我们Zabbix监控系统须要多台做事器上进行支配,那么你就可以把Zabbix监控系统运用程序及其依赖打包到一个Image文件,创建出一个Zabbix监控系统镜像作为一个模板,想要支配的做事器相称于去拷贝这个镜像文件就可以了。Container:容器是从镜像创建的一个运行实例,它可以被启动、停滞、删除等,所创建的每一个容器都是相互隔离的。容器运行着我们所须要的运用做事,例如Docker支配Zabbix监控系统相称于先从一个标准的Zabbix监控系统镜像拷贝到本地做事器上,然后根据这个Image文件天生容器实例运行,并且你可以对其进行干系配置修正。Repository:仓库是用来集中保存镜像的地方,当你创建完自己的镜像往后,你可以利用push推送命令将它上传到仓库,这样一来当下次要在另一台做事器上利用这个镜像的时候,你只须要利用pull命令从仓库高下载下来就可以了。Repository分为公有和私有,最常用的Repository是官方的Docker Hub ,这也是默认的Repository,并且拥有大量的官方镜像可以利用。网址为:hub.docker.com/ 。Docker安装
Docker分为两个版本:社区版(Community Edition,缩写 CE)和企业版(Enterprise Edition,缩写 EE)。社区版本包括了大部分的核心功能知足大部分的需求。企业版包含了一些收费做事,个人用户一样平常用不到。以是我以CentOS7系统安装Docker CE为例。可参考官网文档进行安装https://docs.docker.com/install/linux/docker-ce/centos/
1.安装docker依赖于系统的一些必要工具。
# yum install -y yum-utils device-mapper-persistent-data lvm2
2.添加docker ce版本yum源,这里是官方的,当然你也可以换为海内的yum源,比如阿里云等。
# yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
3.安装docker ce。
# yum install -y docker-ce
4.安装完成后启动docker。
# systemctl start docker
这样Docker就安装完成了。
Docker基本利用我们之前说Docker的三大核心观点,个中镜像是最主要的,它是运行容器的条件。那么我们可以利用pull命令先从默认镜像仓库Docker Hub网站拉取你须要的镜像,比如tomcat运用做事镜像。
# docker pull tomcat
Using default tag: latest
latest: Pulling from library/tomcat
844c33c7e6ea: Downloading 19.32MB/45.38MB
…
81f4cc5808bc: Pull complete
Digest: sha256:996d406c509a4ebe2f4e96eeda331a354f1663b7ec0ff06685b75c4decef7325
Status: Downloaded newer image for tomcat:latest
docker.io/library/tomcat:latest
下载镜像到本地后利用images命令查看镜像
# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
tomcat latest 6408fdc94212 8 days ago 507MB
如果想要删除镜像。
# docker rmi tomcat
容器是镜像的一个运行实例,当我们获取tomcat镜像到本地后,那么我们就可以根据这个tomcat镜像来创建容器了。利用run命令创建一个名为mytomcat的容器,如果需运行在后台利用-d参数,这样docker容器在后台以守护进程形式运行。
# docker run –d --name mytomcat tomcat
查看当前的mytomcat容器已经运行。
# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
0acdd7e8a944 tomcat "catalina.sh run" 35 seconds ago Up 34 seconds 8080/tcp mytomcat
但是tomcat是在docker容器下运行的,如果外部须要访问就要做一个端口映射,比如把mytomcat容器的 8080 端口映射到本机的 8000 端口上。
# docker run -d --name mytomcat -p 8000:8080 tomcat
如果想要停滞运行mytomcat容器。
# docker stop mytomcat
如果想删除mytomcat容器。
# docker rm mytomcat
容器一样平常会在后台运行,我们无法看到容器的信息,如果须要进入容器利用exec命令进行交互式操作。通过-it参数打开标准输入并且分配一个伪终端。
# docker run -d --name mytomcat -p 8000:8080 tomcat
01382c5529da079070da8933a0056e0d469f89eda79a80a26b9872cb1699d291
# docker exec -it mytomcat /bin/bash
root@01382c5529da:/usr/local/tomcat#
可以看到打开了一个新的bash终端,仿佛我们进入到了其余一个Linux系统了,且当前的路径为/usr/local/tomcat,实在我们就可以理解为每个容器底层它便是一个Linux系统,只是这个别系占用的资源是非常小的。
Docker架构
通过以上Docker的先容相信大家这张Docker架构图就很随意马虎看懂了吧,Docker 采取的是客户端-做事器 (C/S) 架构模式。用户在Docker Client端通过docker干系命令,如docker build创建镜像,docker run从镜像运行容器,docker pull 从镜像仓库下载镜像到本地仓库等发送要求到Docker Daemon后台的系统做事进程,Docker Daemon即Server端收到要求后实行不同的任务,比如须要镜像从镜像仓库下载镜像,天生运行容器等。
总结
本篇文章就大略先容了一下Docker容器技能的一些基本观点及基本操作,希望能够使大家对Docker有了一定的理解,后面大家如果对Docker容器技能有兴趣可以搭建类似的环境安装利用一下Docker,并做更深入地学习!