java17/5.x 分支升级以下内容:
- fix(lamp-generator): 代码生成器,按照5.0的项目结构生成新服务
- fix(lamp-generator): 修复代码生成器生成新服务后,无法启动的问题
- refactor(lamp-generator): 优化生成的service类的import类
- fix(lamp-database-max): 修复单体模式启动时,系统无法加载当前登录用户uri权限的bug
- refactor: 部署脚本存放在代码中,打包时一起上传到服务器
为什么要合并?
(这里的” 合并 “,指的是将一个单体版和一个微服务版项目进行合并为一个项目,同时支持单体和微服务 2 种方式)
你是否存在这样的问题或疑惑:
1. 项目规模小,想要前期使用单体版快速上线,后期若业务量增大,可以平滑变更为微服务版!
2. 公司有很多项目,一些小项目希望采用单体版,一些大项目希望采用微服务版
3. 本地开发、测试环境运行微服务项目时,需要启动太多服务,开发机器扛不住?
4. 同时维护 2 套源码(一套单体版,一套微服务版),且保持代码同步的难度大,工作量大!
解决方案:
《灯灯》5.0.0 版本开始,将原来的 lamp-cloud 项目和 lamp-boot 项目合并为一个项目,合并后的项目同时支持采用单体版的方式启动,也同时支持微服务版的方式启动。
合并后面临的挑战:
1. 微服务版本中,代码存在跨服务的接口调用,在单体版本应修改为本地调用,若一套代码同时兼容单体版和为服务版,这类代码如何实现?
2. 单体版只有需要启动一个 java 程序,微服务版需要启动多个 java 程序,在一套代码里如何实现?
具体的实现方式和解决方案请参考源码或者咨询作者。
体验网址
|
vben 版 | soybean 版 |
数据源模式 | 点我体验 | 点我体验 |
字段模式 | 点我体验 | 点我体验 |
账号密码都是:lamp
关于 lamp
灯灯
(简称灯, 英文名:lamp),她是一个项目集,为满足高内聚低耦合设计原则,将一个大项目拆解为以下几个子项目:
-
lamp-util:后端工具集
-
lamp-cloud:基于 Spring Cloud 实现的后台
-
lamp-boot:基于 Spring Boot 实现的后台
-
lamp-job:基于 xxl-job 集成本项目的分布式定时任务
-
lamp-generator:代码生成器
-
lamp-web:前端
lamp-cloud 简介
lamp-cloud
是基于SpringCloudAlibaba、
SpringCloud、
SpringBoot
开发的微服务中后台快速开发平台,支持 jdk17、jdk11和jdk8,
专注于多租户 (SaaS 架构) 解决方案,亦可作为普通项目(非 SaaS 架构)的基础开发框架使用,目前已实现 数据库隔离、字段隔离 等租户隔离方案以及非租户隔离的解决方案。
她拥有自研 RBAC(基于租户应用的角色权限控制体系)、网关统一鉴权、数据权限、优雅缓存解决方案、防缓存击穿、前后端统一表单校验、字典数据自动回显、可视化前后端代码生成器、支持多种文件存储、支持多种短信邮件发送接口、灰度发布、防 XSS 攻击、防 SQL 注入、分布式事务、分布式定时任务等功能;支持多业务系统并行开发, 支持多服务并行开发,是中后台系统开发脚手架的最佳选择。
lamp-cloud 代码简洁,注释齐全,架构清晰,非常适合个人学习以及中小企业作为基础框架使用。采用 Spring Cloud Alibaba、SpringBoot、Mybatis、Seata、Sentinel、RabbitMQ、FastDFS/MinIO、SkyWalking 等主要框架和中间件。本项目旨在实现基础框架能力,不涉及具体业务。
关注项目
-
官网:https://tangyh.top
-
源码:https://github.com/dromara/lamp-cloud
-
源码:https://gitee.com/dromara/lamp-cloud