面试时项目简单怎么办?大麦 教你如何来破局!

项目介绍

大家对于订票时尤其是热门明星的演唱会,第一感觉就是票不好抢,一瞬间票就没有了,而本项目不仅仅是将上述的购票功能实现,并且还要解决这种票不好抢,也就是常说的 高并发 问题

小伙伴通过此项目能够掌握分布式微服务项目的设计、以及 真实生产环境的高并发解决方案。而且项目中遵循了 高内聚 低耦合 设计原则以及使用大量的设计模式来进行架构设计

项目中包括了 微服务本地缓存/分布式缓存消息队列搜索引擎并发编程本地锁/分布式锁设计模式分库分表 等核心技术


查看官网:https://www.javaup.chat/pages/83cf22

项目特点

本项目主打的是真实性和独特性,都是根据真实架构和实际遇到的问题总结的

  • 针对实际生产遇到的问题进行深度定制化的改造是生产中真正用的东西。这些都是针对业务特点单独设计的,网上也没有现成完整的资料,也不是市面上的理论八股文宝典或者简单的后台管理项目

  • 对要毕业的大学生、刚参加工作不久的同学、或者工作多年想对技术有提升的小伙伴都有适合的干货

    • 入参和出参到底如何应该如何设计 加密,从而防止攻击

    • 亮点较多的业务 例如:Redis、Lua、多种数据结构结合

    • 并发编程的高级玩法 例如:线程池的定制化设计、ThreadLocal的深度设计

    • 缓存穿透、缓存击穿、缓存雪崩 在实际项目中的真正落地解决方案

    • 对使用中的 分布式锁、本地锁进行优化 的实际落地解决方案

    • 超高并发情况下,多级缓存、数据一致性 的设计方案

    • 光是生成订单功能就有4个版本 这是为了更好的讲解高并发下要如何去考虑,应该逐步优化哪些方面

    • 各种参数的精细化配置 例如:Sentinel、Hystrix、Ribbon的配置

  • 哪怕是常见的面试问题,也能从生产上遇到的故障来做进一步的分析和完善,比如常见的分布式锁,细节就很多。例如:在方法里还是方法外使用?直接Lock.lock就行了吗?事务存在的话需要去考虑吗?如果利用注解那么要考虑其他切面的关系吗?提供哪些策略呢?这些在 项目中都会得到解答

  • 又比如说 SpringBoot的自动装配原理,很多人都背过这个,但究竟用自动装配有什么好处呢?为什么不直接写个组件然后其他项目来依赖呢?两者的区别在哪里呢?在项目中依旧会有讲解

技术结构

  • 使用了 SpringCloud+SpringCloudAlibaba 的微服务结构

  • 使用了 Nacos 作为注册中心

  • 使用 Redis 不仅仅作为缓存,还使用了Lua脚本/延迟队列/Stream消息队列 等高级特性

  • 引入了 Kafka 消息中间件,SpringBootAdmin 作为服务的监控通知

  • ELK 作为日志的记录,ElasticSearch提供搜索和展示功能,

  • Sentinel/Hystrix 作为熔断保护层

  • 使用 ShardingSphere 实现分库分表,来存储海量的数据

通过以上设计,来实现应对高并发、高吞吐的能力,以及海量数据的存储和服务状态的监控

项目地址:https://gitee.com/java-up-up/damai

在线体验:https://www.damai-javaup.chat

业务结构

通过此业务结构图进一步详细的介绍项目中的服务配置、技术选型、核心业务、基础组件、中间件的使用、监控方式等各个方面,方便大家能够对大麦项目的整体架构和设计有一个清晰的认知

架构和组件设计

针对于分布式和微服务的项目来说,随着业务的发展,项目的数量上千个都是很正常的,但如何要把这些项目做好配置,做好架构设计,设计出组件库,都是要考虑的因素

既然组件库是要给其他服务提供使用,所以在设计时要考虑的细节非常的多,设计模式和高内聚低耦合的思想更加的重要,而且代码的健壮性和高效率的执行也是同样重要,而在大麦项目中,使用了SpringBoot的自动装配机制来设计组件库

除了组件库外,还有对异常的处理、数据的封装格式、多线程的使用等等也都要进行相应的封装设计,这些在项目中同样具备

业务流程

对于大麦项目来说,核心的业务就是用户选择节目然后进行购票功能了,项目中不仅完整了对整个业务流程的完整闭环,而且考虑到既然设计此项目是为了应对高并发的特点,那么在从业务的角度上也做了很多的优化设计

项目的亮点质量高吗

我也是一路过来的,所以很清楚大家的心态,希望是能和实际业务结合起来进行学习项目的架构设计技巧以及解决高并发的解决方案

项目中的各个亮点部分

项目的亮点可以分成多个部分,比如涉及到用户服务的业务时,项目在海量并发的场景下的问题:

  • 用户服务如何设计分库分表,存在用户邮箱、用户手机号多种方式登录,要怎么设计不会发生读扩散问题?

  • 当一瞬间有大量的用户注册请求时,如何防止 缓存穿透问题?网上说的那些方案到底靠谱吗?到底要怎么解决并且不影响用户体验?

  • 用户和购票人数据为了应对高并发的场景下,在缓存中要怎么设计?把所有数据都放进去吗?

  • 如何设计缓存策略?采取哪种结构来存储?采取哪种维度来存储?哪些数据适合放入缓存?哪些不适合?

在用户进行浏览的过程中,对于问题的存在同样也不少:

  • 如何应对高并发下的用户查询请求?在主页列表、类型列表、的请求查看下,如何将设计分库分表的数据查询方案?

  • 节目详情要怎么设计缓存?有了Redis就可以了吗?突发性流量激增的问题怎么解决?

  • 如何设计多级缓存来应对几十万,甚至几百万的访问压力?如何发生了缓存雪崩要解决解决和提前预防?

而在用户购票的流程中,为了解决高并发的压力,需要考虑的问题和细节就会更多:

  • 如何应对高并发下的用户购票压力?在购票流程中怎么考虑缓存和数据库的交互?

  • 库存数量在缓存中应该如何设计?用户购票和支付过程中,要怎么正确的扣除库存?异常了怎么回滚?数据库中的余票数量一致性要如何解决?

  • 分布式锁使用起来的细节到底有哪些?只要加上一行锁就可以了吗?

  • 高并发下的分布式锁如何进一步的优化?锁的粒度?网络请求的性能?

  • 幂等功能如何实现?有哪些维度需要考虑?

  • 经典的缓存数据库一致性的问题实际生产环境中到底如何解决?直接删除缓存、延迟双删 这些方案到底可行吗?

而在整个项目的架构设计上,也有很多的问题存在:

  • 高并发下订单延迟关闭功能如何实现?使用中间件作为延迟队列的问题?使用redis作为延迟队列可以吗?如何提高性能?

  • 分布式id如何生成?经典的雪花算法?直接使用MybatisPlus中的生成策略可以吗?有什么问题?

  • 订单的分库分表如何设计?既要支持订单详情查询、又要支持订单列表查询而不发生读扩散?

  • 如何执行灵活的限流规则?能支持到某个时间段、某个请求、并能记录下异常行为信息?

  • 项目的架构配置、服务配置、数据结构要如何统一设计和管理?异常如何捕获?

  • … … … …

这里只是将常见的问题列举了一下,而在本项目中解决的问题远不止上述列举这些,小伙伴可在学习时带着某个问题来思考,在项目中找到问题的答案

项目展示

为了尽可能的还原,本项目尽可能贴近官网的页面设计和业务流程,小伙伴可以通过前端项目一边来学习业务,一边体会业务中调取了哪些后端接口,这种学习方式是简单且高效的,也建议小伙伴在学习公司的业务时也使用这种方式

主页列表

分类列表

节目详情

生成订单

订单列表

订单详情

技术选型

技术说明官网
Spring-BootWeb服务框架https://spring.io/projects/spring-boot
Spring-Cloud微服务框架https://spring.io/projects/spring-cloud
Spring-Cloud-alibabaalibaba微服务框架https://github.com/alibaba/spring-cloud-alibaba
Spring-Cloud-Gateway微服务网关https://spring.io/projects/spring-cloud-gateway
Nacos服务注册中心https://nacos.io/zh-cn/index.html
Sentinel服务熔断https://sentinelguard.io/zh-cn/
Log4j2日志框架https://github.com/apache/logging-log4j2
Mysql数据库https://www.mysql.com/
MyBatis-PlusORM框架https://baomidou.com
MyBatisGenerator数据层代码生成器http://www.mybatis.org/generator/index.html
AJ-Captcha图形验证码https://gitee.com/anji-plus/captcha
Kafka消息队列https://github.com/apache/kafka/
Redis分布式缓存https://redis.io/
Redisson分布式Redis工具https://redisson.org
Elasticsearch搜索引擎https://github.com/elastic/elasticsearch
LogStash日志收集工具https://github.com/elastic/logstash
Kibana日志可视化查看工具https://github.com/elastic/kibana
Nginx静态资源服务器https://www.nginx.com/
Docker应用容器引擎https://www.docker.com
Jenkins自动化部署工具https://github.com/jenkinsci/jenkins
Hikari数据库连接池https://github.com/brettwooldridge/HikariCP
JWTJWT登录支持https://github.com/jwtk/jjwt
LombokJava语言增强插件https://github.com/rzwitserloot/lombok
HutoolJava工具类库https://github.com/looly/hutool
Swagger-UIAPI文档生成工具https://github.com/swagger-api/swagger-ui
Knife4jSwagger 增强框架https://doc.xiaominfo.com
Hibernator-Validator验证框架http://hibernate.org/validator
XXL-Job分布式定时任务框架http://www.xuxueli.com/xxl-job
ShardingSphere分库分表https://shardingsphere.apache.org

小伙伴的疑惑

学生人群

在大学还在学习中或者即将参加春招、秋招的学生,其实对项目的需求更高,可以这么说能不能决定你能正式工作的因素除了学历外就是项目了,既然学历已经成了定局,那么提高竞争力的就是 项目,如果能在简历和面试中已经有了比较出色的项目经验,那么对于面试官来说绝对是必杀技!

项目的文档和视频讲解的详细,分成了 项目的总体介绍如何启动项目基础介绍项目的架构设计详细业务讲解基础组件讲解设计到的技术讲解深挖细节亮点讲解,配合 详细的代码加注释以及解释流程和设计思路并且还结合了流程图 方便大家更好的理解。学生可根据自己目前学习的进度来跳转到对应的目录来学习

工作了几年的人群

对于这些人群,项目更是必要的,通过此项目讲解能学习到项目的架构设计、设计模式、高并发解决方案,来让自己的技术能力得到提高,并且让自己的简历和面试中通过此项目来增加个人亮点

提供的服务

文档数量120+,总字数26W+,并且还在不断更新中,带你全方位360度无死角彻彻底底掌握项目!

包括对 项目从0到1的讲解项目的细节和亮点总结遇到的面试真题详细的各种优化后的压测报告如何将项目有亮点的写到简历上

项目文档目录

  • 28
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值