基于Spring+SpringMVC+Mybatis的分布式敏捷开发系统架构
| └── 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开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
最后
针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。
上述的面试题答案都整理成文档笔记。 也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
…(img-RGAmCikn-1711831835836)]
最后
针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。
[外链图片转存中…(img-SR0Q8YB7-1711831835837)]
上述的面试题答案都整理成文档笔记。 也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)
[外链图片转存中…(img-MFZuCG5M-1711831835837)]
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。