百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

SpringBoot+Dubbo+Zookeeper+Redis+MQ分布式快速开发平台源码

off999 2025-03-20 17:39 48 浏览 0 评论

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”即可获取源码下载地址,车联网,物联网开发请私聊

相关推荐

使用 python-fire 快速构建 CLI_如何搭建python项目架构

命令行应用程序是开发人员最好的朋友。想快速完成某事?只需敲击几下键盘,您就已经拥有了想要的东西。Python是许多开发人员在需要快速组合某些东西时选择的第一语言。但是我们拼凑起来的东西在大多数时候并...

Python 闭包:从底层逻辑到实战避坑,附安全防护指南

一、闭包到底是什么?你可以把闭包理解成一个"带记忆的函数"。它诞生时会悄悄记下自己周围的变量,哪怕跑到别的地方执行,这些"记忆"也不会丢失。就像有人出门时总会带上...

使用Python实现九九乘法表的打印_用python打印一个九九乘法表

任务要求九九乘法表的结构如下:1×1=11×2=22×2=41×3=32×3=63×3=9...1×9=92×9=18...9×9=81使用Python编写程序,按照上述格式打印出完整的九...

吊打面试官(四)--Java语法基础运算符一文全掌握

简介本文介绍了Java运算符相关知识,包含运算规则,运算符使用经验,特殊运算符注意事项等,全文5400字。熟悉了这些内容,在运算符这块就可以吊打面试官了。Java运算符的规则与特性1.贪心规则(Ma...

Python三目运算基础与进阶_python三目运算符判断三个变量

#头条创作挑战赛#Python中你学会了三步运算,你将会省去很多无用的代码,我接下来由基础到进阶的方式讲解Python三目运算基础在Python中,三目运算符也称为条件表达式。它可以通过一行代码实现条...

Python 中 必须掌握的 20 个核心函数——set()详解

set()是Python中用于创建集合的核心函数,集合是一种无序、不重复元素的容器,非常适合用于成员检测、去重和数学集合运算。一、set()的基本用法1.1创建空集合#创建空集合empty_se...

15个让Python编码效率翻倍的实用技巧

在软件开发领域,代码质量往往比代码数量更重要。本文整理的15个Python编码技巧,源自开发者在真实项目中验证过的工作方法,能够帮助您用更简洁的代码实现更清晰的逻辑。这些技巧覆盖基础语法优化到高级特性...

《Python从小白到入门》自学课程目录汇总(和猫妹学Python)

小朋友们好,大朋友们好!不知不觉,这套猫妹自学Python基础课程已经结束了,猫妹体会到了水滴石穿的力量。水一直向下滴,时间长了能把石头滴穿。只要坚持不懈,细微之力也能做出很难办的事。就比如咱们的学习...

8÷2(2+2) 等于1还是16?国外网友为这道小学数学题吵疯了……

近日,国外网友因为一道小学数学题在推特上争得热火朝天。事情的起因是一个推特网友@pjmdoll发布了一条推文,让他的关注者解答一道数学题:Viralmathequationshavebeen...

Python学不会来打我(21)python表达式知识点汇总

在Python中,表达式是由变量、运算符、函数调用等组合而成的语句,用于产生值或执行特定操作。以下是对Python中常见表达式的详细讲解:1.1算术表达式涉及数学运算的表达式。例如:a=5b...

Python运算符:数学助手,轻松拿咧

Python中的运算符就像是生活中的数学助手,帮助我们快速准确地完成这些计算。比如购物时计算总价、做家务时分配任务等。这篇文章就来详细聊聊Python中的各种运算符,并通过实际代码示例帮助你更好地理解...

Python学不会来打我(17)逻辑运算符的使用方法与使用场景

在Python编程中,逻辑运算符(LogicalOperators)是用于组合多个条件表达式的关键工具。它们可以将多个布尔表达式连接起来,形成更复杂的判断逻辑,并返回一个布尔值(True或Fa...

Python编程基础:运算符的优先级_python中的运算符优先级问题

多个运算符同时出现在一个表达式中时,先执行哪个,后执行哪个,这就涉及运算符的优先级。如数学表达式,有+、-、×、÷、()等,优先级顺序是()、×、÷、+、-,如5+(5-3)×4÷2,先计算(5-3)...

Python运算符与表达式_python中运算符&的功能

一、运算符分类总览1.Python运算符全景图2.运算符优先级表表1.3.1Python运算符优先级(从高到低)优先级运算符描述结合性1**指数右→左2~+-位非/一元加减右→左3*//...

Python操作Excel:从基础到高级的深度实践

Python凭借其丰富的库生态系统,已成为自动化处理Excel数据的强大工具。本文将深入探讨五个关键领域,通过实际代码示例展示如何利用Python进行高效的Excel操作,涵盖数据处理、格式控制、可视...

取消回复欢迎 发表评论: