项目简单的破局之法-极具竞争力的企业级项目“大麦”

2024-08-26 20:36

本文主要是介绍项目简单的破局之法-极具竞争力的企业级项目“大麦”,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于项目的技术架构介绍,可参考此篇文章:"大麦"企业级高并发实战项目亮点介绍

目前项目重复度极低,意味着简历在筛选时脱颖而出的概率更高

项目技术栈特别的丰富,包括了Springboot、SpringCloud、Gateway、Nacos、Sentinel、Log4j2、Mysql、MyBatis-Plus、ShardingSphere、AJ-Captcha、Kafka、Redis、RedisStream、Redisson、Elasticsearch、Kibana、Nginx、Docker、JWT、Swagger-UI、Knife4j、Hibernator-Validator、XXL-Job

项目业务介绍

为了应对用户购买演唱会时的高并发问题,项目中包含了真实生产环境中很多实际的落地解决方案。利用缓存(分布式缓存、本地环境)、锁(不同类型、粒度优化)、mq(异步削峰)、分布分表(海量存储)、服务监控(监听服务的各种状态)、防刷(可动态配置某段时间的并发请求量)

项目业务亮点

  • 可以配置灵活的请求限制规则,提供细致的定制维度(包括:请求数的阈值、统计的时间窗口、限制生效时间)来实现防刷功能
  • 设计多个验证功能(图形验证码、分布式计数器、布隆过滤器)来解决高并发下的缓存穿透问题
  • 利用分片思想在缓存中保存节目的数据、票档、座位数据。极大的提高系统的并发能力
  • 利用Redis+lua解决高并发下的余票数量以及其他数据的扣减问题
  • 利用计算机二进制的特征,设计 基因法 来解决订单服务下的多个条件查询问题
  • 将框架中原有分布式延迟队列功能,通过利用分片存储多线程消费,实现成倍的性能提升!保证大量并发情况下订单的及时关闭问题
  • 使用Elasticsearch来实现演唱会的列表显示,并实现智能搜索
  • Feign、Nacos、Ribbon、LoadBalance微服务框架的额外高级定制扩展,不再只是局限于单纯的使用
  • 为了解决用户购票的高并发问题,对锁的类型、锁的读写场景、锁的检测、锁的分段,等多种维度进行优化
  • 利用自动装配原理设计出了Redis封装、RedisStream、布隆过滤器、服务处理化管理封装、分布式锁、幂等、Web配置、灰度服务切换、延迟队列等多个组件、分布式id、线程池增强等多个组件

项目地址

  • gitee: https://gitee.com/java-up-up/damai
  • github: https://github.com/shining-stars-lk/damai

项目结构图

在这里插入图片描述
在这里插入图片描述

这篇关于项目简单的破局之法-极具竞争力的企业级项目“大麦”的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109617

相关文章

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

Java中使用 @Builder 注解的简单示例

《Java中使用@Builder注解的简单示例》@Builder简化构建但存在复杂性,需配合其他注解,导致可变性、抽象类型处理难题,链式编程非最佳实践,适合长期对象,避免与@Data混用,改用@G... 目录一、案例二、不足之处大多数同学使用 @Builder 无非就是为了链式编程,然而 @Builder

在IntelliJ IDEA中高效运行与调试Spring Boot项目的实战步骤

《在IntelliJIDEA中高效运行与调试SpringBoot项目的实战步骤》本章详解SpringBoot项目导入IntelliJIDEA的流程,教授运行与调试技巧,包括断点设置与变量查看,奠定... 目录引言:为良驹配上好鞍一、为何选择IntelliJ IDEA?二、实战:导入并运行你的第一个项目步骤1

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项