Docker简介
原创者:文思
一、什么是Docker
0、学习起步要求:熟悉Linux命令和相关背景知识;Maven、Git相关知识。
1、Docker是什么?
Docker:基于Go语言实现的云开源项目。Docker开发的Swarm/Compose/Mesos/k8s……等技术框架属于另一个开发运维体系,所以这里只讲Docker基本使用。即Docker基础。
传统项目:开发--war-->运维部署,开发与部署不同的环境和配置给运维部署造成了困扰。传统搬家方式。
Docker:开发--代码|配置|系统|数据(运行环境整体打包)-->运维部署。搬楼方式。
其中,Docker技术中的镜像技术,打破代码即应用的观念,从系统环境开始,自底至上打包应用,达到跨平台快速部署应用,一次封装,到处运行。互联网部署重要的是集群,Docker很好的解决了集群下快速扩容的问题。
一句话总结Docker:Docker是解决了运行环境和配置问题软件容器,方便做持续集成并有助于整体发布的容器虚拟化技术。
2、Docker能干什么?
Docker的理念起源于虚拟机(带环境安装的一种解决方案)。
虚拟机的缺点:资源占用多;启动慢…
基于虚拟机的缺点,Linux发展出另一种虚拟化技术:Linux容器(LXC)。Linux容器不是模拟一个完整的操作系统,而是对进程的隔离。有了容器九可以将软件运行的所有所需资源打包到一个隔离容器中。容器与虚拟机不同,不需要捆绑一整套操作系统,只需要软件工作所需的资源和设置。
容器VS虚拟机
容器是一个应用层抽象,用于将代码和依赖资源打包在一起。多个容器可以在同一台机器上运行,共享操作系统内核,但各自作为独立的进程在用户空间中运行。与虚拟机相比,容器占用的空间较少(容器镜像大小通常只有几十兆),瞬间就能完成启动。
虚拟机 (VM) 是一个物理硬件层抽象,用于将一台服务器变成多台服务器。管理程序允许多个 VM 在一台机器上运行。每个 VM 都包含一整套操作系统、一个或多个应用、必要的二进制文件和库资源,因此占用大量空间。而且 VM 启动也十分缓慢。
传统服务扩容流程繁琐:
项目评审与设备申请-〉入CMDB-〉装机上架-〉初始化-〉服务部署
面对一些热点(春晚峰值、娱乐热点新闻)情况时,突发我预期,只需短期扩容。
业界趋势:
混合云趋势。后期待补充架构讲解。
优点:安全、可扩展、成本
3、去哪里下载
http://docker-cn.com中文网站
http://www.docker.com官网
https://hub.docker.com仓库
二、Docker核心三要素(镜像、容器、仓库)
Docker安装前提是CentOS发行版中的内核支持Docker:
CentOS6.5及以上版本:64位,系统内核版本为2.6.32-431或更高。
CentOS7:系统内核版本为3.10以上。
Docker架构图:
1、镜像
Docker镜像(Image)就是一个只读的模板。镜像可以用来创建Docker容器,一个镜像可以创建很多个容器。
镜像可以比喻作java的类,容器可以比喻作类的实例。
2、容器
Docker利用容器(Container)独立运行一个或一组应用。容器是镜像创建的运 行实例。
容器可以被启动、开始、停止、删除。每一个容器都是相互隔离的,保证独立安全的平台。
3、仓库
Repository集中存放镜像文件的场所。
仓库Reposityory和仓库注册服务器Registry是有区别的。仓库注册服务器上往往存放着多个仓库,每个仓库中又包含多个镜像,每个镜像有不同的标签tag区分。
仓库分为公开库和私有库两种形式。
最大的公开仓库是Docker Hub(https://hub.docker.com),存放了庞大的镜像可供下载。国外访问太慢,而国内的公开仓库包括阿里云、网易云等。
总结:
通过上图也可以更好的理解Docker,Docker也可以理解为Docker本身就是一个容器运行载体或管理引擎,我们把应用程序和配置依赖打包好形成一个可交付的运行环境,这个打包好的运行环境就似乎image镜像文件。只有通过这个镜像文件才能生成Docker容器。Iamge文件可以看作是容器的模板。Docker根据image文件生成容器实例。同一个image文件按可以生成多个同时运行的容器实例。一个容器运行一种服务,可以通过Docker客户端创建对应的容器运行实例。仓库就是存放了一对镜像的地方,需要时拉取得到即可。
三、Docker的安装
注意英文官方与中文官方的文档对应的软件版本!
CentOS6.8下的安装
1、yum install –y epel-release
Docker使用EPEL发布,RHEL系列的OS首先要确保已经持有EPEL仓库,否则请先检查OS的版本,然后先安装对应的EPEL包。
2、yum install –y docker-io
安装Docker
3、安装后的配置文件:/etc/sysconfig/docker
4、启动Docker后台服务:service docker start
5、docker version验证
CentOS7下的安装
Docker CE社区免费版需要安装在CentOS7版本上。
具体看官方文档,比如中文网站https://docs.docker-cn.com/engine/installation/
1、保证CentOS7能上外网
2、yum -y install gcc
3、yum -y install gcc- c++
4、如已经安装老版本请卸载老版本,中文网站翻译的最新版本较慢,建议看英文版官方文档。
5、安装仓库
$ sudo yum install -y yum-utils device-mapper-persistent-data lvm2
6、设置stable镜像仓库(有坑注意)
$ sudo yum-config-manager \
--add-repo\
https://download.docker.com/linux/centos/docker-ce.repo
但由于伟大的防火墙,这里下载很慢,很难安装。就使用中国的阿里云维护的仓库
$ sudo yum-config-manager \
--add-repo\
https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
7、更新yum软件包索引
$ sudo yum makecache fast
8、安装DOCKER CE
$ sudo yum install docker-ce
9、启动Docker(CentOS6.8与Cent7下命令不同),并测试
$ sudo systemctl start docker$ sudo yum install docker-ce
10、配置镜像加速
10.1: mk –p /etc/docker
10.2: vim /etc/docker/daemon.json,注意6.8下的配置文件是/etc/sysconfig/docker
配置内容为(阿里云为例):{”registry-mirrors”:[“http://hub-mirror.c.c163.com”]}