微服务实战系列之玩转Docker(三)

前言

镜像(Image)作为Docker的“水源”,取之于它,用之于它。这对于立志成为运维管理的撒手锏——Docker而言,重要性不言而喻。

我们在虚拟机时代(当然现在依然ing…),如何快速完成系统的迁移呢? 通常是Copy 一个VM。这个VM是“又笨又大”。难怪会被取代,我们总是希望事半功倍,因为本能使然。


一、为什么选择Docker

任何一个出色的新产品诞生,总是能够在正确的时间,正确的场合,通过正确的方式完成它的历史级“亮相”

这里先给一张图:
在这里插入图片描述
在上篇文章中,博主对docker的特点做了简单总结:“轻”“灵”

1. 何谓轻

简单讲,不干涉他人“主权”,不侵犯他人“资源”。在需要的时候,只需打个招呼,自然有人送上门来。所以不用背负重量级的操作系统(OS),不必携带庞大的数据(Database),这样就轻了,总算做到了“轻装上阵”

2. 何谓灵

既已为轻,其灵自现。“胖子总羡慕瘦子的灵巧,殊不知这个瘦子经历了多少辛酸苦辣”。曾经看过这样一个命题:如何提高货车的装货量?

有些人可能说:塞满、塞满、塞满,无孔不入;
有些人可能说:分门别类,堆积起来,越高越好;
有些人可能说:全部打包;

当然以上发言均没有错,但是做到高效就困难了。这里,答案是把所有的货物装入一个标准箱里,最后码放一起。

行文至此,博主不禁有所感言:

万物万事的兴衰也许都遵循了一定的运行规律和演变逻辑,所以新老交替不可避免。在IT世界,追求价值,是我们永恒的目标。

通过上图,我们可以直观看到VM负重累累,而Docker则身轻如燕。

二、Docker引擎核心

1. 技术基座

1.1命名空间namespace

在Linux中,命名空间是一种容器隔离基础技术,。它能够把资源封装在不同的命名空间中实现资源隔离,进而达到容器隔离的目的。不同的命名空间有一套独有的系统资源。常见的命名空间包含以下六类:

命名空间用途及使用参数
UTS隔离主机名和域名信息,使容器变为一个独立的节点,参数名:CLONE_NEWUTS
IPC隔离进程间通信,参数名:CLONE_NEWIPC
Network隔离网络资源,参数名:CLONE_NEWNET
PID隔离进程的ID,参数名:CLONE_NEWPID
Mount隔离文件系统挂载点,参数名:CLONE_NEWNS
User隔离用户和组,参数名:CLONE_NEWUSER

当然,namespace技术是基于chroot实现的,关于这个点,各位盆友应该有所了解。

1.2控制组cgroups

cgoups是Control groups的简称,也是 Linux 内核的一个功能。用于限制、控制和审计进程组所使用的物理资源。Docker基于此实现资源隔离,互不侵犯。
控制范围包括:CPU、内存、磁盘 I/O 、网络带宽、设备访问、资源跟踪审计、层次化控制。

1.3联合文件系统UnionFS

UnionFS 是一种为 Linux 操作系统设计的用于把多个文件系统“合并”到同一个挂载点的文件系统服务。对外看起来是一个整体,可以说有一定的内聚的意图。直观一点,看图:
在这里插入图片描述

小结: 对外,docker实现了高内聚,屏蔽了差异,只显示一个整体;对内,每个容器都基于一个基础镜像完成新建和运行,存在版本的差异。

了解了docker的技术基座后,我们看看“项庄们”如何舞剑吧。

2. 三剑客(镜像-容器-仓库)

下图是Docker引擎三剑客的核心交互逻辑:
在这里插入图片描述

2.1 镜像Image

前面提到了Docker之所以出色,是因为镜像这个大功臣所赐予。镜像好比是“静止”的容器,所以它包含了容器所需的一些必要资源(根文件系统、程序文件、元数据、网络信息、用户组、命令入口等)。
在这里插入图片描述

2.2 容器Container

我们都说,容器是镜像的“运行态”,也就是一个经过后的一个“镜像”实例。比如你需要创建一个最新的nginx镜像,则先准备一个基础镜像,然后完成相应的改造,形成新的镜像。那么该镜像则为当前镜像的latest版本,也就是一个新Tag

所以Container并不是对镜像的直接构造,其实是经过一个“可写层”,对基础镜像完成改造。这里用到一个思想,所谓“向上open, 向下close”

2.3 仓库Repository

docker仓库一般有公有和私有之分。

公有仓库是Docker官方提供一个公共仓库,称为Docker Hub,是免费开放的。受困与网络条件,使用起来比较费劲,一般需要加速器。

私有仓库是用户自己搭建、管理和维护的Docker仓库。当然一般是企业自身或个人使用,不对外开放或者有偿开放。


结语

本文主要对docker的核心原理进行剖析,从底层理解为什么docker能够胜任当前的发展需要。希望各位有所收获,感谢捧场,欢迎一键三连,互相鼓励与学习!


精彩回顾

  • 微服务实战系列之玩转Docker(二)
  • 微服务实战系列之玩转Docker(一)
  • 微服务实战系列之云原生
  • 微服务实战系列之Filter
  • 微服务实战系列之API加密
  • 微服务实战系列之Dubbo(下)
  • 微服务实战系列之Dubbo(上)
  • 微服务实战系列之ZooKeeper(实践篇)
  • 微服务实战系列之ZooKeeper(下)
  • 微服务实战系列之ZooKeeper(中)
  • 微服务实战系列之ZooKeeper(上)
  • 微服务实战系列之MQ
  • 微服务实战系列之通信
  • 微服务实战系列之J2Cache
  • 微服务实战系列之Cache(技巧篇)
  • 微服务实战系列之MemCache
  • 微服务实战系列之EhCache
  • 微服务实战系列之Redis
  • 微服务实战系列之Cache
  • 微服务实战系列之Nginx(技巧篇)
  • 微服务实战系列之Nginx
  • 微服务实战系列之Feign
  • 微服务实战系列之Sentinel
  • 微服务实战系列之Token
  • 微服务实战系列之Nacos
  • 微服务实战系列之Gateway
  • 微服务实战系列之加密RSA
  • 微服务实战系列之签名Sign

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/47283.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

成为CMake砖家(5): VSCode CMake Tools 插件基本使用

大家好,我是白鱼。 之前提到过,白鱼的主力 编辑器/IDE 是 VSCode, 也提到过使用 CMake Language Support 搭配 dotnet 执行 CMakeLists.txt 语法高亮。 对于阅读 CMakeLists.txt 脚本, 这足够了。 而在 C/C 开发过程中&#xff…

NXP i.MX8系列平台开发讲解 - 3.19 Linux TTY子系统(二)

专栏文章目录传送门:返回专栏目录 Hi, 我是你们的老朋友,主要专注于嵌入式软件开发,有兴趣不要忘记点击关注【码思途远】 目录 1. Linux 串口驱动 1.1 Uart 驱动注册流程 1.2 uart 操作函数 1.3 line discipline 2. Linux tty应用层使用…

FPGA 实现DDR4的读写

1 硬件设计 FPGA 端: DDR4: 2 验证方案 3 仿真验证 4 DDR4 下板验证

《昇思25天学习打卡营第25天|第10天》

今天是打卡的第十天,今天开始学应用实践中的LLM原理和实践,今天学的是基于MindSpore实现BERT对话情绪识别。最先了解的是BERT模型的简介(来自变换器的双向编码器表征量(Bidirectional Encoder Representations from Transformers&…

递归锁与普通锁的区别

什么是锁? 在多线程编程中,锁是一种机制,用来确保某些代码块在同一时间只能被一个线程执行。想象一下,你和你的朋友们都想同时进入一个只有一把椅子的房间。为了避免混乱,你们需要一个锁来控制进入的顺序。 普通锁&a…

PHP 包含

PHP 包含 PHP 是一种广泛使用的开源服务器端脚本语言,它在 web 开发中扮演着重要的角色。PHP 的一个核心特性是其能够包含其他文件,这允许开发者将代码分割成可重用的模块,从而提高代码的可维护性和组织性。本文将深入探讨 PHP 中的文件包含机制,包括其工作原理、使用场景…

Java —— 内部类

Java内部类 1.什么是内部类? 将一个类A定义在另一个类B里面,里面的类A就称为内部类(InnerClass),类B则称为外部类(OuterClass)。 2.为什么需要内部类? 具体来说,当一…

大数据量批处理场景处理

大数据量多线程批处理工具:MultiThreadMamager: 基于线程池实现的动态管理工具 基于ExecutorServiceTaskAbstract抽象实现内部方法:material()获取数据、processing()取数结果处理。 由管理工具去调用线程池执行任务和任务自动迭代处理 - Gitee.com 主要…

springboot 重新注册 bean

项目中,有时候会遇到这样的需求:更新配置后,需要重新处理相关的业务,但是不想重启应用。例如 elasticsearch 证书过期后,需要更换 http_ca.crt ,但是又不想重启应用。 本人对 spring IOC 的源码不算深入&a…

NodeJS技巧:在循环中管理异步函数的执行次数

背景介绍 在现代Web开发中,NodeJS因其高效的异步处理能力而备受青睐。尤其在数据抓取、网络爬虫等应用场景中,NodeJS的非阻塞I/O特性使其成为不二之选。然而,在实际编程过程中,我们经常会遇到一个棘手的问题——如何在循环中控制…

HTC 10 刷系统 LineageOS 19.1 Android 12

解锁手机 解锁或导致数据全部清除,注意保存 Bootloader解锁,S-ON可以不用解锁(好像可以绕过解锁安装twrp,暂时没尝试) HTC 官方 Unlock Bootloader HTC Desire 20 pro 可以不通过官方网站解锁 adb reboot bootload…

Unity入门之重要组件和API(4) : Screen

Screen类主要处理屏幕相关的操作。 1.静态属性 1.1常用属性 【设备分辨率】 Resolution resolution Screen.currentResolution; print("设备分辨率宽:" resolution.width " 高:" resolution.height);【屏幕窗口的宽高】 这里…

Spring源码-读取XML文件配置信息

一、XML基础 DTD、XML阐述、XML的两种文档类型约束和DTD的使用-CSDN博客 二、new File()、getResource()、getResourceAsStream() Java中Class类和 ClassLoader 类 的 getResource()和 getResourceAsStream()方法的使用_getclassloader().getresourceasstream-CSDN博客 三、…

svn ldap认证临时切换到本地认证

当前的svn是在CentOS 7 下 SVN、 Apache 对接 LDAP 服务实现用户账号管理和权限认证&#xff0c;本文模拟ldap数据丢失如何恢复svn&#xff0c;方法是临时将认证切换到本地认证 编辑subversion.conf文件 vi /etc/httpd/conf.d/subversion.conf 注释ldap-status #<Locati…

各地跨境电子商务示范区工具变量DID数据(2010-2022年)

数据来源&#xff1a;参考李震等&#xff08;2023&#xff09;的做法&#xff0c;从官方网站上搜集整理了我国跨境电子商务示范区名单与上市公司进行匹配制作。时间跨度&#xff1a;2010-2022年数据范围&#xff1a;上市企业包含指标&#xff1a; stock year 证券简称 In…

高项-信息系统治理知识要点

1、IT 治理由组织治理层或高级管理层负责&#xff1b; IT 治理强调数字目标与组织战略目标保持一致&#xff1b;IT 治理是一种 制度和机制。 2、IT 治理层次分为三层&#xff1a;最高管理层、执行管理层、业务与服务执行层 ◆ 最高管理层&#xff1a;证 实IT 战略与业务战略是否…

个性化画册制作方法,快来看看

画册&#xff0c;不仅仅是一本书&#xff0c;它是记忆的宝库&#xff0c;是时光的缩影。随着技术的进步&#xff0c;个性化画册的制作已经不再是一件困难的事情。今天&#xff0c;就让我来为大家揭开个性化画册制作的神秘面纱&#xff0c;带你一起创造独一无二的回忆。 第一步&…

数据库内核研发学习之路(三)创建postgres内置函数

本章之前已经讲明白了我们的postgres如何进行编译安装&#xff0c;这是很重要的一步&#xff0c;接下来就是学会对postgres进行小的改动&#xff0c;然后保证依然能够顺利编译安装运行&#xff01; 本章续讲内容如何创建一个内置函数。 1、内置函数和用户自定义函数的区别 熟…

鸿蒙开发:Universal Keystore Kit(密钥管理服务)【查询密钥别名集(ArkTS)】

查询密钥别名集(ArkTS) HUKS提供了接口供应用查询密钥别名集。 开发步骤 初始化密钥属性集。用于查询指定密钥别名集TAG&#xff0c;TAG仅支持HUKS_TAG_AUTH_STORAGE_LEVEL。调用接口[listAliases]&#xff0c;查密钥别名集。 HarmonyOS与OpenHarmony鸿蒙文档籽料&#xff1…

入门小结:JavaScript小白语法

一、变量 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </head> &…