您当前的位置:首页 > 电脑百科 > 网络技术 > 网络知识

基于springboot+dubbo分布式架构RBAC权限管理源码免费分享

时间:2020-03-16 13:24:24  来源:  作者:

基于springboot+dubbo分布式架构,提供分布式缓存、分布式锁、分布式Session、读写分离等统一组件及RBAC权限管理等模块。

前言

以分布式基础架构为依托,包含但不仅限于分布式架构、基础框架、前端模板、代码生成、系统监测等功能,致力于为企业在蓬勃发展的业务及快速迭代开发领域提供全方位J2EE企业级技术规范及开发解决方案。

项目简介

  • JAVA语言的分布式系统架构。 使用SpringBoot整合开源框架。
  • 系统包括5个子模块:公共功能、平台管理、项目页面、统一管理平台、项目说明。
  • 公共功能:公共功能(基类、数据访问组件、读写分离、分布式session、HTTP客户端、日志服务、队列服务、支付服务组件、redis缓存、Web安全等等)、公共配置、工具类。
  • 系统管理:包括用户管理、部门管理、菜单管理、角色管理、字典管理、参数管理、日志管理、应用监控等等。
  • 业务相关:微信/支付宝支付。
  • 系统通信:支持扩展子系统,子系统之间使用Dubbo或MQ进行通信。
  • 演示平台使用Maven对项目进行模块化管理,提高项目的易开发性、扩展性。

主要功能

  1. 数据库:Druid数据库连接池,监控数据库访问性能,统计SQL的执行性能。
  2. 持久层:mybatis持久化,使用MyBatis-Plus优化,减少sql开发量;aop切换数据库实现读写分离。Transtraction注解事务。
  3. MVC: 基于spring mvc注解,Rest风格Controller。Exception统一管理。
  4. 缓存和Session:注解redis缓存数据,Spring-session和redis实现分布式session同步,重启服务会话不丢失。
  5. 数据同步:基于redis的分布式锁。
  6. Web安全:实现XSS过滤和CSR过滤。
  7. 多系统交互:Dubbo,ActiveMQ多系统交互。
  8. 前后端分离:前端使用ajax访问后端的rest服务,后端返回json格式数据。页面用Nginx反向代理访问。
  9. 支付功能:实现微信和支付宝支付客户端。
  10. 日志:Logback打印日志,默认打印Web和Service简要日志。
  11. 工具类:字符串处理,类型转换,日期处理,IO和文件,Excel读写,加密解密,HTTP客户端,XML处理,转码,各种Util等等。
  12. 代码生成器:根据数据库表结构生成简单的增删改查功能代码,包括model、mApper、service、controller。

技术选型

● 核心框架:Spring Boot 1.5.12.RELEASE + Dubbo 2.5.7
● 分布式协调服务:ZooKeeper 3.4.11
● 校验框架:Hibernate Validator 5.3.5.Final
● 安全框架:Apache Shiro 1.4.0
● 代码生成:MyBatis Plus Generator 2.1.6
● 持久层框架:MyBatis 3.4.5 + MyBatis-Plus 2.1.6
● 数据库连接池:Alibaba Druid 1.1.9
● 缓存框架:Redis.clients:jedis 2.8.2
● 队列框架:Apache ActiveMQ 5.14.5
● 会话管理:Spring-Session 1.3.1
● 日志管理:SLF4J 
● 前端框架:Layui 2.2.45
● 公用工具集:Hutool 3.2.3
● 支付组件:Egan pay-java-parent 2.0.7
● 代码简化:Lombok 1.16.20
● 序列化框架:Alibaba Fastjson 1.2.41
● HTTP客户端:Hutool-http 4.0.10
● 接口测试框架:Swagger2
● 字体图标:Alibaba Iconfont
● JWT:jsonwebtoken 0.9.0

项目结构

jww
├─jww-common 公共模块
│  ├─jww-common-core 核心组件
│  ├─jww-common-db 数据访问组件
│  ├─jww-common-mdb 多数据源组件
│  ├─jww-common-dsession 分布式session
│  ├─jww-common-http HTTP客户端
│  ├─jww-common-jwt JWT组件
│  ├─jww-common-log 日志服务
│  ├─jww-common-mq 队列服务
│  ├─jww-common-oss 对象储存组件
│  ├─jww-common-pay 支付宝/微信支付组件
│  ├─jww-common-redis 缓存服务
│  ├─jww-common-ship 快递服务组件
│  └─jww-common-web WEB组件
│ 
├─jww-ui 页面模块
│  └─jww-ui-ump 统一管理平台页面
│ 
├─jww-ump 统一管理平台项目
│  ├─jww-ump-common 项目公共组件
│  ├─jww-ump-dao 项目数据访问模块
│  ├─jww-ump-generator 项目代码生成器
│  ├─jww-ump-model 项目MODEL模块
│  ├─jww-ump-mq 项目队列模块
│  ├─jww-ump-rpc-api 项目接口模块
│  ├─jww-ump-rpc-service 项目后台模块
│  ├─jww-ump-server 项目前台控制模块
│  └─sqls 项目SQL语句

核心技术图

基于springboot+dubbo分布式架构RBAC权限管理源码免费分享

 

基础架构图

基于springboot+dubbo分布式架构RBAC权限管理源码免费分享

 

本地部署

  1. 环境要求
  • JDK1.8+
  • MySQL5.5+
  • Maven3.3+
  • Zookeeper3.3+
  • Redis3.0+
  • Nginx1.8+
  • Apache Activemq-5.0+ (可选)
  1. 执行SQL文件jww/jww-ump/sqls/jww.sql,初始化库、表和数据;
  2. 修改jww/jww-ump/jww-ump-rpc-service/src/main/resources/application-dev.yml,更新MySQL帐号密码,Redis的IP、端口和密码,Zookeeper的地址;
  3. 修改jww/jww-ump/jww-ump-server/src/main/resources/application-dev.yml,更新Redis的IP、端口和密码,Zookeeper的地址;
  4. 修改Nginx/conf/nginx.conf,指定静态和动态页面地址(参考附件);
  5. 启动MySQL, Zookeeper, Redis, Nginx;
  6. IntelliJ IDEA 菜单File-Settings-Plugins,添加lombok plugin插件
  7. IntelliJ IDEA中右键 >> Run jww/jww-ump/jww-ump-rpc-service/src/main/java/com/jww/ump/rpc/service/ServiceApplication.java;
  8. IntelliJ IDEA中右键 >> Run jww/jww-ump/jww-ump-server/src/main/java/com/jww/ump/server/ServerApplication.java;
  9. 访问地址:http://localhost 帐户密码:admin/123456
  10. swagger地址:http://localhost:8089/swagger-ui.html

预览图

基于springboot+dubbo分布式架构RBAC权限管理源码免费分享

 


基于springboot+dubbo分布式架构RBAC权限管理源码免费分享

 


基于springboot+dubbo分布式架构RBAC权限管理源码免费分享

 


基于springboot+dubbo分布式架构RBAC权限管理源码免费分享

 


基于springboot+dubbo分布式架构RBAC权限管理源码免费分享


Tags:springboot+dubbo   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
基于springboot+dubbo分布式架构,提供分布式缓存、分布式锁、分布式Session、读写分离等统一组件及RBAC权限管理等模块。前言以分布式基础架构为依托,包含但不仅限于分布式架...【详细内容】
2020-03-16  Tags: springboot+dubbo  点击:(153)  评论:(0)  加入收藏
一、Dubbo介绍引用官方的一段介绍Apache Dubbo (incubating) |ˈdʌbəʊ| is a high-performance, java based RPC framework open-sourced by Alibaba. As in many RPC sy...【详细内容】
2019-08-22  Tags: springboot+dubbo  点击:(228)  评论:(0)  加入收藏
▌简易百科推荐
以京训钉开发平台接口文档为例,使用HttpClient类请求调用其接口,对数据进行增删改查等操作。 文档地址: https://www.yuque.com/bjjnts/jxd/bo1oszusing System;using System.C...【详细内容】
2021-12-28  Wednes    Tags:HttpClient   点击:(1)  评论:(0)  加入收藏
阿里云与爱快路由安装组网教程一、开通好阿里云轻量服务器之后在服务器运维-远程连接处进行远程 二、进入控制台后在root权限下根据需要安装的固件位数复制下面命令。32位:wg...【详细内容】
2021-12-28  ikuai    Tags:组网   点击:(1)  评论:(0)  加入收藏
HTTP 报文是在应用程序之间发送的数据块,这些数据块将通过以文本形式的元信息开头,用于 HTTP 协议交互。请求端(客户端)的 HTTP 报文叫做请求报文,响应端(服务器端)的叫做响应...【详细内容】
2021-12-27  程序员蛋蛋    Tags:HTTP 报文   点击:(5)  评论:(0)  加入收藏
一 网络概念:1.带宽: 标识网卡的最大传输速率,单位为 b/s,比如 1Gbps,10Gbps,相当于马路多宽2.吞吐量: 单位时间内传输数据量大小单位为 b/s 或 B/s ,吞吐量/带宽,就是网络的使用率...【详细内容】
2021-12-27  码农世界    Tags:网络   点击:(3)  评论:(0)  加入收藏
1.TCP/IP 网络模型有几层?分别有什么用? TCP/IP网络模型总共有五层 1.应用层:我们能接触到的就是应用层了,手机,电脑这些这些设备都属于应用层。 2.传输层:就是为应用层提供网络...【详细内容】
2021-12-22  憨猪哥08    Tags:TCP/IP   点击:(35)  评论:(0)  加入收藏
TCP握手的时候维护的队列 半连接队列(SYN队列) 全连接队列(accepted队列)半连接队列是什么?服务器收到客户端SYN数据包后,Linux内核会把该连接存储到半连接队列中,并响应SYN+ACK报...【详细内容】
2021-12-21  DifferentJava    Tags:TCP   点击:(10)  评论:(0)  加入收藏
你好,这里是科技前哨。 随着“元宇宙”概念的爆火,下一代互联网即将到来,也成了互联网前沿热议的话题,12月9日美国众议院的听证会上,共和党议员Patrick McHenry甚至宣称,要调整现...【详细内容】
2021-12-17  王煜全    Tags:Web3   点击:(14)  评论:(0)  加入收藏
一、demopublic static void main(String[] args) throws Exception { RetryPolicy retryPolicy = new ExponentialBackoffRetry( 1000, 3);...【详细内容】
2021-12-15  程序员阿龙    Tags:Curator   点击:(22)  评论:(0)  加入收藏
一、计算机网络概述 1.1 计算机网络的分类按照网络的作用范围:广域网(WAN)、城域网(MAN)、局域网(LAN);按照网络使用者:公用网络、专用网络。1.2 计算机网络的层次结构 TCP/IP四层模...【详细内容】
2021-12-14  一口Linux    Tags:网络知识   点击:(31)  评论:(0)  加入收藏
无论是在外面还是在家里,许多人都习惯了用手机连接 WiFi 进行上网。不知道大家有没有遇到过这样一种情况, 明明已经显示成功连接 WiFi,却仍然提示“网络不可用”或“不可上网”...【详细内容】
2021-12-14  UGREEN绿联    Tags:WiFi   点击:(25)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条