【Docker】docker到底是个啥,底层原理

article/2025/9/21 10:14:41

一、总览

Docker说到底其实就是一个启动了多个Linux NameSpace的应用进程,而这个进程能够使用的资源量,则受Cgroups配置的限制。

  1. 其中NameSpace技术,通过对新创建的进程等重命名,缩小了操作系统视图,实现了看似隔离的效果,本质上仍享用着同一个宿主机的内核,比较明显的例子就是无法修改系统时间。
# 查看可以被限制的资源种类
mount -t cgroup
  1. Cgroups技术则是控制了进程组的使用资源的上限,但是通过top读取的当前宿主机的数据,而非当前容器的数据
# 查看用户进程所占cpu片段时间,默认100000--即100ms
cat /sys/fs/cgroup/cpu.cfs_period_us
# 查看用户的进程所占资源,默认-1-----即不限制
cat /sys/fs/cgroup/cpu.cfs_quota_us 
# 查看生效的进程
cat /sys/fs/cgroup/tasks

二、容器镜像

Mount NameSpace:修改容器进程对文件系统“挂载点”的认知,而挂载在容器根目录上、用来为容器进程提供隔离后执行的文件系统,就是所谓的“容器镜像”也叫rootfs

# 将使用$HOME/test目录作为/进程的根目录
chroot $HOME/test /

最大的优点是:通过容器镜像技术,打包的是整个操作系统的文件和目录,引入了层的概念运用了一种叫做联合文件系统(Union File System)的技术使打包的操作系统被拆分成多层,只有不同层需要再下载打包,以ubuntu为例,可以分为以下三层。
在这里插入图片描述

  • 只读层:ro+wh代表readonly+whiteout,文件删除的动作其实是新创建了一个.wh.foo文件,在联合挂载时,foo文件会被wh.foo遮挡,使得看起来消失,所以whiteout可以理解为“白障”
  • init层:专门用来存放启动容器时写入的指定数据如:/etc/hosts、/etc/resolv.conf信息,该配置信息不会随着docker commit提交
  • 可读写层:专门用来存放修改rootfs的增量,使用docker commit和push指令,保存被修改的可读写层,容器的Volume也出现在这一层。

三、Docker命令

# 将当前目录制作成helloword镜像
docker build -t helloword .
# 查看镜像
docker image ls
# 启动镜像,将容器内80端口映射到宿主机的4000端口
docker run -p 4000:80 helloworld python app.py
# 给容器镜像取名
docker tag helloworld greyPigeon/helloworld:v1
# 镜像推送
docker push greyPigeon/helloworld:v1
# 镜像进入
docker exec -it 容器名 /bin/sh
# 镜像提交
docker commit 提交id greyPigeon/helloworld:v2
# Volume挂载,home文件夹挂载到容器的test目录下,相当于mount --bind /home /test
docker run -v /home:/test

http://chatgpt.dhexx.cn/article/l88WED2B.shtml

相关文章

什么是 Docker?它能用来做什么?

文章目录 什么是云计算?什么是 Docker?虚拟化技术演变特点架构镜像(Image)仓库(Registry )容器(Container) 应用场景 什么是云计算? 云计算是一种资源的服务模式&#x…

docker(1):什么是 Docker

1. 什么是docker Docker是一个开源项目,诞生于2013年初,最初是dotCloud公司内部的一个业余项目。它基于Google公司推出的Go语言实现。项目后来加入了Linux基金会,遵从了Apache2.0协议,项目代码在GitHub(https://github.com/docke…

Docker的使用 (1.什么是docker)

前言 这个系列是我自己学习使用docker的记录和分享,作为一名开发人员,你需要了解这个东西并且学会它的简单使用,但是作为一名开发而不是运维,不要花过多的时间去深究它的原理,而是把它当作一个工具即可 docker Docke…

6.docker是什么?什么是容器?镜像是什么?层又是什么?

一、docker 什么是docker,解决了什么问题? Docker解决了运行环境不一致所带来的问题,Docker会将配置文件进行统一管理;解决耗内存问题,Docker会一开始就为每个程序指定内存分配;让快速扩展,弹…

【Docker】

文章目录 一、准备二、Docker的安装第一步:直接开启一个虚拟机,登录进去后,使用ip a命令查看ip地址,查看到当前虚拟机ip地址是192.168.11.10然后用Xshell 7连接该虚拟机,连接地址填刚才的虚拟机ip地址;第二…

Docker镜像里到底有啥东西?

Docker 容器的本质是一个特殊的进程,而 Docker 镜像则是容器运行所需的文件系统。可以说Docker容器是Docker镜像的实例,镜像是容器的模板。容器是在镜像的基础上运行的,当我们修改原镜像时,并不会对正在运行的容器产生影响。 那么…

通俗的解释什么是Docker,一文搞懂

一、初识Docker 1.1.什么是Docker 微服务虽然具备各种各样的优势,但服务的拆分通用给部署带来了很大的麻烦。 分布式系统中,依赖的组件非常多,不同组件之间部署时往往会产生一些冲突。在数百上千台服务中重复部署,环境不一定一…

【Docker】Docker最近这么火,它到底是什么

前言 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux或Windows操作系统的机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。 📕作者简介:热…

【Docker】什么是Docker,它用来干什么

作者简介: 辭七七,目前大一,正在学习C/C,Java,Python等 作者主页: 七七的个人主页 文章收录专栏: 七七的闲谈 欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖&#x1f…

Docker是什么?Docker可以做什么?

背景 随着云原生、容器化、微服务、k8s 等技术的发展,容器 Docker 也火了一把,同时也逐渐被软件开发者在实践中进行运用。个人在目前接手的项目、参与的项目或技术交流中,发现 Docker 已经非常普及。 对于大多数开发者来说,Docker…

Lucas定理理解与应用

【定义】 Lucas定理是用来求 C(n,m) mod p的值。条件:n和m是非负整数,p是素数 一般用于:n和m但p很小,或者n,m不大但大于p,这样用阶乘解决不了。 【公式】 表达式:C(n,m)%pC(n/p,m/p)*C(n%p,m…

ACM_算法_Lucas定理

Lucas定理是用于求解C(n,m)%p的问题 这里小编用一张图&#xff1a; 这张图就很完整的说明了Lucas定理的内容&#xff0c;比较简单&#xff0c;也比较好理解&#xff0c;小编也就不多说了。 #include <cstdio> #include <cstring> #include <iostream> #incl…

Lucas卢卡斯定理模板

题目算法要素&#xff1a;组合数学&线性求逆元&线性求阶乘的逆元&Lucas定理 题面&#xff1a; Lucas定理内容&#xff1a;不会的走传送门去oiwiki 分析&#xff1a; 由于这题n、m较大&#xff0c;因此直接硬算肯定会炸&#xff08;阶乘都算不完&#xff09;。 故…

Vue脚手架global安装出错

1.安装npm sudo apt-get install npm npm -v 查看npm版本 node -v 查看node版本 2.sudo npm install --global vue-cli发现报错出现 TypeError:this is not a typed array 原因是node版本过低导致的&#xff0c;解决办法&#xff1a; 1&#xff09;sudo npm install -g n 2)…

MySQL高级篇1

第01章 Linux下MySQL的安装与使用 1. 安装前说明 1.1 查看是否安装过MySQL 如果你是用rpm安装, 检查一下RPM PACKAGE&#xff1a; rpm -qa | grep -i mysql # -i 忽略大小写检查mysql service&#xff1a; systemctl status mysqld.service1.2 MySQL的卸载 1. 关闭 mysql…

VScode 环境配置

1.把你的 VS Code 打造成 C 开发利器 https://cloud.tencent.com/developer/article/1555413 2.解决C代码在VSCode中无法快速跳转的问题。 在做C项目的时候&#xff0c; 发现在VSCODE里面的&#xff0c; 跳转很慢&#xff0c; 有时候还跳转失败。并且代码提示也不够友好。让…

在Global Mapper中导入点的文本格式

文章目录 有时候想在Global Mapper快速显示一个点的具体位置&#xff0c;来不及去创建一个具体的矢量文件。一个最快速的方式就是将这个点写在文本文件中导入&#xff1a; 13149831.629692005 2817252.5824931804 0 P1 导入后会询问你该文本文件的描述形式&#xff1a; 接着选择…

最强Microsoft Edge插件安装

一、Global Speed: 视频速度控制 Global Speed与几乎所有视频和音频流媒体站点兼容&#xff0c;包括Youtube&#xff0c;Netflix&#xff0c;哔哩哔哩&#xff0c;腾讯视频&#xff0c;百度网盘&#xff0c; 爱奇艺等。 当我们打开某个视频网站时&#xff0c;点击Global Spee…

关于node、vue、vue/cli安装的问题

新人一枚&#xff0c;说错勿喷。 今天在学习搭建安装vue脚手架&#xff08;vue/cli&#xff09;时碰到的问题。 在运行npm install vue/cli -g 报错&#xff0c;翻译过来大概的意思就是依赖包不对&#xff0c;在网上找了许多的资料。最后在别人博客中找到答案。 来源https://ww…

【GoWeb项目-个人Blog】初始化数据库和日志

2 初始化数据库和日志 项目地址&#xff1a;https://gitee.com/illlloooovvvvcode/daily-blog 2.1各种配置的目录结构 2.2 待初始的全局对象 global.go 存储全局对象 var (GVA_CONFIG conf.ConfGVA_DB *gorm.DBGVA_LOG *zap.Logger //只能输出结构化日志&…