分布式开发框架源码 -威尼斯人最新

weidifferent · 2020年03月09日 · 最后由 回复于 2022年08月03日 · 604 次阅读

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

前言

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

项目简介

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

主要功能

  • 数据库:druid 数据库连接池,监控数据库访问性能,统计 sql 的执行性能。
  • 持久层:mybatis 持久化,使用 mybatis-plus 优化,减少 sql 开发量;aop 切换数据库实现读写分离。transtraction 注解事务。
  • mvc: 基于 spring mvc 注解,rest 风格 controller。exception 统一管理。
  • 缓存和 session:注解 redis 缓存数据,spring-session 和 redis 实现分布式 session 同步,重启服务会话不丢失。
  • 数据同步:基于 redis 的分布式锁。
  • web 安全:实现 xss 过滤和 csr 过滤。
  • 多系统交互:dubbo,activemq 多系统交互。
  • 前后端分离:前端使用 ajax 访问后端的 rest 服务,后端返回 json 格式数据。页面用 nginx 反向代理访问。
  • 支付功能:实现微信和支付宝支付客户端。
  • 日志:logback 打印日志,默认打印 web 和 service 简要日志。
  • 工具类:字符串处理,类型转换,日期处理,io 和文件,excel 读写,加密解密,http 客户端,xml 处理,转码,各种 util 等等。
  • 代码生成器:根据数据库表结构生成简单的增删改查功能代码,包括 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
 jwtjsonwebtoken 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语句

核心技术图

基础架构图

本地部署

1、环境要求

  • jdk1.8
  • mysql5.5
  • maven3.3
  • zookeeper3.3
  • redis3.0
  • nginx1.8
  • apache activemq-5.0 (可选)

2、执行 sql 文件 jww/jww-ump/sqls/jww.sql,初始化库、表和数据;

3、修改 jww/jww-ump/jww-ump-rpc-service/src/main/resources/application-dev.yml,更新 mysql 帐号密码,redis 的 ip、端口和密码,zookeeper 的地址;

4、修改 jww/jww-ump/jww-ump-server/src/main/resources/application-dev.yml,更新 redis 的 ip、端口和密码,zookeeper 的地址;

5、修改 nginx/conf/nginx.conf,指定静态和动态页面地址(参考附件);

6、启动 mysql, zookeeper, redis, nginx;

7、intellij idea 菜单 file-settings-plugins,添加 lombok plugin 插件

8、intellij idea 中右键 >> run jww/jww-ump/jww-ump-rpc-service/src/main/java/com/jww/ump/rpc/service/serviceapplication.java;

9、intellij idea 中右键 >> run jww/jww-ump/jww-ump-server/src/main/java/com/jww/ump/server/serverapplication.java;

10、访问地址: 帐户密码:admin/123456

11、swagger 地址:

效果图:

澳门人威尼斯3966的版权声明

jww使用 apache license 2.0 协议.

项目地址:

https://gitee.com/wanhaha555/jww
暂无回复。
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册
网站地图