Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
官网:
https://www.docker.com/
教程:
https://www.runoob.com/docker/docker-tutorial.html
https://dockertips.readthedocs.io/en/latest/index.html
下图显示了Docker和VM之间的差别:
虚拟机携带操作系统,本身很小的应用程序却因为携带了操作系统而变得非常大,很笨重。Docker是不携带操作系统的,所以Docker的应用就非常的轻巧。
也因为Docker没有OS,因此Windows的Docker镜像是不能在Linux上跑的。arm的镜像也不能在X86上跑。但是不同的Linux发行版由于内核是兼容的,是可以运行的(除非应用依赖了一些发行版相关的东西)。
在线安装:
sudo apt install docker docker.io
离线安装:
https://download.docker.com/linux/static/stable/x86_64/
如果这些新特性在Ubuntu 22.04所使用的内核版本中并不支持,那么即使容器中运行的是Ubuntu 24.04,这些特性也是无法使用的。
https://www.zhihu.com/question/659225649
宿主机是ubuntu22,容器是ubuntu24,容器是否可正常使用ubuntu24特有的一些新功能?
Type I: 直接凌驾于硬件之上,构建出多个隔离的操作系统环境
Type II: 依赖于宿主操作系统,在其上构建出多个隔离的操作系统环境
我们熟知的VMware事实上有两个产品线,一个是VMware ESXi,直接安装在裸金属之上,不需要额外的操作系统,属于第一类虚拟化。另一个是我们普通用户更加熟知的VMware WorkStation,属于第二类虚拟化。
让虚拟机中包含操作系统在内的程序统一运行在低权限的Ring3状态下,一旦虚拟机中的操作系统进行内存管理、I/O通信、中断等操作时,执行特权指令,从而触发异常,物理机将异常派遣给VMM,由VMM进行对应的模拟执行。
然而,x86架构的CPU指令集中有那么一部分指令,它不是特权指令,Ring3状态下也能够执行,但这些指令对于虚拟机来说却是敏感的,不能让它们直接执行。一旦执行,没法触发异常,VMM也就无法介入。
VMware是将原始CPU指令序列翻译成经过处理后的CPU指令序列来执行。这被称作全虚拟化。
而QEMU则是完全模拟执行整个CPU指令集,更像是“解释执行”。
如果把操作系统中所有执行敏感指令的地方都改掉,改成一个接口调用(HyperCall),接口的提供方VMM实现对应处理,省去了捕获和模拟硬件流程等一大段工作,性能将获得大幅度提升。这就是半虚拟化,这项技术的代表就是Xen。
硬件辅助虚拟化:Intel的VT系列技术和AMD的AMD-v系列技术。
VMware是独立的第三方软件,而KVM作为一项虚拟化技术已经集成到Linux内核之中。KVM技术常常搭配QEMU一起使用,称为KVM-QEMU架构。
不同于虚拟化技术要完整虚拟化一台计算机,容器技术更像是操作系统层面的虚拟化,它只需要虚拟出一个操作系统环境。
LXC技术就是这种方案的一个典型代表,全称是LinuX Container,通过Linux内核的Cgroups技术和namespace技术的支撑,隔离操作系统文件、网络等资源,在原生操作系统上隔离出一个单独的空间,将应用程序置于其中运行,这个空间的形态上类似于一个容器将应用程序包含在其中,故取名容器技术。
Docker在LXC的基础上更进一步,将执行执行环境中的各个组件和依赖打包封装成独立的对象,更便于移植和部署。
超轻虚拟化将虚拟化技术的强隔离性和容器技术的轻量性进行融合,提出了一个microVM的概念,底层通过KVM虚拟化技术实现各个microVM的强隔离,而隔离的虚拟机中运行的是一个个精简版的微型操作系统,砍掉了大量无用的功能,专为容器设计的微型OS。
除此虚拟PC之外,还有虚拟网卡(如virtio)和虚拟交换机(如ovs)。
LXD是一个提供了REST API的LXC容器管理器。
官网:
https://linuxcontainers.org/lxd/
有一对很知名的项目:Blue Pill和Red Pill (后来还有个New Red Pill),其中蓝色药片着重于使用虚拟化技术对操作系统,安全软件,反外挂,反调试系统进行欺骗,来进行一些底层操作,而红色药片着重于识别当前是否处于被虚拟化的环境中,一些小众的分支还会尝试对虚拟化环境进行攻击,他一般常见于各种反外挂程序中。
https://www.zhihu.com/question/359121561
操作系统能否知道自己处于虚拟机中?
参考:
https://mp.weixin.qq.com/s/Zmu57U-HlPsyby_qvHSVHQ
VMware/KVM/Docker原来是这么回事儿
https://mp.weixin.qq.com/s/dTygs-QirMgxIrV7SaqjUg
硬件隔离与软件虚拟化
https://mp.weixin.qq.com/s/WZyuTtEfaTFLnCfvhOrp7g
虚拟化原理和分类
https://mp.weixin.qq.com/s/jMC_9tdNuGylDvM_cCqoeA
virtio+ovs转发原理和性能分析
https://mp.weixin.qq.com/s/3a5k3YA6ALri3BrQWQbOpw
浅谈Cgroups
https://mp.weixin.qq.com/s/8Rr-hxKQyHpT7L-Zx7PkcA
浅谈Cgroups V2
https://www.zhihu.com/answer/2488146755
如何通俗解释Docker是什么?
https://zhuanlan.zhihu.com/p/519499603
一文读懂Docker原理
https://zhuanlan.zhihu.com/p/490585683
Docker,containerd,CRI,CRI-O,OCI,runc 分不清?
Podman是一个符合OCI的容器管理工具,它提供了与Docker等类似的功能来管理容器。
https://devopscube.com/podman-tutorial-beginners/
Podman Tutorial For Beginners: Step by Step Guides
1.镜像和容器的关系,类似于类和对象的关系,它们有各自不同的ID。
保存/加载镜像:docker save/load
保存/加载容器:docker export/import
启动镜像:docker run --name <container name> -it <image_name> /bin/bash
启动容器:docker start -i <container id>
进入已启动容器:docker attach <container id>
2.
列出镜像:docker images -a
操作镜像:docker image
列出容器:docker ps -a
3.容器和宿主机的文件交换
从容器往宿主机copy:
docker cp 容器id:/path_in_container /path_on_host
从宿主机往容器copy:
docker cp /path_on_host 容器id:/path_in_container
4.退出
exit
:退出后,会stop容器。
Ctrl+p Ctrl+q:退出后,容器仍然运行。
5.映射文件夹
docker run -it -v <host path>:<docker path> <image_name> /bin/bash
查看映射docker容器的路径:
docker inspect container_name | grep Mounts -A 20
6.查询docker容器的详细信息(例如启动命令)
docker inspect <container_id>
参考:
https://www.cnblogs.com/dyh004/p/9122639.html
docker容器与宿主交互数据
官方文档:
https://docs.docker.com/reference/dockerfile/
构建Docker镜像时处理’Configuring tzdata’交互输入:
DEBIAN_FRONTEND=noninteractive
问题:
Couldn’t create temporary file /tmp/apt.conf.R6cSTc for passing config to apt-key
解决:
chmod 777 /tmp
注意这个是在docker里运行,而不是在host上运行。
docker中的命令没有权限执行的时候,可以用docker run --privileged
。
有时会发现发送到Daemo的内容过大,如下:
Sending build context to Docker daemon 218.2 MB
docker client会默认把Dockerfile同级所有文件发到docker Deamon中。
https://www.cnblogs.com/davis12/p/14453690.html
docker容器权限设置--cap-add
--cap-drop
--privileged
https://blog.csdn.net/Dontla/article/details/132995105
docker run:–security-opt seccomp=unconfined
选项解析 (安全计算模式Secure Computing Mode,实现系统调用过滤,禁用或允许某些系统调用)
http://blog.csdn.net/colorant/article/details/20608157
快速理解Docker
http://www.cnblogs.com/zhangmingcheng/p/5730070.html
Docker数据管理
https://mp.weixin.qq.com/s/E4wKaIddq8_jRVx9q08qtg
Docker入门
https://mp.weixin.qq.com/s/ioRxU9UEr_OJHR5Z5XJ6Vg
Docker入门看这一篇就够了,万字详解!
https://mp.weixin.qq.com/s/_InMrIw4he83dh4ic5qJkw
什么是Docker?看这一篇干货文章就够了!
https://mp.weixin.qq.com/s/S8OXlhRf90nobJtc3TgIpg
基于docker构建hadoop集群
https://mp.weixin.qq.com/s/VfC41XiVmpdWUy3VXgDLuw
Docker基本概念和安装
https://mp.weixin.qq.com/s/LeaYn-CUeu3wognse1fSzw
理解、使用Docker(上)
https://mp.weixin.qq.com/s/YPLnTF_jh8xahZ-uLffSkw
理解、使用Docker(下)
https://mp.weixin.qq.com/s/0jD_Ek2-AOsefjcdr9-A7g
Docker容器介绍
https://mp.weixin.qq.com/s/KBNFQA_4KG0LLadzRtvPPw
如何用两个小时入门Docker?
https://mp.weixin.qq.com/s/2w_63cwNOZ4pzOmarKIk-w
最全的30+个开源免费的Docker工具
https://mp.weixin.qq.com/s/iRCnShcbcL8cUMe0MT1mZQ
用Docker玩转PHP环境配置
https://mp.weixin.qq.com/s/XgCmAi1sgu1iA4cW-Zjcbw
Docker完全指南
https://mp.weixin.qq.com/s/e51KpBltxRd8Qk-VRj6EhQ
让Docker更强大的9个安全开源工具
https://mp.weixin.qq.com/s/DQESB4tB1G43JJQImKsvqg
docker系列学习(一):整体认识
https://mp.weixin.qq.com/s/Ex1AOKGlp2ag6CQTc3rSkA
您想要的docker环境来了!
https://mp.weixin.qq.com/s/HFW3oiGIcYJdaKGjIahXjA
不要把大型JAR包放进Docker镜像
https://mp.weixin.qq.com/s/fY0bfMGL3UXT_3j4LZXaHw
推荐5款好用的开源Docker工具
https://zhuanlan.zhihu.com/p/90408275
下一代容器架构已出,Docker何去何处?看看这里的6问6答!!
https://www.zhihu.com/question/27322045
Docker容器里运行的程序是否与操作系统有关?
https://zhuanlan.zhihu.com/p/115845957
两个奇技淫巧,将Docker镜像体积减小99%
https://mp.weixin.qq.com/s/j2c1cV3J4UK20-yb8FLJZg
Docker中级篇
https://mp.weixin.qq.com/s/0jFHlWAeH5avIO2NLpTmGA
Docker底层原理浅析
https://mp.weixin.qq.com/s/dFUcSJRnH4_QhG_Dyt1RkQ
为什么不建议把数据库部署在Docker容器内
您的打赏,是对我的鼓励