docker基础教程一(简介)

                  Docker简介

                                                        原创者:文思

一、什么是Docker

docker基础教程一(简介)_第1张图片

0、学习起步要求:熟悉Linux命令和相关背景知识;Maven、Git相关知识。

1、Docker是什么?

Docker:基于Go语言实现的云开源项目。Docker开发的Swarm/Compose/Mesos/k8s……等技术框架属于另一个开发运维体系,所以这里只讲Docker基本使用。即Docker基础。

传统项目:开发--war-->运维部署,开发与部署不同的环境和配置给运维部署造成了困扰。传统搬家方式。

Docker:开发--代码|配置|系统|数据(运行环境整体打包)-->运维部署。搬楼方式。

其中,Docker技术中的镜像技术,打破代码即应用的观念,从系统环境开始,自底至上打包应用,达到跨平台快速部署应用,一次封装,到处运行。互联网部署重要的是集群,Docker很好的解决了集群下快速扩容的问题。

一句话总结Docker:Docker是解决了运行环境和配置问题软件容器,方便做持续集成并有助于整体发布的容器虚拟化技术。

docker基础教程一(简介)_第2张图片

2、Docker能干什么?

Docker的理念起源于虚拟机(带环境安装的一种解决方案)。

虚拟机的缺点:资源占用多;启动慢…

基于虚拟机的缺点,Linux发展出另一种虚拟化技术:Linux容器(LXC)。Linux容器不是模拟一个完整的操作系统,而是对进程的隔离。有了容器九可以将软件运行的所有所需资源打包到一个隔离容器中。容器与虚拟机不同,不需要捆绑一整套操作系统,只需要软件工作所需的资源和设置。

容器VS虚拟机

docker基础教程一(简介)_第3张图片

容器是一个应用层抽象,用于将代码和依赖资源打包在一起。多个容器可以在同一台机器上运行,共享操作系统内核,但各自作为独立的进程在用户空间中运行。与虚拟机相比,容器占用的空间较少(容器镜像大小通常只有几十兆),瞬间就能完成启动。

虚拟机 (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架构图:

docker基础教程一(简介)_第4张图片

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/

docker基础教程一(简介)_第5张图片

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”]}

你可能感兴趣的:(docker基础教程一(简介))