基于Spring+SpringMVC+Mybatis的分布式敏捷开发系统架构

发布于:2024-06-26 ⋅ 阅读:(16) ⋅ 点赞:(0)

| └── zheng-pay-web – 演示示例[端口:3332]

├── zheng-ucenter – 用户系统(包括第三方登录)

| ├── zheng-ucenter-common – ucenter系统公共模块

| ├── zheng-ucenter-dao – 代码生成模块,无需开发

| ├── zheng-ucenter-rpc-api – rpc接口包

| ├── zheng-ucenter-rpc-service – rpc服务提供者

| └── zheng-ucenter-web – 网站前台[端口:4441]

├── zheng-wechat – 微信系统

| ├── zheng-wechat-mp – 微信公众号管理系统

| | ├── zheng-wechat-mp-dao – 代码生成模块,无需开发

| | ├── zheng-wechat-mp-service – 业务逻辑

| | └── zheng-wechat-mp-admin – 后台管理[端口:5551]

| └── zheng-ucenter-app – 微信小程序后台

├── zheng-api – API接口总线系统

| ├── zheng-api-common – api系统公共模块

| ├── zheng-api-rpc-api – rpc接口包

| ├── zheng-api-rpc-service – rpc服务提供者

| └── zheng-api-server – api系统服务端[端口:6666]

├── zheng-oss – 对象存储系统

| ├── zheng-oss-sdk – 开发工具包

| ├── zheng-oss-web – 前台接口[端口:7771]

| └── zheng-oss-admin – 后台管理[端口:7772]

├── zheng-message – 实时通知系统

| ├── zheng-message-sdk – 开发工具包

| ├── zheng-message-server – 服务端[端口:8881,SocketIO端口:8882]

| └── zheng-message-client – 客户端

├── zheng-shop – 电子商务系统

└── zheng-demo – 示例模块(包含一些示例代码等)

├── zheng-demo-rpc-api – rpc接口包

├── zheng-demo-rpc-service – rpc服务提供者

└── zheng-demo-web – 演示示例[端口:9999]

技术选型

| 技术 | 名称 | 官网 |

| — | — | — |

| Spring Framework | 容器 | http://projects.spring.io/spring-framework/ |

| SpringMVC | MVC框架 | http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#mvc |

| Apache Shiro | 安全框架 | http://shiro.apache.org/ |

| Spring session | 分布式Session管理 | http://projects.spring.io/spring-session/ |

| MyBatis | ORM框架 | http://www.mybatis.org/mybatis-3/zh/index.html |

| MyBatis Generator | 代码生成 | http://www.mybatis.org/generator/index.html |

| PageHelper | MyBatis物理分页插件 | http://git.oschina.net/free/Mybatis_PageHelper |

| Druid | 数据库连接池 | https://github.com/alibaba/druid |

| FluentValidator | 校验框架 | https://github.com/neoremind/fluent-validator |

| Thymeleaf | 模板引擎 | http://www.thymeleaf.org/ |

| Velocity | 模板引擎 | http://velocity.apache.org/ |

| ZooKeeper | 分布式协调服务 | http://zookeeper.apache.org/ |

| Dubbo | 分布式服务框架 | http://dubbo.io/ |

| TBSchedule & elastic-job | 分布式调度框架 | https://github.com/dangdangdotcom/elastic-job |

| Redis | 分布式缓存数据库 | https://redis.io/ |

| Solr & Elasticsearch | 分布式全文搜索引擎 | http://lucene.apache.org/solr/ https://www.elastic.co/ |

| Quartz | 作业调度框架 | http://www.quartz-scheduler.org/ |

| Ehcache | 进程内缓存框架 | http://www.ehcache.org/ |

| ActiveMQ | 消息队列 | http://activemq.apache.org/ |

| JStorm | 实时流式计算框架 | http://jstorm.io/ |

| FastDFS | 分布式文件系统 | https://github.com/happyfish100/fastdfs |

| Log4J | 日志组件 | http://logging.apache.org/log4j/1.2/ |

| Swagger2 | 接口测试框架 | http://swagger.io/ |

| sequence | 分布式高效ID生产 | http://git.oschina.net/yu120/sequence |

| AliOSS & Qiniu & QcloudCOS | 云存储 | https://www.aliyun.com/product/oss/ http://www.qiniu.com/ https://www.qcloud.com/product/cos |

| Protobuf & json | 数据序列化 | https://github.com/google/protobuf |

| Jenkins | 持续集成工具 | https://jenkins.io/index.html |

| Maven | 项目构建管理 | http://maven.apache.org/ |

| Netty-socketio | 实时推送 | https://github.com/mrniko/netty-socketio |

前端技术:

| 技术 | 名称 | 官网 |

| — | — | — |

| jQuery | 函式库 | http://jquery.com/ |

| Bootstrap | 前端框架 | http://getbootstrap.com/ |

| Bootstrap-table | Bootstrap数据表格 | http://bootstrap-table.wenzhixin.net.cn/ |

| Font-awesome | 字体图标 | http://fontawesome.io/ |

| material-design-iconic-font | 字体图标 | https://github.com/zavoloklom/material-design-iconic-font |

| Waves | 点击效果插件 | https://github.com/fians/Waves |

| zTree | 树插件 | http://www.treejs.cn/v3/ |

| Select2 | 选择框插件 | https://github.com/select2/select2 |

| jquery-confirm | 弹出窗口插件 | https://github.com/craftpip/jquery-confirm |

| jQuery EasyUI | 基于jQuery的UI插件集合体 | http://www.jeasyui.com |

| React | 界面构建框架 | https://github.com/facebook/react |

| Editor.md | Markdown编辑器 | https://github.com/pandao/editor.md |

| zhengAdmin | 后台管理系统模板 | https://github.com/shuzheng/zhengAdmin |

| autoMail | 邮箱地址自动补全插件 | https://github.com/shuzheng/autoMail |

| zheng.jprogress.js | 加载进度条插件 | https://github.com/shuzheng/zheng.jprogress.js |

| zheng.jtotop.js | 返回顶部插件 | https://github.com/shuzheng/zheng.jtotop.js |

| socket.io.js | SocketIO插件 | https://socket.io/ |

架构图

模块依赖

模块介绍

zheng-common

Spring+SpringMVC+Mybatis框架集成公共模块,包括公共配置、MybatisGenerator扩展插件、通用BaseService、工具类等。

zheng-admin

基于bootstrap实现的响应式Material Design风格的通用后台管理系统,zheng项目所有后台系统都是使用该模块界面作为前端展示。

zheng-ui

各个子系统前台thymeleaf模板,前端资源模块,使用nginx代理,实现动静分离。

zheng-upms

本系统是基于RBAC授权和基于用户授权的细粒度权限控制通用平台,并提供单点登录、会话管理和日志管理。接入的系统可自由定义组织、角色、权限、资源等。用户权限=所拥有角色权限合集+用户加权限-用户减权限,优先级:用户减权限>用户加权限>角色权限

zheng-oss

文件存储系统,提供四种方案:

  • 阿里云 OSS

  • 腾讯云 COS

  • 七牛云

  • 本地分布式存储

zheng-api

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

最后

针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。

image

上述的面试题答案都整理成文档笔记。 也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)

image

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
…(img-RGAmCikn-1711831835836)]

最后

针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。

[外链图片转存中…(img-SR0Q8YB7-1711831835837)]

上述的面试题答案都整理成文档笔记。 也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)

[外链图片转存中…(img-MFZuCG5M-1711831835837)]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。