微服务【Docker容器解决项目部署问题&Docker和虚拟机的区别&系统结构】第5章

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本篇主要是:Docker解决项目的部署问题,比如:依赖兼容问题,跨系统环境问题。以及介绍了Docker和虚拟机之间的区别对比

1,什么是Docker

1.1:项目部署的问题

大型项目组件较多,运行环境也较为复杂,就像一个项目前端需要用到node.js组件,后端需要用到数据库,缓存技术redis,异步技术MQ等等!!同时也会在部署的时候碰到一些问题:

1:依赖关系复杂,容易出现兼容性问题(就像下图中的这些node,Redis这些技术应用等等!将来都会部署到服务器中,而大多数服务器都会采用LInux操作系统,而这些技术应用在安装到Linux操作系统之前需要做一些准备工作。每个应用都有自己需要的依赖和函数库,而每个应用的依赖和函数库又有可能存在一定的差异性,例如版本问题,一个项目涉及很多的应用都有自己的版本难免会发生冲突,这样就会非常容易出现兼容性问题。)

2:开发,测试,生产环境有差异(这个就是说:部署的兼容性解决了你部署的成功了运行环境搞定了,但是开发环境,生产环境,预发布环境还需要等着你去搞定,更麻烦的是这些操作环境它们的操作系统还有可能不同,你在一个Windows系统中把开发环境配置好了,换到另外一个操作系统中还能正常运行吗?所以存在环境差异的问题)

image.gif编辑

1.2:Docker如何解决依赖的兼容问题的?

    • 将应用的Libs(函数库),Deps(依赖)配置与应用一起打包。(假如数据库应用需要部署,Docker技术直接把该应用所需要的函数库和依赖的一些配置和应用一起打包然后放入一个该应用的独立容器,每个应用都这样打包放入,到时候部署时候不就避免了依赖冲突等等嘛!
    • 将每个应用放到一个隔离容器去运行,避免互相干扰(可能有人存在这样的问题,把这些打包好的包扔到一个服务器上面难道不会有干扰吗?不会,因为Docker会用隔离的容器进行运行,已经一种沙箱技术什么意思呢!就是这些容器都不见,这样不就避免了干扰了嘛!

    image.gif编辑

    但是仅限于同一个操作系统中

    1.3:Docker解决跨系统环境差异

    1.3.1:以Ubuntu为例操作系统结构(结构如下):

    image.gif编辑

    结构包括:

      • 计算机硬件:例如CPU、内存、磁盘等
      • 系统内核:所有Linux发行版的内核都是Linux,例如CentOS、Ubuntu、Fedora等。内核可以与计算机硬件交互,对外提供内核指令,用于操作计算机硬件。
      • 系统应用:操作系统本身提供的应用、函数库。这些函数库是对内核指令的封装,使用更加方便。  

      其实所有的以Linux内核的操作系统都可以分为两层,一层是Linux内核,一层就是系统应用,区别就是上层的系统应用不同

      举个例子:Ubuntu和CentOSpringBoot都是基于Linux内核,无非是系统应用不同,提供的函数库有差异:image.gif编辑

      此时,如果将一个Ubuntu版本的MySQL应用安装到CentOS系统中去,MySQL在调用Ubuntu函数库时,会发现在CentOS系统中找不到函数库或者函数库找不到,就会报错了:  

      image.gif编辑

      Docker如何解决不同系统环境的问题?

        • 既然每个应用都依赖系统函数库,Docker说了那我直接把系统函数库一起打包,这样就不愁找不到函数库了
        • Docker运行到不同操作系统时,直接基于打包的函数库,借助于操作系统的Linux内核来运行

        如图: image.gif编辑

        1.3.2:内核是干什么用的?

        内核负责与计算机硬件进行交互,比方说调用个cpu,调用内存什么,查看个软件进程等等这些都是内核需要做的事情,而内核会把这些事情变成一个个的指令,调用指令进行操作计算机硬件,但是这些指令大多数比较简陋,如果基于这些指令开发应用太麻烦了。所以我们就有了系统,

        1.3.3:系统应用它又干了什么呢?

        它会将内核的指令进行封装形成函数,许许多多的函数形成了函数库,像咱们程序员可以基于函数库进行开发,程序调用我们的函数库,函数库调用内核的指令,指令调用计算机硬件从而实现应用的执行,这就是Linux系统的结构以及应用的组成原理

        1.4:小结

        Docker如何解决大型项目依赖关系复杂,不同组件依赖的兼容性问题?

          • Docker允许开发中将应用、依赖、函数库、配置一起打包,形成可移植镜像
          • Docker应用运行在容器中,使用沙箱机制,相互隔离

          Docker如何解决开发、测试、生产环境有差异的问题?

            • Docker镜像中包含完整运行环境,包括系统函数库,仅依赖系统的Linux内核,因此可以在任意Linux操作系统上运行

            Docker是一个快速交付应用、运行应用的技术,具备下列优势:

              • 可以将程序及其依赖、运行环境一起打包为一个镜像,可以迁移到任意Linux操作系统
              • 运行时利用沙箱机制形成隔离容器,各个应用互不干扰
              • 启动、移除都可以通过一行命令完成,方便快捷

              2,Docker和虚拟机的区别

              Docker可以让一个应用在任何操作系统中非常方便的运行。而以前我们接触的虚拟机,也能在一个操作系统中,运行另外一个操作系统,保护系统中的任何应用。

              2.1:两者有什么差异呢?

              虚拟机(virtual machine)是在操作系统中模拟硬件设备,然后运行另一个操作系统,比如在 Windows 系统里面运行 Ubuntu 系统,这样就可以运行任意的Ubuntu应用了。

              Docker仅仅是封装函数库,并没有模拟完整的操作系统,如图:

              image.gif编辑

              对比来看:

              image.gif编辑

              2.2:小结:

              Docker和虚拟机的差异:

                • docker是一个系统进程;虚拟机是在操作系统中的操作系统
                • docker体积小、启动速度快、性能好;虚拟机体积大、启动速度慢、性能一般
                相关文章
                |
                4月前
                |
                Kubernetes Docker Python
                Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
                本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
                795 108
                |
                3月前
                |
                弹性计算 关系型数据库 微服务
                基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
                在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
                1642 10
                |
                5月前
                |
                存储 监控 测试技术
                如何将现有的应用程序迁移到Docker容器中?
                如何将现有的应用程序迁移到Docker容器中?
                424 57
                |
                2月前
                |
                应用服务中间件 Linux nginx
                在虚拟机Docker环境下部署Nginx的步骤。
                以上就是在Docker环境下部署Nginx的步骤。需要注意,Docker和Nginix都有很多高级用法和细节需要掌握,以上只是一个基础入门级别的教程。如果你想要更深入地学习和使用它们,请参考官方文档或者其他专业书籍。
                122 5
                |
                2月前
                |
                监控 Kubernetes 安全
                还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
                蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
                还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
                |
                2月前
                |
                NoSQL 算法 Redis
                【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
                Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
                353 5