• Docker入门以及常用命令


    目的:

      Docker入门

         Docker简介

         Centos7安装Docker

         Docker HelloWorld运行原理解析

         阿里云镜像仓库配置

      Docker常用命令

         Docker基本命令

         Docker镜像常用命令

         Docker 容器常用命令


     关于联系Docker,首先要有虚拟机和linux系统的基础,可以参考博客:https://www.cnblogs.com/huangting/p/11510852.html

    Docker简介

    Docker 是一个开源的应用容器引擎,基于 Go语言 并遵从Apache2.0协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中。容器是一个打包了应用服务的环境,它是一个轻量级的虚拟机,每一个容器由一组特定的应用和必要的依赖库组成。容器是完全使用沙箱机制,相互之间不会有任何接口,更重要的是容器性能开销极低。Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE(Enterprise Edition: 企业版),我们用社区版就可以了。

    Docker官网:https://www.docker.com/

    Docker的应用场景:

    Web 应用的自动化打包和发布。

    自动化测试和持续集成、发布。

    在服务型环境中部署和调整数据库或其他的后台应用。

    从头编译或者扩展现有的 OpenShift Cloud Foundry 平台来搭建自己的 PaaS 环境。

    Docker 的优点

    • 简化程序:

    Docker 让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,便可以实现虚拟化。Docker改变了虚拟化的方式,使开发者可以直接将自己的成果放入Docker中进行管理。方便快捷已经是 Docker的最大优势,过去需要用数天乃至数周的 任务,在Docker容器的处理下,只需要数秒就能完成。

     

    • 避免选择恐惧症:

    如果你有选择恐惧症,还是资深患者。那么你可以使用 Docker 打包你的纠结!比如 Docker 镜像;Docker 镜像中包含了运行环境和配置,所以 Docker 可以简化部署多种应用实例工作。比如 Web 应用、后台应用、数据库应用、大数据应用比如 Hadoop 集群、消息队列等等都可以打包成一个镜像部署。

     

    • 节省开支:

    一方面,云计算时代到来,使开发者不必为了追求效果而配置高额的硬件,Docker 改变了高性能必然高价格的思维定势。Docker 与云的结合,让云空间得到更充分的利用。不仅解决了硬件管理的问题,也改变了虚拟化的方式。

     

    Docker的架构

    Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。

    Docker 容器通过 Docker 镜像来创建。

    容器与镜像的关系类似于面向对象编程中的对象与类。

    Docker

    面向对象

    容器

    对象

    镜像

    Docker 镜像(Images)

    是用于创Docker 镜像建 Docker 容器的模板。

    Docker 容器(Container)

    容器是独立运行的一个或一组应用。

    Docker 客户端(Client)

    Docker 客户端通过命令行或者其他工具使用 Docker API (https://docs.docker.com/reference/api/docker_remote_api) Docker 的守护进程通信。

    Docker 主机(Host)

    一个者物理或虚拟的机器用于执行 Docker 守护进程和容器。

    Docker 仓库(Registry)

    Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。

    Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用。

     

    Docker Machine

    Docker Machine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBoxDigital OceanMicrosoft Azure

     Docker 和虚拟机的区别

    Docker是一种轻量级的虚拟化技术,比传统的虚拟机性能更好。
    下图是虚拟机的体系结构:

    server - 表示真实电脑。
    
    Host OS - 真实电脑的操作系统,例如:Windows,Linux
    
    Hypervisor - 虚拟机平台,模拟硬件,如VMWare,VirtualBox
    
    Guest OS - 虚拟机平台上安装的操作系统,例如CentOS Linux
    
    App - 虚拟机操作系统上的应用,例如nginx

    下图是Docker的体系结构:

    server - 表示真实电脑。
    
    Host OS - 真实电脑的操作系统,例如:Windows,Linux
    
    Docker Engine - 新一代虚拟化技术,不需要包含单独的操作系统。
    
    App - 所有的应用程序现在都作为Docker容器运行。
    
    这种体系结构的明显优势是,不需要为虚拟机操作系统提供硬件模拟。所有应用程序都作为Docker容器工作,性能更好。

     

    Centos7安装Docker

    Docker1.13版本之后采用时间线的方式作为版本号,分为社区版CE和企业版EE

    社区版是免费提供给个人开发者和小型团体使用的,企业版会提供额外的收费服务,比如经过官方测试认证过的基础设施、容器、插件等。

    社区版按照stableedge两种方式发布,每个季度更新stable版本,如17.0617.09;每个月份更新edge版本,如17.0917.10

    我们平时用社区版就足够了。所以我们安装社区版;

    我们主要参考:https://docs.docker.com/install/linux/docker-ce/centos/  来安装;

    我们切换到root用户

    1Docker 要求 CentOS 系统的内核版本高于 3.10 ,查看本页面的前提条件来验证你的CentOS 版本是否支持 Docker

    通过 uname -r 命令查看你当前的内核版本

     $ uname -r

    2、使用 root 权限登录 Centos。确保 yum 包更新到最新。

    $ yum update

    注意:这里我踩过一个大坑,一定要用root用户去登陆更新yum,否则运行啥都不会成功!!!!

    3、卸载旧版本(如果安装过旧版本的话)

    $ yum remove docker  docker-common docker-selinux docker-engine

    4、安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的

    $ yum install -y yum-utils device-mapper-persistent-data lvm2

    5、设置yum

    $ yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

    6,安装最新版本的Docker

    $ yum install docker-ce docker-ce-cli containerd.io

    7,启动Docker并设置开机启动

    $ systemctl start docker
    
    $ systemctl enable docker

     

    8,验证Docker

    $ docker version

     

     


     

    阿里云镜像仓库配置

     

    1,登录进入阿里云镜像服务中心,获取镜像地址

    进入阿里云容器镜像服务地址:

    https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors

    使用你的淘宝账号密码登录或者注册一个阿里云账户都行,随你自己啦

    2,进入/etc/docker目录下找到在daemon.json文件(没有就新建),将下面内容写入

    cd /etc/docker
    
    vi daemon-reload

    3,重启daemon

    systemctl daemon-reload

    4,重启docker服务

    systemctl restart docker

    9Docker HelloWorld测试

    $ docker run hello-world

    效果:

     


    Docker HelloWorld运行原理解析

    可以看见我们运行了docker run hello-world

    从左到右 client客户端,Docker运行主机,远程仓库;

    docker build ,pullrun分别是 构建,拉取,运行命令,后面再细讲;

    中间Docker主机里有 Docker daemon主运行线程,以及Containers容器,容器里可以运行很多实例,(实例是从右侧Images镜像实例化出来的)Images是存储再本地的镜像文件,比如 RedisTomat这些镜像文件;

    右侧是Registry镜像仓库,默认远程镜像仓库 https://hub.docker.com/  不过是国外主机,下载很慢,不稳定,所以我们后面要配置成阿里云仓库镜像地址,稳定快捷;

     我们执行docker run hello-world时,它所运行的过程结构如下:


    Docker基本命令

    启动Docker

    systemctl start docker

    停止Docker

    systemctl stop docker

    重启Docker

    systemctl restart docker

    开机启动Docker

    systemctl enable docker

    查看Docker概要信息

    docker info

    查看Docker帮助文档

    docker --help

    查看Docker版本信息

    docker version

      在上面操作中基本上都用到了所以就不截图了


    Docker镜像常用命令

    docker images 列出本机所有镜像

     docker images

      REPOSITORY          镜像的仓库源
      TAG                 镜像的标签(版本)同一个仓库有多个TAG的镜像,多个版本;我们用REPOSITORY:TAG来定义不同的镜像;
      IMAGE ID            镜像ID,镜像的唯一标识
      CREATE              镜像创建时间
      SIZE                镜像大小
      
      OPTIONS             可选参数:
          -a                 显示所有镜像(包括中间层)
          -q                 只显示镜像ID
          -qa                可以组合
          --digests          显示镜像的摘要信息
          --no-trunc         显示完整的镜像信息 

    docker search 搜索镜像 

    https://hub.docker.com/ 这里的搜索效果一样;

    OPTIONS可选参数:

     --no-trunc		显示完整的镜像描述
      -s			列出收藏数不小于指定值的镜像
      --automated		只列出Docker Hub自动构建类型的镜像
    

      

    docker pull 下载镜像

    docker pull 镜像名称:[TAG]

    注意:不加TAG,默认下载最新版本latest

    docker rmi 删除镜像

    删除单个:docker rmi 镜像名称:[TAG]

    如果不写TAG,默认删除最新版本latest

    有镜像生成的容器再运行时候,会报错,删除失败

    我们需要加 -f 强制删除

    删除多个:docker rmi -f 镜像名称1:[TAG] 镜像名称2:[TAG]

    中间空格隔开

    删除全部:docker rmi -f $(docker images -qa)

    我演示删除单个:


    Docker 容器常用命令

    Docker创建并启动容器

    docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

    –name=“容器新名字”:为容器指定一个名称;
    -i:以交互模式运行容器,通常与-t或者-d同时使用;
    -t:为容器重新分配一个伪输入终端,通常与-i同时使用;
    -d: 后台运行容器,并返回容器ID;
    -P: 随机端口映射,容器内部端口随机映射到主机的端口
    -p: 指定端口映射,格式为:主机(宿主)端口:容器端口

    启动普通容器: docker run --name 别名 镜像ID

     启动交互式容器:  docker run -it --name 别名 镜像ID   来运行一个容器,取别名,交互模式运行,以及分配一个伪终端,并且进入伪终端;

    注意: 

    1、启动普通容器的方式基本不用,没有伪终端,没有太大价值;

    启动交互式容器的方式,容器一创建完毕,立即进入伪终端

     守护式方式创建并启动容器

     docker run -di --name 别名 镜像ID

    Docker列出容器

    docker ps [OPTIONS]

    OPTIONS说明:

    -a :显示所有的容器,包括未运行的。
    -f :根据条件过滤显示的内容。
    --format :指定返回值的模板文件。
    -l :显示最近创建的容器。
    -n :列出最近创建的n个容器。
    --no-trunc :不截断输出。
    -q :静默模式,只显示容器编号。
    -s :显示总的文件大小。

    docker ps 查看正在运行的容器
    docker ps -a 查看所有容器
    docker ps -n 2  显示最近创建的2个容器
    docker ps -f status=exited 查看停止的容器

    效果:

    Docker退出容器

    exit 容器停止退出
    ctrl+P+Q 容器不停止退出

    Docker进入容器

     a,docker attach 容器ID or 容器名

     不能进入停止的状态的容器
    You cannot attach to a stopped container, start it first

     

    bDocker进入容器执行命令

    docker exec -it 容器名称 或者 容器ID 执行命令

    直接操作容器,执行完 回到 宿主主机终端;

     我们一般用于 启动容器里的应用 比如 tomcat nginx redis elasticsearch等等

    Docker启动容器

    docker start 容器ID or 容器名

    Docker重启容器

    docker restart 容器ID or 容器名

    Docker停止容器

    docker stop 容器ID or 容器名

     

    Docker删除容器

    docker rm 容器ID

    暴力删除,直接杀掉进程 (不推荐)

    docker kill 容器ID or 容器名

    如果删除正在运行的容器,会报错,我们假如需要删除的话,需要强制删除;

    强制删除docker rm -f 容器ID

     

    删除多个容器 

    docker rm -f 容器ID1  容器ID2 中间空格隔开

    删除所有容器

    docker rm -f $(docker ps -qa)

     

    Docker器日志

    $ docker logs [OPTIONS] CONTAINER

      Options:

        --details        显示更多的信息
    
        -f, --follow         跟踪实时日志
    
        --since string   显示自某个timestamp之后的日志,或相对时间,如42m(即42分钟)
    
        --tail string    从日志末尾显示多少行日志, 默认是all
    
        -t, --timestamps     显示时间戳
    
        --until string   显示自某个timestamp之前的日志,或相对时间,如42m(即42分钟)

    谢谢观看!!

  • 相关阅读:
    Java-01,计算1-10的阶乘之和
    软件工程研究生面试机试考题-2018
    nginx会话保持之sticky模块
    Dubbo原理简介、与Zookeeper整合利用
    Day41 openstack基础
    krb5-libs这个RPM包删掉了导致ssh无法连接
    day40 数据结构-算法(二)
    进程上下文频繁切换导致load average过高
    day39 算法基础
    应用性能管理工具PinPoint介绍
  • 原文地址:https://www.cnblogs.com/huangting/p/11960196.html
Copyright © 2020-2023  润新知