什么是docker

什么是docker

官方概念

        开源的应用容器引擎

定位

         虚拟化容器,是一个单机应用

理解

         1.类似于JVM跨平台的概念,使用容器引擎解决平台依赖问题

         2.以镜像的形式发布自己的应用,运行在任何一个装有容器引擎的操作系统上

         3.类似于GITHUB,将自己的应用(镜像)发布到镜像仓库(共有/私有)中

原理

         把软件和它依赖的环境(包括操作系统和共享库等)、以来的配置文件打包在一起,以镜像的形式放到官方仓库,只要安装了容器引擎,就可以不作任何修改,运行这个软件。

分层共享+内核虚拟化实现轻量化虚拟机

       分层共享

                把一个应用分为任意多个层,比如操作系统(第一层),依赖的库和第三方软件(第二层),应用的软件包和配置文件(第三层)。如果两个应用有相同的底层,就可以共享这些层。

       内核虚拟化

                与宿主机运行在相同的linux内核,不需要指令集模拟。代表:LXC、OpenVZ、Vserver...

共享层冲突问题与解决

       问题

                如果应用A需要修改操作系统的某个配置,应用B不需要修改,改了就会出错

       解决

                给每个应用新增一个优先级最高的空白层。

                        新增A:在最上面的空白层创建一个文件A

                        删除B:在最上层,把B文件设置为不存在

                        修改C:把第一层的C文件拷贝到最上层,修改C

                拿到1.0版本,所有的增删改位于最上层,变更操作完成后,打包为新镜像,版本1.1,发布到镜像仓库中(发布时,只会发布更改的第四层,非常快速)

               

架构

         C/S架构

         docker daemon作server端,在宿主机上以后台守护进程形式运行

         client端比较灵活,可以是本机(以bin命令形式发送指令),也可以是远程(以RESTful AP的形式发送指令)

解决方案

       

docker使用流程图

       

posted @   yc紫日  阅读(361)  评论(1编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示