给自己做了一个简单的SpringBoot微服务开发脚手架

本文介绍了作者开发通用脚手架的过程,包括选择技术栈(如SpringBoot、SpringCloud、MyBatis-Plus等),实现登录认证、日志管理等功能,以及计划中的代码生成器和支付模块。分享了项目的结构和使用方法,源码可在GitHub上获取并参与贡献。

如您不吝赐教,可以提PR或Issues,我会认真拜读。 ^_^

什么是脚手架

百度百科搜索脚手架词条显示,脚手架是为了保证各施工过程顺利进行而搭设的工作平台。

软件的脚手架的作用,维基百科显示

Scaffolding is a meta-programming method of building database-backed software applications. It is a technique supported by some model-view-controller frameworks, in which the programmer may write a specification that describes how the application database may be used. The compiler uses this specification to generate code that the application can use to create, read, update and delete database entries, effectively treating the template as a "scaffold" on which to build a more powerful application.

*译:脚手架是一种构建数据库支持的软件应用程序的元编程方法。它是一些模型-视图-控制器框架支持的一种技术,程序员可以在其中编写描述如何使用应用程序数据库的规范。编译器使用该规范生成应用程序可以用来创建、读取、更新和删除数据库条目的代码,有效地将模板视为构建更强大应用程序的“脚手架”

为什么做

起初是接了一些私活的单子,每次接到不同类型的项目的时候都需要新建一个项目,为了节省时间,我为毕业设计的单子做了同类型的基础框架,在不同的类型上创建新分支进行开发。

后续做的不完全是毕业设计的项目,基础框架自然不能覆盖了,某些项目需要更加完备的功能,因此闲来无事,开始研究是否能做一个属于日常开发的通用脚手架。

开始

编写脚手架的步骤大致为编写或者现找一个可用合适的SpringBoot微服务项目,再开发模板引擎,将原有的项目内容替换成自己的。

准备

首先是技术选型,开发对应类型的项目脚手架。根据我个人的开发需求,开发微服务和单体版本,符合不同体量项目的需求,开发小项目时不需要微服务。并且由于学习的需要,则集成技术选用较新的版本。

环境

版本
Java17+
Lombok/
Maven3.5+
SpringBoot3.0.7
SpringCloud-Alibaba2022.0.0.0

集成

版本
mybatis-Plus17+
redisson/
openfeign3.5+
elastic-search3.0.7
ok-http3.0.7
spring-security6.0.3
mysql8+
jjwt0.9.1
log4j2.20.0
freeMarker2.3.31
jakarta.validation3.0.2
nacos-config2022.0.0.0
nacos-discovery2022.0.0.0

分支

Git管理参考 A successful Git branching model

 

分支一览

复制代码

master # 源分支 ├─ feature/freemarker-1.0.0 # 生成器功能开发分支 ├─ feature/standalone1.0.0  # 单体功能分支 ├─ feature/microservice1.0.0 # 微服务功能分支 # 目前仅一人开发,故没有开启devlop,直接在功能分支上开发

目录

此处我使用的是自己开发的项目,项目结构如下。

 

目录结构

复制代码

spring-cloud-security-cli ├─nacos-example | └config.yml # nacos参考配置文件 ├─ cloud-cli-service # 服务层模块 ├─ cloud-cli-security # 安全认证模块 ├─ cloud-cli-generate # 代码生成器模块(开发中) ├─ cloud-cli-common # 通用模块(工具、配置) ├─ cloud-cli-bean # 实体类模块 ├─ cloud-cli-api # Web api服务 ├─ (待定) cloud-cli-pay # 支付SDK分支

完成的功能

基于Spring Security + JJWT 的登录认证和安全拦截

aspect log4j的全局控制层日志打印

common模块下的其他配置、工具类…

正在开发的功能

生成器模块通过控制台交互、http调用生成自定义项目。

想要加入的功能

包装支付宝、微信支付功能的支付模块

使用配置

代码生成器模块还在开发,目前使用IDE替换项目、包名

替换后将Application的包扫描路径换成需要的路径

image.png

standalone分支使用

启动redis服务。

修改api模块下application.yml文件里的redis、mysql链接信息为你的地址。

image.png

microservice分支使用

参考配置文件为nacos-example文件夹下的config.yml

启动nacos、redis服务。

修改api模块下bootstrap.yml的配置信息。

image.png

源码下载

项目仍在开发维护,感兴趣可以参与贡献。

GitHub地址:github.com/IsNott/spri…

image.png

lamp-cloud微服务脚手架的前身是zuihou-admin-cloud,从3.0.0版本开始,改名为lamp-cloud,它是lamp项目的其中一员。 lamp-cloud微服务脚手架一个基于SpringCloud(Hoxton.SR10) + SpringBoot(2.3.10.RELEASE)的SaaS微服务脚手架,具有统一授权、认证后台管理系统,其中包含具备用户管理、资源权限管理、网关API、分布式事务、大文件断点分片续传等多个模块,支持多业务系统并行开发,可以作为后端服务的开发脚手架。代码简洁,架构清晰,适合学习和直接项目中使用。核心技术采用Nacos、Fegin、Ribbon、Zuul、Hystrix、JWT Token、Mybatis、SpringBoot、Redis、RibbitMQ等主要框架和中间件。 lamp-cloud微服务脚手架功能: 1、服务注册&发现与调用: 基于Nacos来实现的服务注册与发现,使用使用Feign来实现服务互调, 可以到使用HTTP请求远程调用时能与调用本地方法一样的编码体验,开发者完全感知不到这是远程方法,更感知不到这是个HTTP请求。 2、服务鉴权: 通过JWT的方式来加强服务之间调度的权限验证,保证内部服务的安全性。 3、负载均衡: 将服务保留的rest进行代理和网关控制,除了平常经常使用的node.js、nginx外,Spring Cloud系列的zuul和ribbon,可以帮我们进行正常的网关管控和负载均衡。其中扩展和借鉴国外项目的扩展基于JWT的Zuul限流插件,方面进行限流。 4、熔断机制: 因为采取了服务的分布,为了避免服务之间的调用“雪崩”,采用了Hystrix的作为熔断器,避免了服务之间的“雪崩”。 5、监控: 利用Spring Boot Admin 来监控各个独立Service的运行状态;利用turbine来实时查看接口的运行状态和调用频率;通过Zipkin来查看各个服务之间的调用链等。 6、链路调用监控: 利用Zipkin实现微服务的全链路性能监控, 从整体维度到局部维度展示各项指标,将跨应用的所有调用链性能信息集中展现,可方便度量整体和局部性能,并且方便找到故障产生的源头,生产上可极大缩短故障排除时间。有了它,我们能到: 请求链路追踪,故障快速定位:可以通过调用链结合业务日志快速定位错误信息。 可视化:各个阶段耗时,进行性能分析。 依赖优化:各个调用环节的可用性、梳理服务依赖关系以及优化。 数据分析,优化链路:可以得到用户的行为路径,汇总分析应用在很多业务场景。 7、数据权限 利用基于Mybatis的DataScopeInterceptor拦截器实现了简单的数据权限 8、SaaS(多租户)的无感解决方案 使用Mybatis拦截器实现对所有SQL的拦截,修改默认的Schema,从而实现多租户数据隔离的目的。 并且支持可插拔。 9、二级缓存 采用J2Cache操作缓存,第一级缓存使用内存(Caffeine),第二级缓存使用 Redis。 由于大量的缓存读取会导致 L2 的网络成为整个系统的瓶颈,因此 L1 的目标是降低对 L2 的读取次数。 该缓存框架主要用于集群环境中。单机也可使用,用于避免应用重启导致的缓存冷启动后对后端业务的冲击。 10、优雅的Bean转换 采用Dozer组件来对 DTO、DO、PO等对象的优化转换 11、前后端统一表单验证 严谨的表单验证通常需要 前端+后端同时验证, 但传统的项目,均只能前后端一次检验, 后期规则变更,又得前后端同时修改。 故在hibernate-validator的基础上封装了zuihou-validator-starter起步依赖,提供一个通用接口,可以获取需要校验表单的规则,然后前端使用后端返回的规则, 以后若规则改变,只需要后端修改即可。 12、防跨站脚本攻击(XSS) 通过过滤器对所有请求中的 表单参数 进行过滤 通过Json反序列化器实现对所有 application/json 类型的参数 进行过滤 13、当前登录用户信息注入器 通过注解实现用户身份注入 14、在线API 由于原生swagger-ui某些功能支持不够友好,故采用了国内开源的swagger-bootstrap-ui,并制作了stater,方便springboot用户使用。 15、代码生成器 基于Mybatis-plus-generator自定义了一套代码生成器, 通过配置数据库字段的注释,自动生成枚举类、数据字典注解、SaveDTO、UpdateDTO、表单验证规则注解、Swagger注解等。 16、定时任务调度器: 基于xxl-jobs进行了功能增强。(如:指定时间发送任务、执行器和调度器合并项目、多数据源) 17、大文
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值