SpringBoot+Dubbo+Zookeeper+Redis+MQ分布式快速开发平台源码
csdh11 2025-05-02 09:54 12 浏览
if-framework是一个分布式快速开发平台,使用SpringBoot+Dubbo+Zookeeper+Redis+Mysql+MQ等框架,包含:管理员列表、角色管理、菜单管理、定时任务、参数管理、代码生成器、日志管理、OSS存储、消息推送、前后端分离、数据库读写分离等。提供分布式缓存、分布式锁、分布式Session、读写分离等统一组件及RBAC权限管理等模块。体验账号:test/123456
http://134.175.157.186/
总体架构说明:
yx-framework
............................................ yx信息架构
yx-common .......................................... 公共基础模板
yx-generator ....................................... 代码生成器
yx-job ....................................... 定时任务模块
yx-business .................................. 业务组装模块(用于处理具体业务逻辑,注:【该模块既是服务调用方也是服务提供方】)
yx-service ....................................... 微服务模块
yx-sys .............................................. 系统基础服务模块(服务提供方)
yx-sys-common ...................................... 枚举、常量
yx-sys-model ....................................... 实体类
yx-sys-dao ......................................... Mapper接口文件
yx-sys-rpc-api ..................................... 接口定义
yx-sys-rpc-service ................................. 具体实现
yx-user ........................................ ...客户模块(服务提供方)
yx-user-common .................................
yx-user-model ..................................
yx-user-dao ....................................
yx-user-rpc-api ................................
yx-user-rpc-service ............................
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>根据实际业务需要,模块会不断增加<<<<<<<<<<<<<<<<<<<<<<<<<<<
yx-server .......................................服务调用模块
yx-admin-server .................................... 系统管理系统(服务调用方)
yx-web-server ...................................... web网站(服务调用方)
yx-wx-server ....................................... 微信(服务调用方)
yx-mobile-server ................................... APP(服务调用方)
yx-api-server ...................................... 第三方API(服务调用方)
yx-ui ................................................系统静态页面
yx-ui-admin..........................................后台管理系统页面
项目开发依赖的环境
1、安装maven,lombok(开发工具的不同,安装方式不同)
项目运行依赖的环境:
1、安装mysql,zookeeper,redis,nginx并启动相关服务
2、先启动服务的提供方,运行每个模块下rpc-service中的serviceApplication的main方法,即可启动相关服务
3、启动服务调用方,运行每个-server工程下的serverApplication的main方法,即可启动相关服务
## 核心技术图
## 基础架构图
## 项目简介
- yx-framework是Java语言的分布式系统架构。 使用SpringBoot整合开源框架。
- 作者根据自己的工作经历将架子抽离出来,方便二次开发,大家可以根据自己的业务去扩展架构;
- 公共功能:公共功能(基类、数据访问组件、读写分离、分布式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
## 本地部署
1. 环境要求
* JDK1.8+
* MySQL5.5+
* Maven3.3+
* Zookeeper3.3+
* Redis3.0+
* Nginx1.8+
* Apache Activemq-5.0+ (可选)
2. 执行SQL文件doc/sqls/yxdb.sql,初始化库、表和数据;
3. 修改每个工程/src/main/resources/application-dev.yml,更新MySQL帐号密码,Redis的IP、端口和密码,Zookeeper的地址;
5. 修改Nginx/conf/nginx.conf,指定静态和动态页面地址(参考附件);
6. 启动MySQL, Zookeeper, Redis, Nginx;
7. IntelliJ IDEA 菜单File-Settings-Plugins,添加lombok plugin插件
8. 访问地址:http://localhost 帐户密码:admin/123456
9. swagger地址:http://localhost:8089/swagger-ui.html
10. 文件上传、邮件推送,邮件发送,短信发送等工具类可能不可用,需要将自己申请的accessKeyId,accessKeySecret配置到参数表中(sys_param)方可正常使用
## 项目演示
● 演示地址: http://134.175.157.186/
● 账号、密码:test/123456
## 预览图
先转发,转发,转发,然后关注“大数据java架构师”,私信“fbs”即可获取源码下载地址,车联网,物联网开发请私聊
相关推荐
- SpringBoot+LayUI后台管理系统开发脚手架
-
源码获取方式:关注,转发之后私信回复【源码】即可免费获取到!项目简介本项目本着避免重复造轮子的原则,建立一套快速开发JavaWEB项目(springboot-mini),能满足大部分后台管理系统基础开...
- Spring Boot+Vue全栈开发实战,中文版高清PDF资源
-
SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...
- 2021年超详细的java学习路线总结—纯干货分享
-
本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础...
- 探秘Spring Cache:让Java应用飞起来的秘密武器
-
探秘SpringCache:让Java应用飞起来的秘密武器在当今快节奏的软件开发环境中,性能优化显得尤为重要。SpringCache作为Spring框架的一部分,为我们提供了强大的缓存管理能力,让...
- 3,从零开始搭建SSHM开发框架(集成Spring MVC)
-
目录本专题博客已共享在(这个可能会更新的稍微一些)https://code.csdn.net/yangwei19680827/maven_sshm_blog...
- Spring Boot中如何使用缓存?超简单
-
SpringBoot中的缓存可以减少从数据库重复获取数据或执行昂贵计算的需要,从而显著提高应用程序的性能。SpringBoot提供了与各种缓存提供程序的集成,您可以在应用程序中轻松配置和使用缓...
- 我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊
-
接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...
- 1,从零开始搭建SSHM开发框架(环境准备)
-
目录本专题博客已共享在https://code.csdn.net/yangwei19680827/maven_sshm_blog1,从零开始搭建SSHM开发框架(环境准备)...
- 做一个适合二次开发的低代码平台,把程序员从curd中解脱出来-1
-
干程序员也有好长时间了,大多数时间都是在做curd。现在想做一个通用的curd平台直接将我们解放出来;把核心放在业务处理中。用过代码生成器,在数据表设计好之后使用它就可以生成需要的controller...
- 设计一个高性能Java Web框架(java做网站的框架)
-
设计一个高性能JavaWeb框架在当今互联网高速发展的时代,构建高性能的JavaWeb框架对于提升用户体验至关重要。本文将从多个角度探讨如何设计这样一个框架,让我们一起进入这段充满挑战和乐趣的旅程...
- 【推荐】强&牛!一款开源免费的功能强大的代码生成器系统!
-
今天,给大家推荐一个代码生成器系统项目,这个项目目前收获了5.3KStar,个人觉得不错,值得拿出来和大家分享下。这是我目前见过最好的代码生成器系统项目。功能完整,代码结构清晰。...
- Java面试题及答案总结(2025版持续更新)
-
大家好,我是Java面试分享最近很多小伙伴在忙着找工作,给大家整理了一份非常全面的Java面试场景题及答案。...
- Java开发网站架构演变过程-从单体应用到微服务架构详解
-
Java开发网站架构演变过程,到目前为止,大致分为5个阶段,分别为单体架构、集群架构、分布式架构、SOA架构和微服务架构。下面玄武老师来给大家详细介绍下这5种架构模式的发展背景、各自优缺点以及涉及到的...
- 本地缓存GuavaCache(一)(guava本地缓存原理)
-
在并发量、吞吐量越来越大的情况下往往是离不开缓存的,使用缓存能减轻数据库的压力,临时存储数据。根据不同的场景选择不同的缓存,分布式缓存有Redis,Memcached、Tair、EVCache、Aer...
- 一周热门
- 最近发表
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)
- dos 删除目录下所有子目录及文件 (36)