Roses 基于 Spring Boot 的分布式和服务化解决方案开源项目

我要开发同款
匿名用户2018年06月20日
58阅读
开发技术Java
所属分类服务器软件、分布式应用/网格
授权协议Apache

作品详情

Roses基于SpringBoot,是开源项目 Guns 的升级版本,致力做更简洁的分布式和服务化解决方案,Roses提供基于SpringCloud的分布式框架,整合了springmvc+mybatis-plus+eureka+zuul+feign+ribbon+hystrix等等,提供Roses独有的高效率的开发体验,提供可靠消息最终一致性分布式事务解决方案,提供基于调用链的服务治理,提供可靠的服务异常定位方案(Log+Trace),一个分布式框架不仅需要构建高效稳定的底层开发框架,更需要解决分布式带来的种种挑战。

在几年前,刚工作的时候就开始接触分布式,并且使用分布式编写业务,那时候还很菜(现在也菜),只觉得微服务很牛逼,殊不知其中的艰难险阻,踩过很多坑,也走过弯路,Roses是根据自己积攒的经验编写出来的,完全开源,目的就是想让新接触微服务,搞分布式开发的同学能够快速上手。Roses在编写的时候有两个核心思想,第一个是注重解决分布式带来的种种挑战,第二个是注重提高开发人员的效率。

Roses的一些特点:

1.网关实现统一鉴权,资源权限过滤(鉴权机制)

2.网关生成唯一请求号(RequestNoGenerateFilter)(主要为了定位问题)

3.分布式事务解决方案(可靠消息最终一致性)

 4.分布式配置中心roses-config(统一管理项目配置,好维护)

5.一切请求基于RequestData和ResponseData(简化开发)

6.独创基于BeanPostProcessor的资源扫描器(多服务之间的资源搜集,集中管理)

7.独特的Feign错误解码器(继承Guns的开发思想,极大提高了开发效率)

8.Log+Trace日志记录(定位问题更便捷)

9.统一的文件日志记录格式(日志记录的规范)

快速开发微服务的秘籍roses-core

在roses-core模块的com.stylefeng.roses.core.config包下整合了大量开发常用到的配置,其中包含默认异常拦截,登陆用户的上下文获取,默认缓存配置,默认fastjson的配置,默认mybatis-plus的配置,默认的swagger的配置,默认的web配置等等等等,使得在新业务开发中,只要pom引入roses-core这个模块,即可很方便的注入这些特性,直接上手开编写业务,大大减少了新业务,新模块的配置,调试,各种框架集成拼接的时间,因为这些在Roses中已经为您提供好了,利用SpringBoot的自动配置机制,同样的,这些配置在项目启动的时候会默认加载,因为在roses-core模块下的META-INF/spring.factories中配有这些类,当然,如果您不需要某些特性(自动配置类)您可以在@SpringBootApplication注解上增加exclude参数来排除这些自动配置。

更多详情,请点击:https://gitee.com/naan1993/roses

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论