接下来,咱们来了解一下 Spring Cloud 在与 DevOps 融合方面能够作哪些事情,它是如何让应用持续交付更加快捷的?咱们都知道,DevOps 打造了一套持续交付的流程,包括:开发、编译、测试、发布、运营等节点。如何让应用更顺畅地经过上述各个节点呢?Spring Cloud 能够在每一个研发节点上作一些配合和优化:面试
刚才咱们已经详细介绍了 Spring Cloud 在开发框架、服务集成和融合 DevOps 等方面的内容,接下来咱们看看 Spring Cloud 在适配云平台方面能够作哪些事情。一般为了让各类云计算技术栈对应用开发者透明,下降应用上云的难度,咱们须要适配虚拟机、容器等不一样类型的云基础设施。数据库
虚拟机是物理机的抽象,包括操做系统、内存和存储等,在制做 VM 镜像的时候能够按需安装软件,例如:WEB服务器和数据库等,这些软件也会出如今以该镜像启动的虚拟机中,VM 与它所在的主机,以及主机上其余 VM 相互隔离。容器在系统中只须要代码运行库环境所需的空间便可,同一个操做系统上的容器共享主机内核。因为实现原理不一样,运行虚拟机和容器时所需的资源也不一样。虚拟机本质上是一个完整的计算机,比容器须要更多的资源,而容器只是操做系统的一部分。通常容器集群资源密集度较低,所以在单个服务器上运行多容器要比在单个服务器上运行多VM更适合。服务器
那咱们的应用适合部署在哪一种基础设施上呢?一般公共应用适合采用虚拟机部署,例如:消息队列、注册中心、数据库等等,这类应用对运行资源要求比较高,自己没有太多个组件构成;业务应用适合采用容器部署,咱们能够将业务应用拆解成大量职责单一的微服务组件,每一个组件对资源要求相对肯定,并且在不一样访问量下须要弹性伸缩。框架
所以,咱们 DevOps 系统须要抽象出操做不一样基础设施的管理接口,基于这些管理接口实现应用生命周期管理、服务治理等功能,这块能够借鉴国外厂商指定了一个云应用管理标准 CAMP(Cloud Application Management for Platform),它定义了应用构建、运行、管理、监控和更新等API,以及资源模型和交互协议等。ßß微服务
在单个微服务构建上,Spring 已经从展现层、领域层和数据源层给咱们提供了丰富的组件,咱们只须要关注业务逻辑代码的编写;在服务集成上,Spring Cloud 已经提供了微服务全家桶,咱们只须要引用这些服务,不须要自行搭建这些公共服务;在对接 DevOps 和 云基础设施上,咱们能够作一些优化和适配。在它的支持下,咱们能够更加轻松地拥抱微服务、DevOps 和云计算,更好地应对新技术挑战。遵循分工协做的理念,Spring Cloud 给咱们提供了一种填空式的开发模式,在这种开发模式下,咱们只须要聚焦业务和用户,从而以更快地迭代速度打磨出优秀的产品。工具
Spring 家族变得愈来愈庞大,包括 Spring Framework、Spring Boot、Spring Cloud 等,若是咱们对它没有一个全局的认知,那咱们很容易迷失在技术细节当中,也用很差这款产品。本文是做者参与公司微服务框架研发过程当中积累的经验认知,能够做为 Spring Cloud 知识体系的索引,后续能够根据它深刻学习某个特性。学习
本文主要价值是帮助你们梳理出 Spring Cloud 相关的知识框架,也就是咱们常说的全局视角或者上帝视角。有了这个框架以后,咱们能够根据本身的须要按图索骥找相关节点的资料来研究学习,不至于陷入细节找不到方向。固然,考虑到咱们每一个人的工做学习状况不一样,平时遇到的问题也不一样,本文内容没法覆盖全部人遇到的问题,欢迎你们留言提问。测试
今天先分享到这里,若是你以为有价值,麻烦动动手指 转发 给其余须要的小伙伴。另外,老兵哥我后续还会分享职业规划、应聘面试、技能提高、影响力打造等经验,欢迎 关注 本专栏或歪信公主号 「IT老兵哥」!优化
本系列其余文章索引以下:职业规划