美文网首页Linux
Docker安装以及镜像、容器的管理操作备份还原——精

Docker安装以及镜像、容器的管理操作备份还原——精

作者: yichen_china | 来源:发表于2019-05-25 11:52 被阅读64次

    Docker简介

    Docker是在Linux容器里运行应用的开源工具,是一种轻量级的虚拟化方式。Docker的设计宗旨是通过对应用软件的封装、发布、部署、运行等生命周期的管理,达到应用组件级别“一次封装,到处运行”的目的。这里的组件可以是一个应用,也可以是一套服务,甚至可以使一个完整的操作系统。

    Docker的优势

    • Docker的容器技术可以在一台主机上轻松地为任何应用创建个轻量级的、可移植的、自给自足的容器。通过这种容器打包应用程序,简化了重新部署、调试这些琐碎的重复工作,极大地提高了工作效率。采用Docker容器技术,迁移只需要在新的服务器上启动需要的容器就可以。
    • Dockerer容器很快,启动和停止可以在秒级实现,比传统虚拟机要快很多。
    • Docker核利用容器来实现类似VM的功能,从而以更加节省的硬件资源提供,使得在一台主机上同时运行数干个Docker容器成为可能。
    • Docker 操作方便,还可以通过Dockerfle配置镜像文件,支持灵活的自动化创建和部署。

    Docker核心概念

    1、镜像(image)

    Docker的镜像是创建容器的基础,类似虚拟机的快照,可以理解为是一个面向Docker容器引擎的只读模板,比如一个镜像可以是一个完整的centos操作系统,也可以是一个安装了MySQL的应用程序,称之为一个镜像。
    镜像文件用户可以自己创建和更新现有镜像,也可以从网上下载已经做好的应用镜像直接使用。

    2、容器(Container)

    容器是镜像的另一个运行实例,是独立运行的一个或一组应用以及他们所必须的运行环境,包括文件系统、系统库类、shell环境等。镜像是只读模板,而容器会给这个只读模板一个额外的可写层。

    3、仓库(Repository)

    仓库是用来集中存放镜像的地方,当自己创建了镜像后,可以使用push命令将它上传到公共仓库(Public)或者私有仓库(Private),这样,当其他机器想要使用时,直接下载下来即可使用。仓库注册服务器(Registry)是存放仓库的地方,其中包含了多个库,每个仓库集中存放某一类镜像,并且使用不同的标签来区分它们。

    安装Docker

    安装docker有两种方式:其一:使用curl获得docker的安装脚本进行安装;其二:使用docker自己的Yum源来安装。这里以yum源为例安装docker。

    1.仓库配置

    vim /etc/yum.repos.d/docker.repo 
    
    [docker-repo]
    name=Doker Repository
    baseurl=https://yum.dockerproject.org/repo/main/centos/$releasever/
    enabled=1
    gpgcheck=1
    gpgkey=https://yum.dockerproject.org/gpg
    

    2.安装docker

    yum install docker-engine -y
    

    3.启动服务

    systemctl start docker
    systemctl enable docker.service    #开机自启动
    

    4.镜像加速

    vim /etc/docker/daemon.json 
    
     {
        "registry-mirrors": [
            "https://registry.docker-cn.com"  #官方提供的国内镜像加速器地址
        ],
        "insecure-registries": []
    }
    

    5.重启服务

    systemctl daemon-reload
    systemctl restart docker
    

    6.查看docker版本

    docker version 
    
    image.png

    7.查看docker的默认存储目录

    image.png

    Docker镜像操作:

    Docker运行容器前需要本地存在对应的镜像。如果不存在本地镜像,docker就会尝试从默认镜像仓库(官方仓库)https://hub.docker.com下载

    1.搜索镜像

    命令格式:docker search 关键字
    

    例如搜索关键字为lamp的镜像


    image.png

    2.获取镜像

    下载镜像不指定标签,默认下载最新版本的镜像,也可以通过指定的标签下载特定版本的镜像。这里的标签(tag)是用来区分镜像版本的。

    命令格式:docker pull 仓库名称[:标签]
    

    例如下载镜像nickistre/centos-lamp


    image.png

    整个下载过程可以看出,镜像文件由若干层(Layer)组成,我们称之为AUFS(文件联合系统),是实现增量保存与更新的基础,下载过程中会输出镜像的各层信息

    3.查看镜像信息

    命令格式:docker images 仓库名称[:标签]
    

    例如查看本地所有镜像


    image.png

    REPOSITORY ---镜像属于的仓库
    TAG ---镜像的标签信息,标记同一个仓库中不同镜像
    IMAGE ID ---镜像的唯一ID号,唯一标识了该镜像
    CREATED ---镜像创建时间
    SIZE ---镜像大小

    4.获取镜像详细信息

    命令格式:docker inspect 镜像ID号
    

    例如获取镜像的详细信息


    image.png

    5.为本地镜像添加新标签

    命令格式:docker tag 名称[:标签] 新名称[:标签]
    

    例如本地镜像 添加新的名称为lamp,新的标签为lamp


    image.png

    6.删除镜像

    命令格式:docker rmi 仓库名称:标签 或者docker rmi 镜像ID号
    

    例如删除镜像lamp:lamp


    image.png

    注意:当一个镜像有多个标签的时候,docker rmi 命令只是删除该镜像多个标签中的指定标签,不会影响镜像文件。但当该镜像只剩下一个标签的时候,此时删除该标签的时候会彻底删除该镜像。

    image.png

    使用docker rmi 镜像ID号命令时,必须确保该镜像没有被容器使用才能进行,删除时系统会先删除掉指向该镜像的所有标签,然后删除镜像本身。如果该镜像已经被容器使用,正确的做法是先删除依赖该镜像的所有容器,再删除镜像

    7.存出镜像和载入镜像(镜像迁移)

    存出镜像,也就是将镜像保存成本地文件。

    命令格式:docker save -o 存储文件名 存储的镜像
    

    例如将本地的镜像存出为文件lamp


    image.png

    载入镜像,也就是将导出的文件导入到其他机器的镜像库中

    命令格式:docker load < 存出的文件 或者docker --input 存出的文件
    

    例如从文件lamp中载入镜像本地镜像库


    image.png

    8.上传镜像

    本地存储的镜像越来越多,就需要指定一个专门的地方存放这些镜像-仓库。

    命令格式:docker push 仓库名称:标签 
    

    例如在公共仓库上成功注册了一个账号,这个账号叫做xiang10,新增的镜像的标签为xiang10/lamp:centos7

    docker tag nickistre/centos-lamp  xiang10/lamp:centos7
    
    image.png

    成功登陆后上传镜像


    image.png

    Docker容器操作

    1.创建容器

    创建容器就是将镜像加载到到容器,新创建的容器默认处于停止状态,不运行任何程序。

    命令格式:docker create [选项] 镜像 运行的程序
    
    -i 让容器对的输入保持打开
    -t 让Docker分配一个伪终端
    
    image.png

    2.查看容器的运行状态

    docker ps       #查看所有容器的运行状态
    docker ps -a   #查看最近一次启动的容器的运行状态
    
    image.png

    3.创建并启动容器

    可以直接执行docker run命令

    其运行过程:
    1.检查本地是否存在指定的镜像,当镜像不存在时,会从公共仓库下载;
    2.利用镜像创建并启动容器;
    3.执行用户指定的应用程序;
    4.执行完毕后容器被中止运行

    例如创建容器并启动执行一条shell命令

    docker run centos /usr/bin/bash -c ls / 
    
    image.png image.png

    但有时候需要在后台持续运行这个容器,就要让docker以守护态在后台运行,可以在docker run命令后添加“-d”选项实现。那么,容器运行的程序就不能结束。

    docker run -d centos /usr/bin/bash -c "while true;do echo hello;done"
    
    image.png

    4.运行、中止容器

    命令格式:docker start 容器的ID/名称  #启动停止状态的容器
    
    命令格式:docker stop 容器的ID/名称  #中止运行状态的容器
    
    image.png
    image.png

    5.进入容器

    当不进入容器时,容器运行完所执行的程序后会自动停止,为了避免这样的情况,我们需要进入容器执行,且退出容器后,容器并不会停止。

    命令格式:docker exec -it 容器的ID/名称 /bin/bash 
    -i 让容器对的输入保持打开
    -t 让Docker分配一个伪终端
    
    image.png

    6.导出与导入容器

    导出容器,也就是将已经创建好的容器容器导出为文件

    命令格式:docker export 容器的ID/名称 > 文件名
    

    例如导出容器到文件centos7tar


    image.png

    导入容器,也就是将导出文件传输到其他机器

    命令格式:cat 文件名| docker import - 生成的镜像名称:标签
    

    例如导入文件centos7tar成为本地镜像


    image.png

    7.删除容器

    将一个已经处于中止状态的容器删除

    命令格式:docker rm 容器的ID/名称 
    
    image.png

    如果要删除一个正在运行的容器,可以添加-f选项强制删除,但建议先将容器停止再做删除操作。

    相关文章

      网友评论

        本文标题:Docker安装以及镜像、容器的管理操作备份还原——精

        本文链接:https://www.haomeiwen.com/subject/hppazqtx.html