zuihou-admin-cloud 2.5.1 发布,支持配置外部数据源

栏目: 软件资讯 · 发布时间: 5年前

内容简介:今日更新: 升级依赖 mybatisplus.version -> 3.4.0 mybatis.version -> 3.5.5 mybatis-spring.version -> 2.0.5 p6spy.version -> 3.9.1 独立租户服务(zuihou-tenant-server),需要租户模式(zuihou-admin...

今日更新:

  • 升级依赖
  • mybatisplus.version -> 3.4.0
    mybatis.version -> 3.5.5 
    mybatis-spring.version -> 2.0.5 
    p6spy.version -> 3.9.1
  • 独立租户服务(zuihou-tenant-server),需要租户模式(zuihou-admin-ui)的就启动租户服务(TenantApplication)。zuihou_none模式和不需要新增租户的无需启动,使得租户功能、权限功能最小化 ????????????
  • 新增租户时,DATASOURCE模式支持指定任意数据库作为租户的数据源 ????????????
  • 支持每个服务的租户库独立数据库 (之前的版本默认都是zuihou_base_xxxx) ????????????
  • 将DATASOURCE模式 zuihou-authority-server/src/main/resources/sqls/ 下的初始化租户库脚本,分散到各个服务 ????????????
  • 将SCHEMA模式 zuihou-authority-server/src/main/resources/sqls/ 下的初始化租户库脚本,调整到租户服务 ????????????
  • 修复新增数据源时,网关服务无法动态新增数据源的bug
  • 修复升级版本后DATASOURCE模式无法使用p6spy打印 sql 的bug
  • 新增TenantP6SpyLogger:用于 p6spy 在输出的sql日志中,打印当前租户、当前用户ID、当前数据源连接url
  • 修复p6spy配置文件配置项使用错误的bug
  • 修复p6spy批量操作打印SQL日志重复的问题
  • 优化mybatis plus升级后提示的过时代码
  • SCHEMA、COLUMN模式实现插件调整成 MP 3.4.0 版本最新插件
  • 优化 SuperCacheServiceImpl 类几个批量操作方法的逻辑
  • 升级docs/dockerfile/ 下的 mysql 8 和 nacos脚本,使得 nacos 升级到1.3.1并完全支持mysql8 ????????????
  • 新增租户时,内置超级管理员(admin),用于维护、管理整个SaaS平台,拥有一切权利,能登录到任意的租户系统中,查看其数据。 ????????????
  •  优化登录接口性能(查询租户、应用、用户表走缓存)
  •  SuperCacheService 新增getByKey方法 - 修复 AttachmentController#findAttachmentByBiz 接口和父类接口冲突
  • 修复地区管理查询数据的bug
  • 优化重置用户密码功能
  • 用户表新增readonly字段 - org表新增类型字段,用于区分单位或者部门
  • 修复限流功能设置了有效期时的bug
  • 新增zuihou-public公共模块,将zuihou-common(业务公共包)、zuihou-tenant-datasource(数据源模式插件包)等跟业务相关的 工具 类、插件、业务公共类等移到该模块下 - 修复shells/linux/start.sh启动脚本参数位置错误的bug
  • 修复代码不完全兼容NONE模式的bug
  • SCHEMA、DATASOURCE 模式各个服务链接的库和描述:
  • 后台服务 项目名 启动时连接的库 运行时租户库 功能描述
    认证服务 zuihou-oauth zuihou_defaults zuihou_base_{tenant} 负责登录、用户必备的数据接口
    权限服务 zuihou-authority zuihou_defaults zuihou_base_{tenant} 权限、公共、组织架构等基础功能。 后期考虑更名为 zuihou-base(欢迎提建议)
    文件服务 zuihou-file zuihou_defaults zuihou_base_{tenant} 负责文件上传、下载等功能
    消息服务 zuihou-msgs zuihou_defaults zuihou_base_{tenant} 负责站内信、消息、短信、邮件等功能
    租户服务 zuihou-tenant zuihou_defaults zuihou_defaults 负责租户模式管理租户
    网关服务 zuihou-gate zuihou_defaults zuihou_extend_{tenant} 负责统一路由、认证、限流等
    订单服务 zuihou-order zuihou_defaults zuihou_extend_{tenant} 演示用
    演示服务 zuihou-demo zuihou_defaults zuihou_extend_{tenant} 演示用
    定时服务 zuihou-jobs zuihou_defaults zuihou_base_{tenant}、zuihou_extend_{tenant} 负责定时任务

租户模式:

租户模式 描述 优点 缺点 分布式事务
NONE(非租户模式)  没有租户 简单、适合独立系统 缺少租户系统的便利性 支持
COLUMN(字段模式) 租户共用一个数据库,在业务表中增加字段来区分   简单、不复杂、开发无感知  数据隔离性差、安全性差、数据备份和恢复困难 支持
SCHEMA(独立schema)  每个租户独立一个 数据库(schema),执行sql时,动态在表名前增加schema 简单、开发无感知、数据隔离性好 配置文件中必须配置数据库的root账号、不支持复杂sql和 sql嵌套自定义函数 支持
DATASOURCE(独立数据源)  每个租户独立一个 数据库(数据源),执行代码时,动态切换数据源 可独立部署数据库,数据隔离性好、扩展性高、故障影响小 相对复杂、开发需要注意切换数据源时的事务问题、需要较多的数据库 支持

简介:


基于`SpringCloud(Hoxton.SR7)`  + `SpringBoot(2.2.9.RELEASE)` 的 SaaS型单体架构脚手架,具备用户管理、资源权限管理、网关统一鉴权、Xss防跨站攻击、自动代码生成、多存储系统、分布式事务、分布式定时任务等多个模块,支持多业务系统并行开发,支持多服务并行开发,可以作为后端服务的开发脚手架。代码简洁,架构清晰,非常适合学习使用。核心技术采用Nacos、Fegin、Ribbon、Zuul、Hystrix、JWT Token、Mybatis、SpringBoot、Seata、Nacos、Sentinel、RabbitMQ、FastDFS等主要框架和中间件。

希望能努力打造一套从 SaaS基础框架 - 微服务架构 - 自动化部署 - 系统监测 的解决方案。本项目旨在实现基础能力,不涉及具体业务。
 

功能点介绍:

 服务鉴权:

通过JWT的方式来加强服务之间调度的权限验证,保证内部服务的安全性。

监控:

利用Spring Boot Admin 来监控各个独立Service的运行状态;利用turbine来实时查看接口的运行状态和调用频率;通过Zipkin来查看各个服务之间的调用链等。

数据权限:

利用基于Mybatis的DataScopeInterceptor拦截器实现了简单的数据权限

SaaS的无感解决方案:

使用Mybatis拦截器实现对所有SQL的拦截,COLUMN模式动态拼接租户编码,SCHEMA模式修改默认的Schema,DATASOURCE模式动态切换数据源,从而实现多租户数据隔离的目的。并且支持禁用租户模式。

二级缓存:

采用J2Cache操作缓存,第一级缓存使用内存(Caffeine),第二级缓存使用 Redis。 由于大量的缓存读取会导致 L2 的网络成为整个系统的瓶颈,因此 L1 的目标是降低对 L2 的读取次数。 该缓存框架主要用于集群环境中。单机也可使用,用于避免应用重启导致的缓存冷启动后对后端业务的冲击。

优雅的Bean转换:

采用Dozer组件来对 DTO、DO、PO等对象的优化转换

前后端统一表单验证:

严谨的表单验证通常需要 前端+后端同时验证, 但传统的项目,均只能前后端各做一次检验, 后期规则变更,又得前后端同时修改。 故在hibernate-validator的基础上封装了zuihou-validator-starter起步依赖,提供一个通用接口,可以获取需要校验表单的规则,然后前端使用后端返回的规则, 以后若规则改变,只需要后端修改即可。

防跨站脚本攻击(XSS):

  •      通过过滤器对所有请求中的 表单参数 进行过滤
  •      通过Json反序列化器实现对所有 application/json 类型的参数 进行过滤

当前用户信息注入器:

 通过注解实现用户身份注入

在线API:

由于原生swagger-ui某些功能支持不够友好,故采用了国内开源的 knife4j ,并制作了stater,方便springboot用户使用。

代码生成器:

基于Mybatis-plus-generator自定义了一套代码生成器, 通过配置数据库字段的注释,自动生成枚举类、数据字典注解、SaveDTO、UpdateDTO、表单验证规则注解、Swagger注解等。

定时任务调度器:

基于xxl-jobs进行了功能增强。(如:指定时间发送任务、执行器和调度器合并项目、多数据源)

大文件/断点/分片续传:

前端采用webupload.js、后端采用NIO实现了大文件断点分片续传,启动Eureka、Zuul、File服务后,直接打开docs/chunkUploadDemo/demo.html即可进行测试。 经测试,本地限制堆栈最大内存128M启动File服务,5分钟内能成功上传4.6G+的大文件,正式服耗时则会受到用户带宽和服务器带宽的影响,时间比较长。

分布式事务:

集成了阿里的分布式事务中间件:seata,以 高效 并且对业务 0侵入 的方式,解决 微服务 场景下面临的分布式事务问题。

灰度发布:
    
为了解决频繁的服务更新上线,版本回退,快速迭代,公司内部协同开发,本项目采用修改ribbon的负载均衡策略来实现来灰度发布。     

关联数据自动注入:

用于解决跨表、跨库、跨服务分页数据的属性或单个对象的属性 回显关联数据之痛, 支持对静态数据属性(数据字典)、动态主键数据进行自动注入。

项目代码地址

项目 gitee github 备注
微服务项目 https://gitee.com/zuihou111/zuihou-admin-cloud https://github.com/zuihou/zuihou-admin-cloud SpringCloud 版本后端代码
单体项目 https://gitee.com/zuihou111/zuihou-admin-boot https://github.com/zuihou/zuihou-admin-boot SpringBoot 版本后端代码
租户后台 https://gitee.com/zuihou111/zuihou-ui https://github.com/zuihou/zuihou-ui | 给客户使用的前端
开发&运营后台 https://gitee.com/zuihou111/zuihou-admin-ui https://github.com/zuihou/zuihou-admin-ui 给公司内部开发&运营&运维等人员使用
代码生成器 https://gitee.com/zuihou111/zuihou-generator https://github.com/zuihou/zuihou-generator 开发人员使用
核心工具包 https://gitee.com/zuihou111/zuihou-commons https://github.com/zuihou/zuihou-commons 核心工具包

演示地址 (演示账号没有写权限,只能查询)

项目 演示地址 管理员账号 普通账号
租户后台 http://tangyh.top:10000/zuihou-ui zuihou/zuihou test/zuiou
开发&运营后台 http://tangyh.top:180/zuihou-admin-ui demoAdmin/zuihou

以上所述就是小编给大家介绍的《zuihou-admin-cloud 2.5.1 发布,支持配置外部数据源》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Designing Web Navigation

Designing Web Navigation

James Kalbach / O'Reilly Media / 2007-8-15 / USD 49.99

Thoroughly rewritten for today's web environment, this bestselling book offers a fresh look at a fundamental topic of web site development: navigation design. Amid all the changes to the Web in the pa......一起来看看 《Designing Web Navigation》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

MD5 加密
MD5 加密

MD5 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器