基于 Spring Boot 的研发框架 SOFABoot

基于 Spring Boot 的研发框架 SOFABoot

Apache 2.0
Java 查看源码»
跨平台
阿里巴巴
2018-04-19
王练

SOFABoot 是蚂蚁金服开源的基于 Spring Boot 的研发框架,它在 Spring Boot 的基础上,提供了诸如 Readiness Check,类隔离,日志空间隔离等等能力。在增强了 Spring Boot 的同时,SOFABoot 提供了让用户可以在 Spring Boot 中非常方便地使用 SOFAStack 相关中间件的能力。

一、背景

Spring Boot 是一个非常优秀的开源框架,可以非常方便地就构建出一个基于 Spring 的应用程序,但是在使用过程中,还是会遇到一些问题:

  • Spring Boot 提供了一个基础的健康检查的能力,中间件和应用都可以扩展来实现自己的健康检查逻辑。但是 Spring Boot 的健康检查只有 Liveness Check 的能力,缺少 Readiness Check 的能力,这样会有比较致命的问题。当一个微服务应用启动的时候,必须要先保证启动后应用是健康的,才可以将上游的流量放进来(来自于 RPC,网关,定时任务等等流量),否则就可能会导致一定时间内大量的错误发生。

  • Spring Boot 虽然通过依赖管理(Dependency Management)的方式最大程度的保证了 Spring Boot 管理的 JAR 包之间的兼容性,但是不可避免的,当引入一些其他的 JAR 包的时候,还是可能会遇到冲突,而且很多时候这种冲突解决起来并不是这么容易,一个例子是当冲突的包是序列化相关的类库时,比如说 Hessian,如果应用中的一个组件需要使用 Hessian 3,而另一个则必须要使用 Hessian 4,由于 Hessian 3 和 Hessian 4 之间的不兼容性,并且序列化还涉及到微服务中的上下游服务,要把 Hessian 统一到一个版本绝非易事。

  • 在超大规模微服务运维的场景下,运维能力的平台化是一定要解决的问题,而监控又是其中非常主要的一个点,针对于日志监控这种情况,Spring Boot 并没有提供任何解决方案。大部分的开源组件,具体要打印哪些日志,打印到什么路径,什么文件下面,都是由应用的使用者来决定,这样会导致每一个应用的日志配置都各式各样,每一个应用都需要去监控系统中配置自己应用的日志监控,导致关键的监控的实施成本特别高。

为了解决以上的问题,又因为 SOFAStack 中的诸多中间件本身就需要集成 Spring Boot,所以蚂蚁金服基于 Spring Boot 开发并开源了 SOFABoot,来解决以上的问题,也方便使用者在 Spring Boot 中方便地去使用 SOFAStack 中间件。

二、功能简介

为了解决 Spring Boot 在实施大规模微服务架构时候的问题,SOFABoot 提供了以下的能力:

2.1 增强 Spring Boot 的健康检查能力

针对 Spring Boot 缺少 Readiness Check 能力的情况,SOFABoot 增加了 Spring Boot 现有的健康检查的能力,提供了 Readiness Check 的能力。利用 Readiness Check 的能力,SOFAStack 下各种中间件只有在 Readiness Check 通过之后,才将流量引入到应用的实例中,比如 RPC,只有在 Readiness Check 通过之后,才会向服务注册中心注册,后面来自上游应用的流量才会进入。

除了中间件可以利用 Readiness Check 的事件来控制流量的进入之外,PAAS 系统也可以通过访问 http://localhost:8080/health/readiness 来获取应用的 Readiness Check 的状况,用来控制例如负载均衡设备等等的流量。

2.2 提供类隔离的能力

为了解决 Spring Boot 下的类依赖冲突的问题,SOFABoot 基于 SOFAArk 提供了 Spring Boot 上的类隔离的能力,在一个 SOFABoot 的系统中,只要引入 SOFAArk 相关的依赖,就可以将 SOFAStack 的中间件相关的类和应用相关的类的 ClassLoader 进行隔离,防止出现类冲突。当然,用户也可以基于 SOFAArk,将其他的中间件、第三方的依赖和应用的类进行隔离。

2.3 日志空间隔离能力

为了统一大规模微服务场景下的中间件日志的打印,SOFABoot 提供了日志空间隔离的能力给各个 SOFAStack 的中间件,各个 SOFAStack 的中间件采用日志空间隔离的能力之后,自动就会将本身的日志和应用的普通日志隔离开来,并且打印的日志的路径也是相对固定,非常方便进行统一地监控。

2.4 SOFAStack 中间件的集成管理

基于 Spring Boot 的自动配置能力,SOFABoot 提供了 SOFAStack 中间件统一易用的编程接口以及 Spring Boot 的 Starter,方便在 Spring Boot 环境下使用 SOFAStack 中间件,每一个 SOFAStack 中间件都是独立可插拔的组件,节约开发时间,和后期维护的成本。

的码云指数为
超过 的项目
加载中

评论(10)

二进制艺术
二进制艺术
不错,不过我还是用 springboot
lgphp
lgphp
没什么大用
二的基本算合格
二的基本算合格
支持~
黄海彬
黄海彬
不错!
kukaqin
kukaqin
osgi?
晴風1960318070
晴風1960318070
6666666
回忆总想笑
回忆总想笑
66
O
OSC_XDbdHm
666
之渊
之渊
6666
r
rongyang
666666

SOFABoot 2.6.2 发布,蚂蚁金服开源研发框架

SOFABoot 2.6.2 发布了,SOFABoot 是蚂蚁金服开源的基于 Spring Boot 的研发框架,它在 Spring Boot 的基础上,提供了诸如 Readiness Check、类隔离、日志空间隔离等能力。在增强了 Spring B...

04/05 06:42

SOFABoot 3.1.2 发布,蚂蚁金服开源研发框架

SOFABoot 3.1.2 发布了,SOFABoot 是蚂蚁金服开源的基于 Spring Boot 的研发框架,它在 Spring Boot 的基础上,提供了诸如 Readiness Check、类隔离、日志空间隔离等能力。在增强了 Spring B...

02/24 07:06

SOFABoot 2.6.1 发布,蚂蚁金服开源研发框架

SOFABoot 2.6.1 发布了,SOFABoot 是蚂蚁金服开源的基于 Spring Boot 的研发框架,它在 Spring Boot 的基础上,提供了诸如 Readiness Check、类隔离、日志空间隔离等能力。在增强了 Spring B...

02/03 08:12

SOFABoot 2.6.0 发布,蚂蚁金服开源研发框架

1、发布 SOFABoot v2.6.0 , 主要变更如下: i. 模块化开发支持扩展点机制 ii. 支持 Spring Bean 异步初始化,加速应用启动 iii. 修复配置属性 management.port 导致健康检查失败问题 iv. 修复...

01/26 08:29

SOFABoot 3.1.1 发布,支持 Gradle 依赖管理

1、发布 SOFABoot v3.1.1 , 主要变更如下: i. 提供 Gradle 插件,支持 Gradle 依赖管理 ii. 优化日志配置,默认引入 log-sofa-boot-starter iii. 修复 Spring Cloud Context RestartListen...

2018/12/29 16:14

SOFABoot 3.1.0 发布,支持 JDK 11

SOFABoot 3.1.0 发布了,SOFABoot 是蚂蚁金服开源的基于 Spring Boot 的研发框架,它在 Spring Boot 的基础上,提供了诸如 Readiness Check、类隔离、日志空间隔离等能力。在增强了 Spring B...

2018/12/08 08:43

久等了,SOFABoot 3.0 正式发布,支持 Spring Boot 2.0

前言 久等了!SOFABoot 正式发布 3.0.0,支持 Spring Boot 2.0~~ SOFABoot 是蚂蚁金服开源的基于 Spring Boot 的研发框架,它在 Spring Boot 的基础上,提供了诸如 Readiness Check,类隔离...

2018/11/16 13:52

SOFABoot 3 发布,兼容 Spring Cloud、Spring Boot

SOFABoot 3.0.0 发布了,SOFABoot 是蚂蚁金服开源的基于 Spring Boot 的研发框架,它在 Spring Boot 的基础上,提供了诸如 Readiness Check、类隔离、日志空间隔离等能力。在增强了 Spring B...

2018/11/10 07:21

SOFABoot v2.5.1 发布,基于 Spring Boot 的研发框架

1、发布 SOFABoot v2.5.1, 主要变更: i. 修复 HealthIndicator 健康检查问题; ii. 升级 SOFARPC 至 v5.4.7 iii. 升级 SOFABolt 至 v1.4.6 iv. 升级 SOFATracer 至 v2.2.2 详情见发布报告:...

2018/10/27 18:34

SOFABoot 2.5.0 发布,基于 Spring Boot 的研发框架

SOFABoot v2.5.0 已发布, 主要变更如下: i. 提供 SOFABoot banner; ii. 修复 SofaRuntimeProperties 配置不生效问题; iii. 使用 Jackson 替代 fastjson; iv. 优化健康检查逻辑; v. 升级...

2018/10/12 11:18

没有更多内容

加载失败,请刷新页面

8
回答
SOFA:十年锤炼自研架构,拥抱开源共建

SOFA(Scalable Open Financial Architecture)是蚂蚁金服研发的金融级分布式中间件,很多人认为这个国产自主研发项目来势...

2018/09/12 15:49

没有更多内容

加载失败,请刷新页面

没有更多内容

蚂蚁开源 | 在 Spring Boot 中集成 SOFABoot 类隔离能力

SOFABoot 是蚂蚁金服中间件团队开源的基于 Spring Boot 的一个开发框架,其在 Spring Boot 基础能力之上,增加了类隔离能力。蚂蚁金服内部丰富的实践场景表明,类隔离能力对解决类冲突、版本...

2018/08/16 12:22
8
0
开源 | 蚂蚁金服分布式中间件开源第二弹:丰富微服务架构体系

小蚂蚁说: 数据、消息、微服务是蚂蚁金服自主研发的金融级分布式中间件 SOFA (Scalable Open Financial Architecture)的三大方向。 一个多月前,蚂蚁金服开源了 SOFABoot 和 SOFARPC 两个...

2018/06/01 14:56
59
0
Alipay 开源 SofaRPC

概述 SOFARPC 是一个高可扩展性、高性能、生产级的 Java RPC 框架。在蚂蚁金服 SOFARPC 已经经历了十多年及五代版本的发展。SOFARPC 致力于简化应用之间的 RPC 调用,为应用提供方便透明、稳...

2018/04/20 08:56
3.7K
0
蚂蚁金服启动分布式中间件开源计划,用于快速构建金融级云原生架构

原文地址:http://www.sohu.com/a/228804309_99940985 我们很高兴地宣布,今天蚂蚁金服启动分布式中间件(Scalable Open Financial Architecture,以下简称 SOFA 中间件)的开源计划! SOFA...

2018/05/01 16:47
533
0
SOFARPC 5.5.X 新版发布 | 集成 Nacos 与 Hystrix

SOFA Scalable Open Financial Architecture 是蚂蚁金服自主研发的金融级分布式中间件,包含了构建金融级云原生架构所需的各个组件,是在金融场景里锤炼出来的最佳实践。 SOFA 文档: http://...

03/06 11:38
3
0
重磅消息:蚂蚁金服推出RPC框架

**先附上框架地址** > https://github.com/alipay/sofa-boot > https://github.com/alipay/sofa-rpc **蚂蚁金服推出一系列框架和组件服务 ** **sofa-boot ** > SOFABoot 是蚂蚁金服开源的基于...

2018/04/20 00:34
451
0
Hey, SOFAer!有些话想对你说:

“开源”二字代表的不仅仅是一个项目,更是代表了整个技术社区,代表了隐藏在背后的工程师们。 很幸运,这一年遇到你们。 生于蚂蚁金服,经历 12 年的业务锤炼,这是金融级分布式架构 SOFASt...

04/16 11:58
1
0
蚂蚁金服微服务实践 | 开源中国年终盛典分享实录

章耿,花名余淮,蚂蚁金服高级技术专家。 2007 年毕业后一直从事服务化相关的工作,最早在国家电网做电子商务平台 SOA 化的工作,之后在京东负责京东的服务化框架 JSF,目前在蚂蚁金服中间件...

02/21 15:09
15
0
蚂蚁金服微服务实践|开源中国年终盛典分享实录

章耿,花名余淮,蚂蚁金服高级技术专家。目前在蚂蚁金服中间件服务与框架组负责应用框架与SOFAStack相关的工作。本文根据余淮在 2018 开源中国年终盛典的演讲内容整理,完整的分享 PPT 获取方...

01/30 10:09
22
0
2018年阿里巴巴开源的那些牛逼java项目汇总

把阿里巴巴的一些重要的开源项目进行整理,希望对大家有所帮助。(以下项目排名不分先后) 1.分布式应用服务开发的一站式解决方案 Spring Cloud Alibaba Spring Cloud Alibaba 致力于提供分布...

02/15 17:40
46
0

没有更多内容

加载失败,请刷新页面

返回顶部
顶部