1.Spring Cloud微服务基础

传统项目架构

传统项目分为三层架构,将业务逻辑层、数据库访问层、控制层放入在一个项目中。

有点:适合个人或者小团队开发,不适合大团队开发。


分布式项目架构


根据业务需求进行拆分成N个子系统,多个子系统相互协作才能完成业务流程子系统之间通讯使用RPC远程通讯技术。

优点:

    1.把模块拆分,使用接口通信,降低模块之间的耦合度。

    2.把项目拆分成若干个子项目,不同的团队负责不同的子项目。

    3.增加功能时只需要再增加一个子项目,调用其它系统的接口就可以。

    4.可以灵活的进行分布式部署。

有优点就有缺点,缺点如下:

    1.系统之间交互需要使用远程通信,接口开发增加工作量。

    2.各个模块有一些通用的业务逻辑无法共用。

为了解决上面分布式架构的缺点,我们引入了soa架构,SOA:ServiceOriented Architecture面向服务的架构。也就是把工程拆分成服务层、表现层两个工程。服务层中包含业务逻辑,只需要对外提供服务即可。表现层只需要处理和页面的交互,业务逻辑都是调用服务层的服务来实现。

面向服务架构

什么是SOA架构

业务系统分解为多个组件,让每个组件都独立提供离散,自治,可复用的服务能力
通过服务的组合和编排来实现上层的业务流程

作用:简化维护,降低整体风险,伸缩灵活

spring cloud还需要k8_java

微服务架构

什么是微服务架构

架构设计概念,各服务间隔离(分布式也是隔离),自治(分布式依赖整体组合)其它特性(单一职责,边界,异步通信,独立部署)是分布式概念的跟严格执行
SOA到微服务架构的演进过程

作用:各服务可独立应用,组合服务也可系统应用(巨石应用[monolith]的简化实现策略-平台思想)

SpringCloud

SpringCloud 为开发人员提供了快速构建分布式系统的一些工具,包括配置管理、服务发现、断路器、路由、负载均衡、微代理、事件总线、全局锁、决策竞选、分布式会话等等。它运行环境简单,可以在开发人员的电脑上跑。spring cloud是基于Springboot的,所以需要开发中对Springboot有一定的了解。

SpringCloud主要包括以下内容

Spring Cloud Netflix

    是对Netflix开发的一套分布式服务框架的封装,包括服务的发现和注册,负载均衡、断路器、REST客户端、请求路由等。

Spring Cloud Config

    将配置信息中央化保存, 配置Spring Cloud Bus可以实现动态修改配置文件。

Spring Cloud Bus

    分布式消息队列,是对Kafka, MQ的封装

Spring Cloud Security

    对Spring Security的封装,并能配合Netflix使用

Spring Cloud Zookeeper

    对Zookeeper的封装,使之能配置其它Spring Cloud的子项目使用

Spring Cloud Eureka

    Spring Cloud Eureka 是 Spring Cloud Netflix 微服务套件中的一部分,它基于Netflix Eureka 做了二次封装,主要负责完成微服务架构中的服务治理功能。