• docker是什么,能做什么,如何用


    Docker为什么出现?

    一款产品: 开发–上线 两套环境!应用环境,应用配置!

    开发 — 运维。 问题:我在我的电脑上可以允许!版本更新,导致服务不可用!对于运维来说考验十分大?

    环境配置是十分的麻烦,每一个及其都要部署环境(集群Redis、ES、Hadoop)费事费力。

    发布一个项目( jar + (Redis MySQL JDK ES) ),项目能不能带上环境安装打包!

    之前在服务器配置一个应用的环境 Redis MySQL JDK ES Hadoop 配置超麻烦了,不能够跨平台。

    开发环境Windows,最后发布到Linux!

    传统:开发jar,运维来做!

    现在:开发打包部署上线,一套流程做完!

    安卓流程:java — apk —发布(应用商店)一 张三使用apk一安装即可用!

    docker流程: java-jar(环境) — 打包项目帯上环境(镜像) — ( Docker仓库:商店)-----

    Docker给以上的问题,提出了解决方案!
    在这里插入图片描述

    Docker的思想就来自于集装箱!

    JRE – 多个应用(端口冲突) – 原来都是交叉的!
    隔离:Docker核心思想!打包装箱!每个箱子是互相隔离的。

    Docker通过隔离机制,可以将服务器利用到极致!

    本质:所有的技术都是因为出现了一些问题,我们需要去解决,才去学习!

    Docker历史

    2010年,几个的年轻人,就在美国成立了一家公司 dotcloud

    做一些pass的云计算服务!LXC(Linux Container容器)有关的容器技术!

    Linux Container容器是一种内核虚拟化技术,可以提供轻量级的虚拟化,以便隔离进程和资源。

    他们将自己的技术(容器化技术)命名就是 Docker
    Docker刚刚延生的时候,没有引起行业的注意!dotCloud,就活不下去!

    开源

    2013年,Docker开源!

    越来越多的人发现docker的优点!火了。Docker每个月都会更新一个版本!

    2014年4月9日,Docker1.0发布!

    docker为什么这么火?十分的轻巧!

    在容器技术出来之前,我们都是使用虚拟机技术!

    虚拟机:在window中装一个VMware,通过这个软件我们可以虚拟出来一台或者多台电脑!笨重!

    虚拟机也属于虚拟化技术,Docker容器技术,也是一种虚拟化技术!

    VMware : linux centos 原生镜像(一个电脑!) 隔离、需要开启多个虚拟机! 几个G 几分钟
    docker: 隔离,镜像(最核心的环境 4m + jdk + mysql)十分的小巧,运行镜像就可以了!小巧! 几个M 秒级启动!
    
    • 1
    • 2

    聊聊Docker

    Docker基于Go语言开发的!开源项目!

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

    文档:https://docs.docker.com/ Docker的文档是超级详细的!

    仓库地址:https://hub.docker.com/(类似于github,可以push)

    docker能干嘛

    之前的虚拟机技术
    内核,库,app应用

    image-20200515153852954

    虚拟机技术缺点

    1、 资源占用十分多

    2、 冗余步骤多

    3、 启动很慢!

    容器化技术

    容器化技术不是模拟一个完整的操作系统

    image-20200515094336846

    比较Docker和虚拟机技术的不同:

    • 传统虚拟机,虚拟出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
    • 容器内的应用直接运行在宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以就轻便了
    • 每个容器间是互相隔离,每个容器内都有一个属于自己的文件系统,互不影响

    DevOps(开发、运维)

    应用更快速的交付和部署

    传统:一堆帮助文档,安装程序。

    Docker:打包镜像发布测试一键运行。

    更便捷的升级和扩缩容

    使用了 Docker之后,我们部署应用就和搭积木一样
    项目打包为一个镜像(带着环境直接跑起来),扩展 服务器A!服务器B

    打包之后可以在不同的服务器上跑

    更简单的系统运维
    在容器化之后,我们的开发,测试环境都是高度一致的

    更高效的计算资源利用

    Docker是内核级别的虚拟化,可以在一个物理机上可以运行很多的容器实例!服务器的性能可以被压榨到极致。

    Docker安装

    Docker的基本组成

    image-20200514195805400

    镜像(image):

    docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,tomcat镜像==> run ==>tomcat01容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)。

    容器(container):

    Docker利用容器技术,独立运行一个或者一组应用,通过镜像来创建的.
    启动,停止,删除,基本命令
    目前就可以把这个容器理解为就是一个简易的 Linux系统。

    仓库(repository):

    仓库就是存放镜像的地方!
    仓库分为公有仓库和私有仓库。(很类似git)
    Docker Hub是国外的。
    阿里云…都有容器服务器(配置镜像加速!)

    安装Docker

    环境准备

    1.Linux要求内核3.0以上

    2.CentOS 7

    3.使用FinalShell连接远程服务器进行操作

    # 系统内核需要3.0以上
    [root@localhost /]# uname -r
    3.10.0-957.el7.x86_64
    #系统版本
    [root@localhost /]# cat /etc/os-release
    NAME="CentOS Linux"
    VERSION="7 (Core)"
    ID="centos"
    ID_LIKE="rhel fedora"
    VERSION_ID="7"
    PRETTY_NAME="CentOS Linux 7 (Core)"
    ANSI_COLOR="0;31"
    CPE_NAME="cpe:/o:centos:centos:7"
    HOME_URL="https://www.centos.org/"
    BUG_REPORT_URL="https://bugs.centos.org/"
    
    CENTOS_MANTISBT_PROJECT="CentOS-7"
    CENTOS_MANTISBT_PROJECT_VERSION="7"
    REDHAT_SUPPORT_PRODUCT="centos"
    REDHAT_SUPPORT_PRODUCT_VERSION="7"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    安装

    帮助文档:https://docs.docker.com/engine/install/
    卸载与安装
    1.卸载旧版本

    yum remove docker \
                      docker-client \
                      docker-client-latest \
                      docker-common \
                      docker-latest \
                      docker-latest-logrotate \
                      docker-logrotate \
                      docker-engine
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    2.需要的安装包

    yum install -y yum-utils
    
    • 1

    3.设置镜像的仓库

    yum-config-manager \
        --add-repo \
        https://download.docker.com/linux/centos/docker-ce.repo
    #上述方法默认是从国外的,不推荐
    
    #推荐使用国内的 阿里云的
    yum-config-manager \
        --add-repo \
        https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
        
    #更新yum软件包索引
    yum makecache fast
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    4.安装docker相关的内容 docker-ce 社区版 而ee是企业版

    yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin # 这里我们使用社区版即可
    
    ydn选择y
    
    ## 如果想指定版本安装 就输入下面的。并修改内容
    yum install docker-ce-<VERSION_STRING> docker-ce-cli-<VERSION_STRING> containerd.io docker-compose-plugin
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    5.启动docker

    systemctl start docker
    
    • 1

    6.使用docker version查看是否按照成功

    docker version
    
    • 1

    7.测试

    docker run hello-world
    
    #出现 Hello from Docker! 证明安装成功了
    #没有hello-world镜像的话会先去远程push
    
    • 1
    • 2
    • 3
    • 4

    8.查看已经下载的镜像(从这里可以查看已有镜像的id)

    [root@localhost /]# docker images
    REPOSITORY    TAG       IMAGE ID       CREATED        SIZE
    hello-world   latest    feb5d9fea6a5   8 months ago   13.3kB
    
    • 1
    • 2
    • 3

    卸载docker

    ## 1. 卸载依赖
    yum remove docker-ce docker-ce-cli containerd.io docker-compose-plugin
    ## 2. 删除资源
    rm -rf /var/lib/docker
    rm -rf /var/lib/containerd
    # /var/lib/docker 是docker的默认工作路径!
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    镜像加速

    找到阿里云镜像加速器

    配置使用

    ## 1.创建一个目录
    sudo mkdir -p /etc/docker
    
    ## 2.编写配置文件
    sudo tee /etc/docker/daemon.json <<-'EOF'
    {
      "registry-mirrors": ["https://t2wwyxhb.mirror.aliyuncs.com"]
    }
    EOF
    
    ## 3.重启服务
    sudo systemctl daemon-reload
    sudo systemctl restart docker
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    回顾HelloWorld流程

    image-20200515102503722

    docker run 流程图

    image-20200515102637246

    底层原理

    Docker是怎么工作的

    Docker是一个Client-Server结构的系统,Docker的守护进程运行在主机上。通过Socket从客户端访问!

    Docker-Server接收到Docker-Client的指令,就会执行这个命令!

    image-20200515102949558

    为什么Docker比Vm快
    1、docker有着比虚拟机更少的抽象层。由于docker不需要Hypervisor实现硬件资源虚拟化,运行在docker容器上的程序直接使用的都是实际物理机的硬件资源。因此在CPU、内存利用率上docker将会在效率上有明显优势。
    2、docker利用的是宿主机的内核,而不需要Guest OS。

    GuestOS: VM(虚拟机)里的的系统(OS)
    
    HostOS:物理机里的系统(OS)
    
    • 1
    • 2
    • 3

    image-20200515104117329

    因此,当新建一个 容器时,docker不需要和虚拟机一样重新加载一个操作系统内核,避免引导、加载操作系统内核返个比较费时费资源的过程。当新建一个虚拟机时,虚拟机软件需要加载GuestOS,新建过程是分钟级别的。而docker由于直接利用宿主机的操作系统,则省略了这个复杂的过程,因此新建一个docker容器只需要几秒钟

  • 相关阅读:
    【牛客网面试必刷TOP101】链表篇(三)
    榕树贷款元数据接入支持 T+1 和近实时两种方式
    基于ChatGPT打造安全脚本工具流程
    mysql日志总结
    什么是 Linux Mint,它比 Ubuntu 好在哪里?
    论坛回顾|用社区和开发者工具驱动软件供应链安全治理——章华鹏
    【K8S】集群中部署nginx应用 运行手写yaml文件报错排查过程
    基于大规模测量和多任务深度学习的电子鼻系统目标识别、浓度预测和状态判断
    静态HTML网页设计作品 DIV布局家乡介绍网页模板代码---(太原 10页带本地存储登录注册 js表单校验)
    基于bootstarp-table实现列固定
  • 原文地址:https://blog.csdn.net/qq_43585922/article/details/125809067