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),她是一个项目集,为满足高内聚低耦合设计原则,将一个大项目拆解为以下几个子项目:

  1. lamp-util:后端工具集

  2. lamp-cloud:基于 Spring Cloud 实现的后台

  3. lamp-boot:基于 Spring Boot 实现的后台

  4. lamp-job:基于 xxl-job 集成本项目的分布式定时任务

  5. lamp-generator:代码生成器

  6. 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

免责声明:本文系转载,版权归原作者所有;旨在传递信息,不代表一休教程网的观点和立场。