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

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

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

javafx 如何将项目打包为 Windows 的可执行文件exe

《javafx如何将项目打包为Windows的可执行文件exe》文章介绍了三种将JavaFX项目打包为.exe文件的方法:方法1使用jpackage(适用于JDK14及以上版本),方法2使用La... 目录方法 1:使用 jpackage(适用于 JDK 14 及更高版本)方法 2:使用 Launch4j(

Docker集成CI/CD的项目实践

《Docker集成CI/CD的项目实践》本文主要介绍了Docker集成CI/CD的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、引言1.1 什么是 CI/CD?1.2 docker 在 CI/CD 中的作用二、Docke

SpringBoot项目引入token设置方式

《SpringBoot项目引入token设置方式》本文详细介绍了JWT(JSONWebToken)的基本概念、结构、应用场景以及工作原理,通过动手实践,展示了如何在SpringBoot项目中实现JWT... 目录一. 先了解熟悉JWT(jsON Web Token)1. JSON Web Token是什么鬼

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p