微服务【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体积小、启动速度快、性能好;虚拟机体积大、启动速度慢、性能一般
                相关文章
                |
                1月前
                |
                运维 Kubernetes Docker
                利用Docker和Kubernetes构建微服务架构
                利用Docker和Kubernetes构建微服务架构
                |
                2月前
                |
                Kubernetes 调度 虚拟化
                Kubernetes和Docker有什么区别
                【10月更文挑战第18天】Kubernetes和Docker有什么区别
                |
                2月前
                |
                Kubernetes 持续交付 Docker
                利用 Docker 和 Kubernetes 实现微服务部署
                【10月更文挑战第2天】利用 Docker 和 Kubernetes 实现微服务部署
                |
                10天前
                |
                关系型数据库 MySQL Docker
                《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
                《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
                62 24
                |
                12天前
                |
                关系型数据库 MySQL Docker
                《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
                《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
                78 6
                |
                1月前
                |
                安全 持续交付 Docker
                微服务架构和 Docker 容器化部署的优点是什么?
                微服务架构和 Docker 容器化部署的优点是什么?
                |
                1月前
                |
                Docker 微服务 容器
                使用Docker Compose实现微服务架构的快速部署
                使用Docker Compose实现微服务架构的快速部署
                58 1
                |
                2月前
                |
                Kubernetes 负载均衡 Docker
                构建高效微服务架构:Docker与Kubernetes的完美搭档
                本文介绍了Docker和Kubernetes在构建高效微服务架构中的应用,涵盖基本概念、在微服务架构中的作用及其实现方法。通过具体实例,如用户服务、商品服务和订单服务,展示了如何利用Docker和Kubernetes实现服务的打包、部署、扩展及管理,确保微服务架构的稳定性和可靠性。
                104 7
                |
                1月前
                |
                安全 Linux 虚拟化
                LXD如何使用,跟Docker的区别都有什么?优点和缺点都有什么?
                【10月更文挑战第28天】LXD如何使用,跟Docker的区别都有什么?优点和缺点都有什么?
                147 1
                |
                1月前
                |
                Kubernetes 负载均衡 Docker
                构建高效微服务架构:Docker与Kubernetes的完美搭档
                【10月更文挑战第22天】随着云计算和容器技术的快速发展,微服务架构逐渐成为现代企业级应用的首选架构。微服务架构将一个大型应用程序拆分为多个小型、独立的服务,每个服务负责完成一个特定的功能。这种架构具有灵活性、可扩展性和易于维护的特点。在构建微服务架构时,Docker和Kubernetes是两个不可或缺的工具,它们可以完美搭档,为微服务架构提供高效的支持。本文将从三个方面探讨Docker和Kubernetes在构建高效微服务架构中的应用:一是Docker和Kubernetes的基本概念;二是它们在微服务架构中的作用;三是通过实例讲解如何使用Docker和Kubernetes构建微服务架构。
                66 6