springrain 云原生微服务实现

我要开发同款
匿名用户2013年08月07日
86阅读
所属分类Java、Web应用开发、Web框架
授权协议Apache

作品详情

说明springrain是spring/springboot的开发范例.基于K8S+Istio实现云原生微服务.springrain自带代码生成器,能够生成对表的增删改查的逻辑代码.springrain是标准Maven项目,只依赖springboot,没有hibernate,struts,ibatis,数据库调优可以使用druid输出慢sql,比分析xml中的语句更直观,springrain所有的sql语句都使用Finder封装管理,只要查看Finder的引用即可.实现了什么?不增加学习成本,像单体一样开发分布式微服务.不修改业务代码,可以实现单体,分层,微服务多种部署模式切换.集成seata分布式事务实现.子项目module的前后端可以独立运行,也可以被无感知集成,实现前后端按需打包.实现思路启动加载springbean时,先检查本地是否有实现,如果没有就启动GRPC远程调用.开发人员无感知.基于seata分布式事务实现.支持有注解和无注解(开发人员无感知,理论上有不同步风险,个人感觉做好日志,风险不大)混合使用.基于K8S的Service实现服务注册和发现,ConfigMap实现配置中心.开发人员无感知.基于Istio实现微服务的发现,监控,熔断,限流.开发人员无感知.

架构设计详细思路:https://www.jiagou.com/post/58-cloud-native-service-mesh

限制接口和实现的命名强制规范.一个RPC接口只能有一个实现.分布式事务,一定要避免A服务update表t,RPC调用B服务,B服务也update表t.这样A等待B结果,B等待A释放锁,造成死锁.分布式无注解比较方便,理论上有不同步风险,个人感觉做好日志,风险不大Service层不可以使用ServletAPI,例如HttpRequest建议每个前后端module/子项目,都有各自的前缀,方便nginx根据路径解析如果module依赖包的特定版本(例如netty,Grpc)和根项目版本冲突,module不能无感知集成,暂时只能独立运行体验单体到分层切换修改springrain-system-web依赖springrain-system-service,不再依赖springrain-system-serviceimpl. springrain-system-serviceimpl添加springrain-grpc-server依赖,启用org.springrain.SystemServiceImplApplication的@SpringBootApplication注解

启动seata-server服务端.seata客户端的配置在项目的resources/file.conf里,默认配置是default.grouplist="127.0.0.1:8091"启动springrain-system-serviceimpl启动springrain-system-web访问https://127.0.0.1:8080/system/api/checkHealth文档

https://gitee.com/chunanyong/springrain/tree/master/springrain-system/springrain-system-web/doc

代码生成器

https://gitee.com/chunanyong/springrain/tree/master/springrain-gencode

sql脚本

https://gitee.com/chunanyong/springrain/tree/master/springrain-system/springrain-system-web/sql

测试用例//就极简而言,一个数据库只需要一个Service,就可以管理这个数据库的任意一张表//@Test查询基本类型publicvoidtestObject()throwsException{//Finderfinder=newFinder("selectidfromt_userwhere1=1");Finderfinder=Finder.getSelectFinder(User.class,"id").append("WHERE1=1");finder.append("andid=:userId").setParam("userId","admin");Stringid=baseDemoService.queryForObject(finder,String.class);System.out.println(id);}//@Test查询一个对象publicvoidtestObjectUser()throwsException{//Finderfinder=newFinder("select*fromt_userwhereid=:userIdorderbyid");Finderfinder=Finder.getSelectFinder(User.class).append("WHERE id=:userIdorderbyiddesc");finder.setParam("userId","admin");Useru=baseDemoService.queryForObject(finder,User.class);System.out.println(u.getName());}//@Test查询分页publicvoidtestMsSql()throwsException{//Finderfinder=newFinder("select*fromt_userorderbyid");Finderfinder=Finder.getSelectFinder(User.class).append("orderbyiddesc");Listlist=baseDemoService.queryForList(finder,User.class,newPage(2));System.out.println(list.size());for(Users:list){System.out.println(s.getName());}}//@Test调用数据库存储过程publicvoidtestProc()throwsException{Finderfinder=newFinder();finder.setParam("unitId",0);finder.setProcName("proc_up");MapqueryObjectByProc=(Map)baseDemoService.queryObjectByProc(finder);System.out.println(queryObjectByProc.get("#update-count-10"));}//@Test调用数据库函数publicvoidtestFunction()throwsException{Finderfinder=newFinder();finder.setFunName("fun_userId");finder.setParam("userId","admin");StringuserName=baseDemoService.queryForObjectByByFunction(finder,String.class);System.out.println(userName);}
声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论