热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

docker多物理机容器_Docker(1)什么是Docker

​1|0学习Docker前的必备知识1|1环境配置的烦恼软件开发最大的麻烦事之一,就是环境配置相信每位编程初学者都会在环境配置上倒腾很久,而作为老师也会

​1|0学习 Docker 前的必备知识

1|1环境配置的烦恼

  • 软件开发最大的麻烦事之一,就是环境配置
  • 相信每位编程初学者都会在环境配置上倒腾很久,而作为老师也会因为不同机器出现五花八门的环境配置问题而烦恼
  • 想要软件正常运行,那么系统的设置和各种库、组件正确的安装才能如期运行
  • 举例来说,安装一个 Python 应用,计算机必须有 Python 引擎,还必须有各种依赖,可能还要配置环境变量
  • 当你需要换机器的时候,你之前所配置的环境又要重头来一遍,非常麻烦

1|2很久以前的应用部署方式

介绍

025d379af972bb05ab4b603859505aa8.png

在一个物理服务器上面安装系统,直接部署应用

缺点

  • 部署非常慢
  • 成本非常高
  • 资源浪费:部署的应用并不会占满服务器资源,会有大部分的空闲资源
  • 难于迁移和扩展:像上面说到的,换台服务器,环境又要重新配
  • 可能会被限定硬件厂商:底层系统架构不同

1|3虚拟化技术出现后的应用部署方式

虚拟化介绍

96694f2240b5f625ab488f1942e42851.png
  • 一个主机部署多个虚拟机,每个虚拟机可以部署多个应用
  • 比如在 Windows 系统里面运行 Linux 系统的 VM
  • 对于底层系统(主机)来说,虚拟机就是一个普通文件,不需要就删掉,对主机没有影响

虚拟化优点

  • 资源池:一个物理机的资源分配到了不同的虚拟机
  • 易扩展:添加物理主机或虚拟机
  • 易云化:阿里云、AWS 提供虚拟化技术

虚拟化局限性

  • 资源占用多:每一个虚拟机都是一个完整的操作系统,要给其分配资源,当虚拟机数量增多时,物理主机本身消耗的资源势必增多
  • 冗余步骤多:虚拟机是完整的操作系统,一些系统级别的操作步骤,往往无法跳过,比如用户登录
  • 启动慢:启动操作系统需要多久,启动虚拟机就需要多久。可能要等几分钟,应用程序才能真正运行

2|0容器的基础知识

2|1容器为什么会出现

  • 上面也讲述了单机部署应用和虚拟机技术的局限性
  • 容器的诞生就是为了解决这些局限性的

2|2什么是容器

  • 对应用软件和其依赖的包进行标准化打包
  • 应用之间相互隔离
  • 共享同一个 OSKernel
  • 可以运行在很多主流操作系统上
  • 可以理解成:标准化软件单元

2|3容器解决了什么问题 

  • 解决了开发和运维之间的矛盾
  • 在开发和运维之间搭建了一个桥梁,是实现 devops 的最佳解决方案

2|4容器和虚拟机的区别

b0f98eb98259219c0860b8016c3bfd3f.png

容器和虚拟机都具有相似的资源隔离和分配特点,但是功能不同,因为容器虚拟化了操作系统,而不是硬件,所以更加便携和高效

9fe5c17b196f33a17ceeab397dfcbd2b.png

2|5虚拟化 + 容器

  • 其实就是 一台物理机上部署多个 VM,每个 VM 上又可以有多个容器
  • 容器和 VM 一起结合使用,在部署和管理应用程序时提供了很大的灵活性
d6454ef9dc553dd0cb6c7655a0376458.png

3|0Docker 的详细介绍

3|1Docker 简介

  • Docker 是一个开源的应用容器引擎,基于 Go 语言
  • 可以打包应用以及依赖包到一 个轻量级、可移植的容器中
  • Docker 打包好了的容器,可以发布到任何流行的 Linux 机器上,也可以实现虚拟化
  • 容器是完全使用沙箱机制,相互之间不会有任何接口(独立)
  • 容器性能开销极低
  • Docker 使用客户端-服务器 (C/S) 架构模式,使用远程 API 来管理和创建 Docker 容器
  • Docker 是实现容器技术的一种工具
  • Docker 容器还可以进行版本管理、复制、分享、修改,就像管理普通的代码一样

工作中的应用场景

  • Web 应用的自动化打包和发布
  • 自动化测试和持续集成、发布(我们的重点)
  • 组建微服务架构,通过多个容器,一台机器可以跑多个服务,因此在本机可以模拟出微服务架构

3|2将软件打包到容器中,以进行开发,运输和部署

  • 容器是打包代码及其所有依赖项的软件的标准单元,所以该软件可以从一个计算机环境快速可靠地在另一个计算机环境进行运行
  • Docker 容器镜像是一个轻量级、独立的、可执行的软件包,它包含运行应用程序所需的一切:运行环境、系统工具、系统库、配置
  • 容器镜像在运行时成为容器
  • 容器化软件都可用于基于 Linux 和 Windows 的应用程序,始终运行相同
  • 容器将软件与其环境隔离开来,即使存在差异,但软件仍然可以运行

3|3在 Docker 镜像上运行的 Docker 容器的优势

  • 标准:Docker 创建了容器的行业标准,因此它们可以在任何地方移植
  • 轻巧:容器共享机器的操作系统内核,因此不需要每个应用程序都用操作系统,从而提高了服务器效率,并降低了服务器资源的消耗
  • 安全:容器中的应用程序更安全,Docker 提供业界最强大的默认隔离功能

3|4Docker 架构

27f9e329bae06fa57eb852a542254516.png

架构图箭头的意思大概是

  • 在 Docker Client 敲 Docker 命令调用 Docker API 来操作 Host 上的 Docker 服务
  • Docker 服务可以从仓库拉镜像到本机,也可以用本机镜像创建一个容器并运行

仓库(Registry)

  • 集中存放镜像文件的场所
  • 每个镜像文件有不同的标签(不同的版本)
  • 最大的开放仓库是Docker Hub: https://hub.docker.com/ 存放了数量庞大的镜像供用户下载
  • 国内的公开仓库包括阿里云,网易云等
  • 仓库分为公开仓库(public)和私有仓库(private)两种形式

镜像(Images)

  • 创建容器的模板
  • 一个镜像可以创建很多容器

容器(Containers)

  • 容器是镜像生成的运行实例
  • Docker 利用容器独立运行一个或一组应用(服务)
  • 每个容器之间是相互隔离的
  • 它可以被启用、开始、停止、删除

主机(HOST)

  • 一个物理机或虚拟机
  • 用于运行 Docker 守护进程和多个容器
  • 可存放多个镜像
  • 也称为宿主机,node节点

Docker 守护程序(daemon)

  • 监听 Docker API 请求
  • 也会管理 Docker 对象,如:镜像、容器、网络、卷
  • 守护程序还可以与其他守护程序通信以管理 Docker 服务

Docker 客户端(client)

  • 客户端使用 Docker 命令或其他工具调用 Docker API
  • 当然也可以在 HOST 直接敲 Docker 命令
  • 客户端可以与多个 Docker 守护程序通信

官方介绍文档:https://docs.docker.com/get-started/overview/

本文转载自:https://www.cnblogs.com/poloyy/p/13898977.html



推荐阅读
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 在现代网络环境中,两台计算机之间的文件传输需求日益增长。传统的FTP和SSH方式虽然有效,但其配置复杂、步骤繁琐,难以满足快速且安全的传输需求。本文将介绍一种基于Go语言开发的新一代文件传输工具——Croc,它不仅简化了操作流程,还提供了强大的加密和跨平台支持。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • 从零开始构建完整手机站:Vue CLI 3 实战指南(第一部分)
    本系列教程将引导您使用 Vue CLI 3 构建一个功能齐全的移动应用。我们将深入探讨项目中涉及的每一个知识点,并确保这些内容与实际工作中的需求紧密结合。 ... [详细]
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
  • 本文详细记录了在银河麒麟操作系统和龙芯架构上使用 Qt 5.15.2 进行项目打包时遇到的问题及解决方案,特别关注于 linuxdeployqt 工具的应用。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • 随着网络安全威胁的不断演变,电子邮件系统成为攻击者频繁利用的目标。本文详细探讨了电子邮件系统中的常见漏洞及其潜在风险,并提供了专业的防护建议。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
author-avatar
李波2602884584
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有