1.Docker概述

1.1.Docker简介

Docker 是一个开源的应用容器引擎,基于 Go 语言开发。Docker 可以让开发者打包他们的应用以及依赖包到一个轻
量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互
之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。

· Docker应用场景

  • Web 应用的自动化打包和发布
  • 自动化测试和持续集成、发布
  • 在服务型环境中部署和调整数据库或其他的后台应用

使用Docker可以实现开发人员的开发环境、测试人员的测试环境、运维人员的生产环境的一致性。

1.2. Docker容器与传统虚拟机比较

  • 传统虚拟机

传统虚拟机技术基于安装在主操作系统上的虚拟机管理系统(如:VirtualBox和VMWare等),创建虚拟机(虚拟出
各种硬件),在虚拟机上安装从操作系统,在从操作系统中安装部署各种应用。

  • Docker

Docker容器是在操作系统层面上实现虚拟化,直接复用本地主机的操作系统,而传统虚拟机则是在硬件层面实现虚
拟化。与传统的虚拟机相比,Docker优势体现为启动速度快、占用体积小。

1.3. Docker组成部分

2. Docker安装与启动

Docker可以运行在MAC、Windows、CentOS、DEBIAN、UBUNTU等操作系统上,提供社区版和企业版,本课程基于CentOS安装Docker。CentOS6对docker支持的不好,使用docker建议使用CentOS7。

以下是在CentOS7中安装Docker的步骤:

  1. # 1、yum 包更新到最新
  2. sudo yum update
  3. # 2、作用:安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依
  4. 赖的
  5. sudo yum install -y yum-utils device-mapper-persistent-data lvm2
  6. # 3、 设置yum源
  7. # 3.1、方案一:使用ustc的(推荐)
  8. sudo yum-config-manager --add-repo http://mirrors.ustc.edu.cn/dockerce/
  9. linux/centos/docker-ce.repo
  10. # 3.2、方案二:使用阿里云(可能失败)
  11. sudo yum-config-manager --add-repo http://mirrors.aliyun.com/dockerce/
  12. linux/centos/docker-ce.repo
  13. # 4、 安装docker;出现输入的界面都按 y
  14. sudo yum install -y docker-ce
  15. # 5、 查看docker版本
  16. docker -v

    

2.2. 设置ustc镜像

  ustc是老牌的linux镜像服务提供者了,还在遥远的ubuntu 5.04版本的时候就在用。ustc的docker镜像加速器速度很快。ustc docker mirror的优势之一就是不需要注册,是真正的公共服务。

      1、 编辑文件/etc/docker/daemon.json

  1. # 执行如下命令:
  2. mkdir /etc/docker
  3. vi /etc/docker/daemon.json

      2、在文件中加入下面内容

      

  1. {
  2. "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"]
  3. }

2.3. Docker启动与停止命令      

  1. # 启动docker服务:
  2. systemctl start docker
  3. # 停止docker服务:
  4. systemctl stop docker
  5. # 重启docker服务:
  6. systemctl restart docker
  7. # 查看docker服务状态:
  8. systemctl status docker
  9. # 设置开机启动docker服务:
  10. systemctl enable docker

3. Docker常用命令

3.1. 镜像相关命令

镜像:Docker镜像是由文件系统叠加而成(是一种文件的存储形式);是docker中的核心概念,可以认为镜像就是对某些运行环境或者软件打的包,用户可以从docker仓库中下载基础镜像到本地,比如开发人员可以从docker仓库拉取(下载)一个只包含centos7系统的基础镜像,然后在这个镜像中安装jdk、mysql、Tomcat和自己开发的应用,最后将这些环境打一个新的镜像。开发人员将这个新的镜像提交给测试人员进行测试,测试人员只需要在测试环境下运行这个镜像就可以了,这样就可以保证开发人员的环境和测试人员的环境完全一致。

Docker提供的关于镜像的操作有:     

  • 查看镜像
  • 搜索镜像
  • 拉取镜像
  • 删除镜像

3.1.1. 查看镜像

REPOSITORY:镜像名称
TAG:镜像标签
IMAGE ID:镜像ID
CREATED:镜像的创建日期

SIZE:镜像大小

3.1.2. 搜索镜像

NAME:镜像名称
DESCRIPTION:镜像描述
STARS:用户评价,反应一个镜像的受欢迎程度
OFFICIAL:是否官方
AUTOMATED:自动构建,表示该镜像由Docker Hub自动构建流程创建的

3.1.3. 拉取镜像

3.1.4. 删除镜像

3.2. 容器相关命令

容器,也是docker中的核心概念,容器是由镜像运行产生的运行实例。镜像和容器的关系,就如同Java语言中类和对象的关系。

Docker提供的关于容器的操作有:

    • 查看容器
    • 创建容器
    • 启动容器
    • 停止容器
    • 文件拷贝
    • 目录挂载
    • 查看容器ip地址
    • 删除容器

3.2.1. 查看容器

查看正在运行的容器使用命令:docker ps
查看所有容器使用命令:docker ps -a

3.2.2. 创建并启动容器

可以基于已有的镜像来创建和启动容器,创建与启动容器使用命令:docker run

参数说明:
-i:表示运行容器
-t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。
--name :为创建的容器命名。

-v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件
映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。
-d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t
两个参数,创建后就会自动进去容器)。
-p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

1)交互式容器

以交互式方式创建并启动容器,启动完成后,直接进入当前容器。使用exit命令退出容器。需要注意的是以此种方式
启动容器,如果退出容器,则容器会进入停止状态。

2)守护式容器
创建一个守护式容器;如果对于一个需要长期运行的容器来说,我们可以创建一个守护式容器。命令如下(容器名称 
不能重复):

  1. #创建并启动守护式容器
  2. docker run -di --name=mycentos2 centos:7
  3. #登录进入容器命令为:docker exec -it container_name (或者 container_id) /bin/bash(exit退出
  4. 时,容器不会停止)
  5. docker exec -it mycentos2 /bin/bash

3.2.3. 停止并启动容器

3.2.4. 文件拷贝

  • 将linux宿主机中的文件拷贝到容器内可以使用命令:
  1. # docker cp 需要拷贝的文件或目录 容器名称:容器目录
  2. # 创建一个文件abc.txt
  3. touch abc.txt
  4. # 复制abc.txt到mycentos2的容器的 / 目录下
  5. docker cp abc.txt mycentos2:/
  6. # 进入mycentos2容器
  7. docker exec -it mycentos2 /bin/bash
  8. # 查看容器 / 目录下文件
  9. ll

  • 将文件从容器内拷贝出来到linux宿主机使用命令:
  1. # docker cp 容器名称:容器目录 需要拷贝的文件或目录
  2. #进入容器后创建文件cba.txt
  3. touch cba.txt
  4. # 退出容器
  5. exit
  6. # 在Linux宿主机器执行复制;将容器mycentos2的/cba.txt文件复制到 宿主机器的/root目录下
  7. docker cp mycentos2:/cba.txt /root

3.2.5. 目录挂载

可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器。

创建容器时添加-v参数,后边为宿主机目录:容器目录,例如: docker run -di -v /usr/local/test:/usr/local/test --name=mycentos3 centos:7

  1. # 创建linux宿主机器要挂载的目录
  2. mkdir /usr/local/test
  3. # 创建并启动容器mycentos3,并挂载linux中的/usr/local/test目录到容器的/usr/local/test;也就是在
  4. linux中的/usr/local/test中操作相当于对容器相应目录操作
  5. docker run -di -v /usr/local/test:/usr/local/test --name=mycentos3 centos:7
  6. # 在linux下创建文件
  7. touch /usr/local/test/def.txt
  8. # 进入容器
  9. docker exec -it mycentos3 /bin/bash
  10. # 在容器中查看目录中是否有对应文件def.txt
  11. ll /usr/local/test

3.2.6. 查看容器ip

可以通过以下命令查看容器运行的各种数据 docker inspect 容器名称(容器ID)

3.2.7. 删除容器

删除指定的容器:docker rm 容器名称(容器ID) 删除所有容器:docker rm `docker ps -a -q`

4. Docker应用部署

4.1. MySQL部署

4.1.1. 拉取镜像

4.1.3. 操作容器MySQL

4.1.4. 远程登录MySQL

使用Navicat在windows中进行远程登录在docker容器中的mysql。

4.2. Tomcat部署

4.2.2. 创建容器

4.4.4. 远程连接redis

可以使用redis图形界面客户端工具连接redis,端口也是6379。

5. Docker Compose

5.1. Compose简介

5.1.1. 概念

Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排。它是一个定义和运行多容器的docker应用工具。

使用compose,你能通过YMAL文件配置你自己的服务,然后通过一个命令,你能使用配置文件创建和运行所有的服务。

5.1.2. 组成

Docker-Compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container)。
Docker-Compose运行目录下的所有文件(docker-compose.yml,extends文件或环境变量文件等)组成一个工
程,若无特殊指定工程名即为当前目录名。一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像,参
数,依赖。一个服务当中可包括多个容器实例。

  • 服务(service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。每个服务都有自己的名
    字、使用的镜像、挂载的数据卷、所属的网络、依赖哪些其他服务等等,即以容器为粒度,用户需要Compose
    所完成的任务。

  • 项目(project):由一组关联的应用容器组成的一个完成业务单元,在docker-compose.yml中定义。即是
    Compose的一个配置文件可以解析为一个项目,Compose通过分析指定配置文件,得出配置文件所需完成的所
    有容器管理与部署操作。

Docker-Compose的工程配置文件默认为docker-compose.yml,可通过环境变量COMPOSE_FILE或-f参数自定义配
置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。

使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。在工作中,经常会碰到需要多个容器
相互配合来完成某项任务的情况。例如:要部署一个Web项目,除了Web服务容器,往往还需要再加上后端的数据
库服务容器,甚至还包括负载均衡容器等。

5.2. 安装与卸载

Compose目前已经完全支持Linux、Mac OS和Windows,在我们安装Compose之前,需要先安装Docker。下面我
们以编译好的二进制包方式安装在Linux系统中。

5.2.1. 安装

5.2.2. 卸载

5.3. Compose常用命令参考

使用Compose前,可以通过执行docker-compose --help|-h 来查看Compose基本命令用法。
也可以通过执行docker-compose [COMMAND] --help 或者docker-compose --help [COMMAND] 来查看某个具体的使
用格式。

可以知道Compose命令的基本的使用格式为:

5.3.1. up

格式为:

up命令十分强大,它尝试自动完成包括构建镜像,(重新)创建服务,启动服务,并关联服务相关容器的一些列操
作。链接的服务都将会被自动启动,除非已经处于运行状态。
多数情况下我们可以直接通过该命令来启动一个项目。
选项包括:

5.3.2. ps

格式为:

列出项目中目前的所有容器。
选项包括:

5.3.3. stop

格式为:

停止已经处于运行状态的容器,但不删除它。
选项包括:

5.3.4. down

格式为:

停止和删除容器、网络、卷、镜像,这些内容是通过docker-compose up命令创建的. 默认值删除 容器 网络,可以
通过指定 rmi 、volumes参数删除镜像和卷。
选项包括:

5.4. Compose模版文件

模板文件是使用Compose的核心,涉及的指令关键字也比较多,大部分指令与docker run 相关参数的含义都是类
似的。默认的模板文件名称为docker-compose.yml,格式为YAML格式。
比如一个Compose模板文件:

5.5. Compose应用

需求:编写compose模版文件,实现同时启动tomcat、mysql和redis容器。

5.5.1. 编写模版文件

docker-compose.yml文件内容如下(文件内容请从 资料\配置文件\docker-compose.yml 复制):

上面我们声明了3个服务;分别是:redis1、mysql1、web1;并且对3个服务都指定了对应的docker 镜像和端口。

5.5.2. 启动

5.5.3. 测试

在windows下访问启动的3个服务进行测试都可以;如下面访问9090的tomcat如下:

6. 迁移与备份

其中涉及到的命令有:

  • docker commit 将容器保存为镜像
  • docker save 将镜像备份为tar文件
  • docker load 根据tar文件恢复为镜像

6.1. 将Docker容器保存为镜像

使用docker commit命令可以将容器保存为镜像。
命令形式:docker commit 容器名称 镜像名称

此镜像的内容就是当前容器的内容,接下来你可以用此镜像再次运行新的容器

6.2. 镜像备份

使用docker save命令可以将已有镜像保存为tar 文件。
命令形式:docker save –o tar文件名 镜像名

6.3. 镜像恢复与迁移

使用docker load命令可以根据tar文件恢复为docker镜像。
命令形式:docker load -i tar文件名

7. Dockerfile文件

7.1. 什么是Dockerfile文件

前面的课程中已经知道了,要获得镜像,可以从Docker仓库中进行下载。那如果我们想自己开发一个镜像,那该如
何做呢?答案是:Dockerfile
Dockerfile其实就是一个文本文件,由一系列命令和参数构成,Docker可以读取Dockerfile文件并根据Dockerfile文
件的描述来构建镜像。
Dockerfile文件内容一般分为4部分:

  • 基础镜像信息
  • 维护者信息
  • 镜像操作指令
  • 容器启动时执行的指令

7.2. Dockerfile常用命令

7.3. 使用Dockerfile创建镜像

7.4. 基于镜像创建容器

基于刚刚创建的镜像 jdk1.8 创建并启动容器进行测试;

8. Docker私有仓库

8.1. 私有仓库搭建与配置

Docker官方的Docker hub(https://hub.docker.com)是一个用于管理公共镜像的仓库,我们可以从上面拉取镜像
到本地,也可以把我们自己的镜像推送上去。但是,有时候我们的服务器无法访问互联网,或者你不希望将自己的镜
像放到公网当中,那么我们就需要搭建自己的私有仓库来存储和管理自己的镜像。

私有仓库搭建步骤:

  1. # 1、拉取私有仓库镜像
  2. docker pull registry
  3. # 2、启动私有仓库容器
  4. docker run -di --name=registry -p 5000:5000 registry
  5. # 3、打开浏览器 输入地址http://宿主机ip:5000/v2/_catalog,看到{"repositories":[]} 表示私有仓库
  6. 搭建成功
  7. # 4、修改daemon.json
  8. vi /etc/docker/daemon.json
  9. # 在上述文件中添加一个key,保存退出。此步用于让 docker 信任私有仓库地址;注意将宿主机ip修改为自己宿主
  10. 机真实ip
  11. {"insecure-registries":["宿主机ip:5000"]}
  12. # 5、重启docker 服务
  13. systemctl restart docker
  14. docker start registry

8.2. 将镜像上传至私有仓库

操作步骤:

  1. # 1、标记镜像为私有仓库的镜像
  2. docker tag jdk1.8 宿主机IP:5000/jdk1.8
  3. # 2、再次启动私有仓库容器
  4. docker restart registry
  5. # 3、上传标记的镜像
  6. docker push 宿主机IP:5000/jdk1.8
  7. # 4、输入网址查看仓库效果

8.3. 从私有仓库拉取镜像

8.3.1. 私有仓库所在服务器拉取镜像

若是在私有仓库所在的服务器上去拉取镜像;那么直接执行如下命令:

  1. # 因为私有仓库所在的服务器上已经存在相关镜像;所以先删除;请指定镜像名,不是id
  2. docker rmi 服务器ip:5000/jdk1.8
  3. #拉取镜像
  4. docker pull 服务器ip:5000/jdk1.8
  5. #可以通过如下命令查看 docker 的信息;了解到私有仓库地址
  6. docker info

执行 docker info 命令之后显示内容:

8.3.2. 其它服务器拉取私有仓库镜像

大多数情况下,都是某台服务器部署了私有镜像仓库之后;到其它服务器上从私有仓库中拉取镜像,若要拉取私有仓
库镜像需要去修改docker的配置文件,设置启动时候的仓库地址。

  1. # 打开配置文件
  2. vi /usr/lib/systemd/system/docker.service
  3. # 在打开的上述文件中按照下面的图,添加如下的内容;注意修改下面内容中的ip地址
  4. --add-registry=192.168.12.135:5000 --insecure-registry=192.168.12.135:5000 \
  5. # 修改完后需要重新加载docker配置文件并重启docker
  6. systemctl daemon-reload
  7. systemctl restart docker

在重启之后;那么则可以去拉取私有仓库中的镜像:

  1. # 执行拉取镜像命令并查看
  2. docker pull jdk1.8
  3. docker images

整体docker的私有仓库运作形如下图:

Docker应用容器引擎的更多相关文章

  1. Centos7下安装与卸载docker应用容器引擎

    Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Li ...

  2. Windows 7 下安装 docker 应用容器引擎

    文档地址 ====================================== 安装篇 下载工具 https://get.daocloud.io/toolbox/ 下载完成点击安装 (可参考: ...

  3. 你不得不了解的应用容器引擎---Docker

    最近突然想搭一个redis集群玩玩,因为公司的电脑同时开2个虚拟机就卡的不行,所以我就想到用Docker开启多个redis-server来搭建.然后在网上找着找着发现,使用Docker,哪需要搭建啊, ...

  4. 史上最全面的Docker容器引擎使用教程

    目录 1.Docker安装 1.1 检查 1.2 安装 1.3 镜像加速 1.4 卸载Docker 2.实战Nginx 3.Docker命令小结 4.DockerFile创建镜像 4.1 Docker ...

  5. Docker 1.3.3/1.4.0 发布下载,Linux 容器引擎

    Docker 1.3.3 发布,下载地址: https://github.com/docker/docker/archive/v1.3.3.zip 改进记录包括: Security Fix path ...

  6. 操作系统-容器-引擎容器-百科:Docker

    ylbtech-操作系统-容器-引擎容器-百科:Docker Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上 ...

  7. 【转帖】技术选型之Docker容器引擎

    技术选型之Docker容器引擎 https://segmentfault.com/a/1190000019462392 图过不来的 原作者写的挺好的 题外话 最近对Docker和Kubernetes进 ...

  8. 【应用容器引擎】Docker笔记

    一.Docker是什么? Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的linux机器上,也可以实现虚拟化.它是一个轻量级容器技 ...

  9. 【开发工具 docker】值得学习的应用容器引擎docker安装

    概述: Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何 ...

随机推荐

  1. datepicker插件的使用

    教程链接:http://www.runoob.com/jqueryui/example-datepicker.html 参数:http://hare6.blog.163.com/blog/static ...

  2. shell学习(21)- tr

    Linux tr 命令用于转换或删除文件中的字符. tr 指令从标准输入设备读取数据,经过字符串转译后,将结果输出到标准输出设备. 在tr中利用集合的概念,可以轻松地将字符从一个集合映射到另一个集合中 ...

  3. (四)IO流之InputStream和OutputStream

    InputStream:定义了字节输入流的抽象类 OutputStream:定义了字节输出流的抽象类;该类所有方法返回void值 FileInputStream:继承InputStream FileO ...

  4. 【JZOJ4883】【NOIP2016提高A组集训第12场11.10】灵知的太阳信仰

    题目描述 在炽热的核熔炉中,居住着一位少女,名为灵乌路空. 据说,从来没有人敢踏入过那个熔炉,因为人们畏缩于空所持有的力量--核能. 核焰,可融真金. 咳咳. 每次核融的时候,空都会选取一些原子,排成 ...

  5. 给图片加ALT属性是个什么意思?有什么优点呢

    使用百度统计的seo建议当中一条图片ALT信息"存在没有alt信息的img标签"扣分较多.站点图片中加入ALT对seo有什么优点呢?这是非常多初学seo的朋友们都须要询问的问题.a ...

  6. @NOIP2018 - D2T1@ 旅行

    目录 @题目描述@ @题解@ @代码@ @题目描述@ 小 Y 是一个爱好旅行的 OIer.她来到 X 国,打算将各个城市都玩一遍. 小Y了解到, X国的 n 个城市之间有 m 条双向道路.每条双向道路 ...

  7. LeetCode74 Search a 2D Matrix

    Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...

  8. Object-c学习笔记十八-----NSPredicate

    Cocoa提供了一个类NSPredicate类,该类主要用于指定过滤器的条件,该对象可以准确的描述所需条件,对每个对象通过谓词进行筛选,判断是否与条件相匹配.谓词表示计算真值或假值的函数. NSPre ...

  9. Android ListView显示底部的分割线

    有些时候,我们会提出这样的需求,希望ListView显示底部(顶部)的分割线,这样做,会使得UI效果更加精致,如下图所示: 如果搜索资料,大家会搜到一堆相关的方法,最多的莫过于设置listview的f ...

  10. selenium webdriver学习(四)------------定位页面元素(转)

    selenium webdriver学习(四)------------定位页面元素 博客分类: Selenium-webdriver seleniumwebdriver定位页面元素findElemen ...