热门标签 | 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



推荐阅读
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • window下的python安装插件,Go语言社区,Golang程序员人脉社 ... [详细]
  • 您的数据库配置是否安全?DBSAT工具助您一臂之力!
    本文探讨了Oracle提供的免费工具DBSAT,该工具能够有效协助用户检测和优化数据库配置的安全性。通过全面的分析和报告,DBSAT帮助用户识别潜在的安全漏洞,并提供针对性的改进建议,确保数据库系统的稳定性和安全性。 ... [详细]
  • 浏览器作为我们日常不可或缺的软件工具,其背后的运作机制却鲜为人知。本文将深入探讨浏览器内核及其版本的演变历程,帮助读者更好地理解这一关键技术组件,揭示其内部运作的奥秘。 ... [详细]
  • Parallels Desktop for Mac 是一款功能强大的虚拟化软件,能够在不重启的情况下实现在同一台电脑上无缝切换和使用 Windows 和 macOS 系统中的各种应用程序。该软件不仅提供了高效稳定的性能,还支持多种高级功能,如拖放文件、共享剪贴板等,极大地提升了用户的生产力和使用体验。 ... [详细]
  • Linux CentOS 7 安装PostgreSQL 9.5.17 (源码编译)
    近日需要将PostgreSQL数据库从Windows中迁移到Linux中,LinuxCentOS7安装PostgreSQL9.5.17安装过程特此记录。安装环境&#x ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
  • Ansible:自动化运维工具详解
    Ansible 是一款新兴的自动化运维工具,基于 Python 开发,集成了多种运维工具(如 Puppet、CFEngine、Chef、Func 和 Fabric)的优点,实现了批量系统配置、程序部署和命令执行等功能。本文将详细介绍 Ansible 的架构、特性和优势。 ... [详细]
  • 如何在虚拟机中实现Linux与Windows主机之间的文件夹共享
    为了在虚拟机中实现Linux与Windows主机之间的文件夹共享,首先需要确保Linux系统已安装VMware Tools。如果尚未安装,可以通过虚拟机软件提供的“安装VMware Tools”选项进行安装。安装完成后,通过配置共享文件夹设置,即可实现主机与虚拟机之间的文件互传。此外,建议检查虚拟机网络设置,确保网络连接正常,以提高文件传输的稳定性和速度。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • 本文通过思维导图的形式,深入解析了大型网站技术架构的核心原理与实际案例。首先,探讨了大型网站架构的演化过程,从单体应用到分布式系统的转变,以及各阶段的关键技术和挑战。接着,详细分析了常见的大型网站架构模式,包括负载均衡、缓存机制、数据库设计等,并结合具体案例进行说明。这些内容不仅有助于理解大型网站的技术实现,还能为实际项目提供宝贵的参考。 ... [详细]
  • Android 构建基础流程详解
    Android 构建基础流程详解 ... [详细]
  • 在本文中,我们将探讨如何在Docker环境中高效地管理和利用数据库。首先,需要安装Docker Desktop以确保本地环境准备就绪。接下来,可以从Docker Hub中选择合适的数据库镜像,并通过简单的命令将其拉取到本地。此外,我们还将介绍如何配置和优化这些数据库容器,以实现最佳性能和安全性。 ... [详细]
  • 在开发过程中,我最初也依赖于功能全面但操作繁琐的集成开发环境(IDE),如Borland Delphi 和 Microsoft Visual Studio。然而,随着对高效开发的追求,我逐渐转向了更加轻量级和灵活的工具组合。通过 CLIfe,我构建了一个高度定制化的开发环境,不仅提高了代码编写效率,还简化了项目管理流程。这一配置结合了多种强大的命令行工具和插件,使我在日常开发中能够更加得心应手。 ... [详细]
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社区 版权所有