Java 后端学习路线(2026 最新版)
这是 Java 学习路线的 2026 最新版,每年都会根据当下 Java 后端求职和招聘的最新要求进行全面的优化和改进。
这篇文章可能是你所见过的最用心、最全面的 Java 后端学习路线,共 4w+ 字。不过,也不用担心内容太多学不完,我会按照学习难度给出找一份小厂工作必学的内容以及适合循序渐进提高 Java 后端开发能力的学习路线。
对于初学者,你可以按照这篇文章推荐的学习路线和资料进行系统性的学习;对于有经验的开发者,你可以根据这篇文章更一步地深入学习 Java 后端开发,提升个人竞争力。
为了保证内容不至于太杂,这篇文章不会展开讲学习方法和成长建议,这部分可以看 JavaGuide「程序人生」里的几篇文章:
这篇文章也不会涉及到计算机基础的内容,关于计算机基础知识的学习可以参考我的网站上的分享:计算机基础书籍推荐。
多说一句:对于编程初学者,我不太建议上来通过做项目学习。实践确实很重要,如果你没有编程基础的话,直接上手实战,很容易最后学个四不像。建议你在学习编程的初期尽量多看一些优质视频。跟着视频一步一步走,可以让你少踩很多坑,学习编程的信心也会增加。
Java 后端学习路线概览
我画了一张图,先简单带大家看看 Java 后端学习路线的全貌以及我所推荐的学习顺序。
下图中涉及到的每一个知识点都会在下文中详细介绍(附带学习资源推荐)。

上面这张图片的原图+PDF 版本,可以在公众号「JavaGuide」后台回复“学习路线”获取。

内容比较多?劝退? 如果你只想找到一份小厂的开发工作的话,建议你把重心放在 Java 基础、数据库、常用框架、常用工具上。
像 JVM、分布式、高并发、高可用、微服务这些知识点,如果你想进大厂或者说让自己在求职的时候更有竞争力,那你就也是要多花一点时间来学习的。
现在面试很卷,想要找到一个好工作的话,就需要你去多学一点,多练习一点。虽然,你目前学的很多知识,在你工作之后可能用不到,但是,面试的筛选就需要你会这些。毕竟,很多岗位是很多人一起竞争,为了达到筛选效果,面试难度通常都会比较大的。这也就是所谓的:“面试造火箭,入职拧螺丝”。
已经淘汰的 Java 技术
已经淘汰的 Java 技术,不要再学了!这篇文章提到了在 Java 开发领域中已经被淘汰的技术,一定一定一定不要再学了!谁推荐你学下面这些技术,直接甩他两耳光子。
JSP
- 原因:JSP 已经过时,无法满足现代 Web 开发需求;前后端分离成为主流。
- 替代方案:模板引擎(如 Thymeleaf、Freemarker)在传统全栈开发中更流行;而在前后端分离架构中,React、Vue、Angular 等现代前端框架已取代 JSP 的角色。
- 注意:一些国企和央企的老项目可能仍然在使用 JSP,但这种情况越来越少见。
Struts(尤其是 1.x)
- 原因:配置繁琐、开发效率低,且存在严重的安全漏洞(如世界著名的 Apache Struts 2 漏洞)。此外,社区维护不足,生态逐渐萎缩。
- 替代方案:Spring MVC 和 Spring WebFlux 提供了更简洁的开发体验、更强大的功能以及完善的社区支持,完全取代了 Struts。
EJB (Enterprise JavaBeans)
- 原因:EJB 过于复杂,开发成本高,学习曲线陡峭,在实际项目中逐步被更轻量化的框架取代。
- 替代方案:Spring/Spring Boot 提供了更加简洁且功能强大的企业级开发解决方案,几乎已经成为 Java 企业开发的事实标准。此外,国产的 Solon 和云原生友好的 Quarkus 等框架也非常不错。
Java Applets
- 原因:现代浏览器(如 Chrome、Firefox、Edge)早已全面移除对 Java Applets 的支持,同时 Applets 存在严重的安全性问题。
- 替代方案:HTML5、WebAssembly 以及现代 JavaScript 框架(如 React、Vue)可以实现更加安全、高效的交互体验,无需插件支持。
SOAP / JAX-WS
- 原因:SOAP 和 JAX-WS 过于复杂,数据格式冗长(XML),对开发效率和性能不友好。
- 替代方案:RESTful API 和 RPC 更轻量、高效,是现代微服务架构的首选。
RMI(Remote Method Invocation)
- 原因:RMI 是一种早期的 Java 远程调用技术,但兼容性差、配置繁琐,且性能较差。
- 替代方案:RESTful API 和 PRC 提供了更简单、高效的远程调用解决方案,完全取代了 RMI。
Swing / JavaFX
- 原因:桌面应用在开发领域的份额大幅减少,Web 和移动端成为主流。Swing 和 JavaFX 的生态不如现代跨平台框架丰富。
- 替代方案:跨平台桌面开发框架(如 Flutter Desktop、Electron)更具现代化体验。
- 注意:一些国企和央企的老项目可能仍然在使用 Swing / JavaFX,但这种情况越来越少见。
Ant
- 原因:Ant 是一种基于 XML 配置的构建工具,缺乏易用性,配置繁琐。
- 替代方案:Maven 和 Gradle 提供了更高效的项目依赖管理和构建功能,成为现代构建工具的首选。
面试题自测
纸上学来终觉浅,躬行此事要知难。为了帮助你更好地将知识内化,我特别准备了一份与该学习路线完全匹配的高频面试题集:Java 后端学习路线配套高频面试题集(JavaGuide 知识星球专属)。
这份资源可以帮你:
- 自我检测: 系统性地检验自己对各个知识点的掌握情况。
- 查漏补缺: 及时发现自己的薄弱环节,进行针对性巩固。
- 模拟面试: 提前熟悉面试节奏和高频考点。
强烈推荐大家通过自测的方式,把学习推向更深的层次。
Java 核心
Java 基础
如果你之前没有学习过编程的话,我建议你可以看看视频教程。像尚硅谷的 《Java 基础教程系列》和韩顺平老师的《零基础 30 天学会 Java》就很不错。

👉我整理了尚硅谷最新的 Java 后端学习系列完整的视频教程&资料,喜欢看视频的朋友可以点此链接下载: 【最新整理】尚硅谷 Java 后端全套教程 & 实战项目(推荐)。

看视频的同时,配套一本好书也是非常有作用的。
优秀的 Java 基础书籍非常多,我这里只推荐 3 本。
1、《Head First Java》

《Head First Java》这本书的内容很轻松有趣,可以说是我学习编程初期最喜欢的几本书之一了。同时,这本书也是我的 Java 启蒙书籍。我在学习 Java 的初期多亏了这本书的帮助,自己才算是跨进 Java 语言的大门。我在 Java 这块能够坚持下来,这本书有很大的功劳。我身边的的很多朋友学习 Java 初期都是看的这本书。
有很多小伙伴就会问了:这本书适不适合编程新手阅读呢?
我个人觉得这本书还是挺适合编程新手阅读的,毕竟是 “Head First” 系列。
2、《Java 核心技术卷 1+卷 2》

《Java 核心技术卷 1+卷 2》这两本书的内容很多,全看的话比较费时间,比较适合当工作书。我当时在大学的时候就买了两本放在寝室,没事的时候就翻翻。个人建议有点 Java 基础之后再读这两本,介绍的还是比较深入和全面的。
3、《Java 编程的逻辑》
《Java 编程的逻辑》是一本非常低调的好书,相比于入门书来说,内容更有深度。适合初学者,同时也适合大家拿来复习 Java 基础知识。这篇文章中有这本书的阅读建议:八股文骚套路之 Java 基础 。

学完 Java 基础之后,你可以用自己学的东西实现一个简单的 Java 程序,也可以尝试用 Java 解决一些编程问题,以此来将自己学到的东西付诸于实践。
不太建议学习 Java 基础的之后通过做游戏来巩固。为什么培训班喜欢通过这种方式呢?说白点就是为了找到你的 G 点。新手学习完 Java 基础后做游戏一般是不太现实的,还不如找一些简单的程序问题解决一下比如简单的算法题。
记得多总结!打好基础!把自己重要的东西都记录下来。 API 文档放在自己可以看到的地方,以备自己可以随时查阅。为了能让自己写出更优秀的代码,《Effective Java》、《重构》 这两本书没事也可以看。
学完这部分内容之后,务必确保自己掌握下面知识点:
- 基本语法、基本数据类型
- 对象、类、接口
- 继承、泛型
- 方法
- 异常、断言
- 集合
- ……
学习的过程中,强烈建议配合上我总结的常见问题和重要知识点(顺便还能准备一下面试常见问题):
Java 基础:
Java 基础常见面试题总结(上)(Java 语言的基本概念、语法、数据类型、变量、方法等)
Java 基础常见面试题总结(中)(面向对象基础、字符串、对象的比较与拷贝等)
Java 基础常见面试题总结(下)(异常、泛型、反射、SPI、序列化、注解等)
Java 集合:
- Java 集合常见面试题总结(上)(Java 集合基础、
ArrayList、LinkedList、HashSet、ArrayDeque、PriorityQueue、BlockingQueue等) - Java 集合常见面试题总结(下)(
HashMap、ConcurrentHashMap等)
- Java 集合常见面试题总结(上)(Java 集合基础、
Java 并发(进阶)
并发或者说多线程这部分内容稍微会比较难以理解和实践。如果你刚学完 Java 基础的话,我建议你学习并发这部分内容的时候,可以先简单地了解一下基础知识比如线程和进程的对比。到了后面,你对于 Java 了解的更深了之后,再回来仔细看看这部分的内容。
Java 并发书籍的话,挺多写的还不错的,比如《实战 Java 高并发程序设计》、《Java 并发编程之美》、《Java 并发实现原理:JDK 源码剖析》。



想要系统学习的话,还是找从里面找一本认真阅读一下。当然,你也可以多选几本结合起来一起看,遇到不懂的知识点再去看看别的书籍的讲解或者找对应的博客讲解。
视频的话,还是推荐尚硅谷周阳老师讲的:Java 并发编程视频教程。
👉我整理了尚硅谷最新的 Java 后端学习系列完整的视频教程&资料,喜欢看视频的朋友可以点此链接下载: 【最新整理】尚硅谷 Java 后端全套教程 & 实战项目(推荐)。

学习的过程中,强烈建议配合上我总结的常见问题和重要知识点:
- Java并发常见面试题总结(上)(多线程基础知识,例如线程和进程的概念、死锁)
- Java并发常见面试题总结(中)(各种锁,例如乐观锁和悲观锁、
synchronized关键字、ReentrantLock) - Java并发常见面试题总结(下)(
ThreadLocal、线程池、Future、AQS、虚拟线程等)
JVM(进阶)
JVM 属于是比并发更高阶一些的内容,学习顺序可以适当延后,比如你可以在框架知识学完之后再回过头来看 JVM。并且,JVM 相关的知识点,一般是大厂(例如美团、阿里)和一些不错的中厂(例如携程、顺丰、招银网络)面试才会问到,面试国企、差一点的中厂和小厂就没必要准备了。
不过,我个人建议如果你学有余力的话,还是抽时间学习一下,还是有用的。正所谓只有搞懂了 JVM 才有可能真正把 Java 语言“吃透”。
实际工作中,中小厂一般不会做 JVM 调优,但万一遇到类似 OOM 的问题,你如果知道如何去排查和解决,岂不是更好?
学习 JVM 这部分的内容,一定要注意要实战和理论结合。
书籍的话,《深入理解 Java 虚拟机》 这本书是首先要推荐的。

这本书就一句话形容:国产书籍中的战斗机,实实在在的优秀! (真心希望国内能有更多这样的优质书籍出现!加油!💪)
这本书的第三版已经出来挺久了,新增了很多不错的内容比如 ZGC 等新一代 GC 的原理剖析。
不论是你面试还是你想要在 Java 领域学习的更深,你都离不开这本书籍。这本书不光要看,你还要多看几遍,里面都是干货。这本书里面还有一些需要自己实践的东西,我建议你也跟着实践一下。
类似的书籍还有 《实战 Java 虚拟机》、《虚拟机设计与实现:以 JVM 为例》,这两本都是非常不错的!


如果你对实战比较感兴趣,想要自己动手写一个简易的 JVM 的话,可以看看 《自己动手写 Java 虚拟机》 这本书。

书中的代码是基于 Go 语言实现的,搞懂了原理之后,你可以使用 Java 语言模仿着写一个,也算是练练手! 如果你当前没有能力独立使用 Java 语言模仿着写一个的话,你也可以在网上找到很多基于 Java 语言版本的实现,比如《zachaxy 的手写 JVM 系列》。
另外,R 大在豆瓣发的《从表到里学习 JVM 实现》这篇文章中也推荐了很多不错的 JVM 相关的书籍,推荐小伙伴们去看看。
视频的话,尚硅谷的宋红康老师讲的《JVM 全套教程》内容非常硬,一共有接近 400 小节(对应的浓缩精华版:《尚硅谷 JVM 精讲与 GC 调优教程》)。
课程的内容分为 3 部分:
- 《内存与垃圾回收篇》
- 《字节码与类的加载篇》
- 《性能监控与调优篇》

👉我整理了尚硅谷最新的 Java 后端学习系列完整的视频教程&资料,喜欢看视频的朋友可以点此链接下载: 【最新整理】尚硅谷 Java 后端全套教程 & 实战项目(推荐)。

学习的过程中,强烈建议配合上我总结的常见问题和重要知识点:
数据库
基础(可选)
数据库基础知识点的话,其实是可选择性学习的。对于计算机专业的同学来说,大学的时候应该也学习过。不过,绝大部分学了之后也相当于没学,没学过的也不用担心哈!
这里还是提供一些学习资料给想要学习数据库基础知识的同学把!
书籍的话,强烈推荐《数据库系统概念》,这本书涵盖了数据库系统的全套概念,知识体系清晰,是学习数据库系统非常经典的教材!不是参考书!

如果你觉得书籍比较枯燥,自己坚持不下来的话,我推荐你可以先看看一些不错的视频。就比如北京师范大学的《数据库系统原理》这个就很不错。
这个课程的老师讲的非常详细,而且每一小节的作业设计的也与所讲知识很贴合,后面还有很多配套实验。

如果你比较喜欢动手,对于理论知识比较抵触的话,我推荐你看看《如何开发一个简单的数据库》 ,这个 project 会手把手教你编写一个简单的数据库。

纸上学来终觉浅 绝知此事要躬行!强烈推荐 CS 专业的小伙伴一定要多多实践!!!
MySQL
对于 Java 开发来说,虽然 PostgreSQL 也挺火,但 MySQL 是主流,国内的绝大部分企业还是用的 MySQL。
MySQL 入门可以找一些视频看看,比如黑马的《MySQL 数据库入门到精通》。看视频的过程中,可以配套一本 MySQL 入门类的书籍比如《MySQL 必知必会》。
初期不需要学太深了,搞清楚下面这些知识点即可:
MySQL 常用命令 :
- 安全:登录、增加/删除用户、备份数据和还原数据
- 数据库操作: 建库建表/删库删表、用户权限分配
- ……
MySQL 中常用的数据类型、字符集编码
MySQL 简单查询、条件查询、模糊查询、多表查询以及如何对查询结果排序、过滤、分组……
MySQL 中使用索引、视图、存储过程、游标、触发器
……
更进一步的话,可以找一些优秀的书籍来学习底层原理和性能优化,比如《高性能 MySQL》和《MySQL 技术内幕》。

另外,强推一波 《MySQL 是怎样运行的》 这本书,内容很适合拿来准备面试。讲的很细节,但又不枯燥,内容非常良心!

如果你想让自己更加了解 MySQL ,同时也是为了准备面试的话,下面这些知识点要格外注意:
- 索引:索引优缺点、B 树和 B+树、聚集索引与非聚集索引、覆盖索引
- 事务:事务、数据库事务、ACID、并发事务、事务隔离级别
- 存储引擎(MyISAM 和 InnoDB)
- 锁机制与 InnoDB 锁算法
学习的过程中,强烈建议配合上我总结的常见问题和重要知识点:
- MySQL 常见面试题总结(MySQL 基础、存储引擎、事务、索引、锁、性能优化等)
- MySQL 索引详解
- MySQL 三大日志(binlog、redo log 和 undo log)详解
- MySQL 事务隔离级别详解
- InnoDB 存储引擎对 MVCC 的实现
- SQL 语句在 MySQL 中的执行过程
PostgreSQL(可选)
和 MySQL 一样,PostgreSQL 也是开源免费且功能强大的关系型数据库。PostgreSQL 的 Slogan 是“世界上最先进的开源关系型数据库” 。

客观来说,PostgreSQL 确实比 MySQL 优秀。不过,目前国内 MySQL 还是主流,PostgreSQL 是可选择性学习的。
PostgreSQL 中文文档建议看看:PostgreSQL 14 中文文档。另外,PostgreSQL 书籍的话,看这里的推荐即可:数据库书籍推荐:PostgreSQL。
Redis
后端项目如果用到分布式缓存的话,一般用的都是 Redis。不过,Redis 不仅仅能做缓存,还能用作分布式锁、延时队列、消息队列等等。
免费的视频教程的话,推荐 GeekHour 的 一小时Redis教程(非常推荐,通俗易懂,简单介绍了 Redis 中涉及到的绝大部分知识点) 和尚硅谷的 《Redis 7 系列最新视频》(阳哥出品,内容更全面,Redis 版本更新,强烈推荐)。
书籍的话,强烈推荐 《Redis 设计与实现》和 《Redis 核心原理与实践》 这两本书。《Redis 核心原理与实践》这本书出版日期相对近一些,主要是结合源码来分析 Redis 的重要知识点比如各种数据结构和高级特性。

付费专栏的话,推荐一个极客时间的《Redis 核心技术与实战》,虽然未涉及到太多新版 Redis 的内容,但胜在内容全面且清晰易懂。我当时看这个专栏确实学了不少东西,尤其是评论区有很多大佬的精彩的评论。
学习的过程中,强烈建议配合上我总结的常见问题和重要知识点:
- 缓存基础常见面试题总结
- Redis 常见面试题总结(上)
- Redis 常见面试题总结(下)
- Redis 5 种基本数据类型详解
- Redis 3 种特殊数据类型详解
- Redis 持久化机制详解
- Redis 内存碎片详解
MongoDB(可选)
MongoDB 作为 Java 后端开发来说,是可选择性学习的,用的不多,面试一般也不会问,除非你的项目用到了 MongoDB 。
这里就不推荐视频或者书籍了,推荐两篇我写的文章:
常用开发工具
非常重要!非常重要!特别是 Git 和 Docker。
除了下面这些工具之外,我强烈建议你一定要搞懂 Github 的使用。一些使用 Github 的小技巧,你可以看Github 小技巧这篇文章。
IDEA
俗话说:“工欲善其事,必先利其器 !”。选择一款好的开发工具对于我们高效率编码非常有帮助!
常用的 Java 开发工具就 Eclipse 和 IDEA。就我个人而言 IDEA 是最适合 Java 开发者的 IDE ,没有之一(勿杠,你喜欢的就是最好的)。
除了 IDEA 自身对编码优秀的支持(比如智能上下文提示)之外,IDEA 中还有丰富的插件来帮助我们高效开发。
近几年,像 Cursor 这样的 AI 编程 IDE 兴起,确实对 IDEA 有了一定冲击。但整体来看,IDEA 依然难以被取代。无论是开发体验还是代码重构能力,IDEA 都有着无与伦比的优势。当然,在 AI 辅助编程这一块,IDEA 的表现的确有些落后。要知道,过去代码智能提示可是它的拿手好戏。
IntelliJ IDEA 官方中文文档今年正式上线了,强烈推荐以这个为第一手资料。
IDEA 官方中文文档入口: https://www.jetbrains.com/zh-cn/help/idea/getting-started.html
另外,「IDEA 高效使用指南」是我创建的一个网站,上面包含了下面这些内容:
- IDEA 使用技巧
- IDEA 必备插件
- IDEA 插件开发入门
- 使用 IDEA 进行重构的小技巧
- 使用 IDEA 进行源码阅读的技巧
Maven
Maven 其实使用起来挺简单的,一两天时间就能入门基本使用了。不过,想要用好还是挺难的,初期的时候会基本使用就好了。
多提一句:学习常用框架之前可以提前花时间学习一下 Maven 的使用,千万不要 到处找 Jar 包,下载 Jar 包(如果你做的项目没用上包管理工具,那请你尽快换一个新点的教程看)。
Maven 这里不用推荐什么视频或者书籍了,直接看下面这篇文章即可:
学完之后,务必要搞懂下面这些问题(初学者搞懂前两个问题即可):
- Maven 项目如何创建?如何引入依赖?
- Maven 依赖冲突如何解决?
- Maven 多模块项目的构建、运行、打包如何做?
- Maven 私服如何搭建?
Git
Git 技能对于程序员来说也是必备的!试着在学习的过程中将自己的代码托管在 Github 上,有一个漂亮的 Github 主页在求职面试中是十分加分的。并且,现在的企业都是基于 Git 在 GitHub 或 GitLab 平台上做版本控制。
学习 Git 的话,强烈推荐给大家一个可以交互式学习 Git 的网站 Learn Git Branching。效果真的非常非常棒,通过游戏的方式让你学习 Git 的常见操作。
整个教程分为很多关,每一关都有非常详细的指导,还会有详细的动图展示结果。并且,你做错了之后还可以使用 reset 命令从头开始。

如果你是在不知道答案的话,还可以使用 show solution 命令查看答案。

这种即时反馈的学习让过程变得有趣!真心感谢这个网站的作者,太爱了!
另外,你可以看看这篇 Git 极简入门 ,像版本控制和 Git 的相关概念、Git 常见操作这篇文章都有介绍到。
如果想要详细了解 Git 的话,可以看看《Pro Git》这本书,介绍的非常全面,免费,支持阅读,并且有中文版!


这是这本书的另外一个在线阅读地址:https://git-scm.com/book/zh/v2。
如果你比较喜欢看视频教程的话,可以看看极客时间的《玩转 Git 三剑客》,课程的作者是携程代码平台负责人苏玲,讲的挺不错的!
Docker
传统的开发流程中,我们的项目通常需要使用 MySQL、Redis、FastDFS 等等环境,这些环境都是需要我们手动去进行下载并配置的,安装配置流程极其复杂,而且不同系统下的操作也不一样。
Docker 的出现完美地解决了这一问题,我们可以在容器中安装 MySQL、Redis 等软件环境,使得应用和环境架构分开,它的优势在于:
- 一致的运行环境,能够更轻松地迁移
- 对进程进行封装隔离,容器与容器之间互不影响,更高效地利用系统资源
- 可以通过镜像复制多个一致的容器
Docker 常见概念解读,可以看这篇 JavaGuide 的这篇Docker 基本概念解读 ,从零到上手实战可以看Docker 从入门到上手干事这篇文章,内容非常详细!
另外,再给大家推荐一本质量非常高的开源书籍《Docker 从入门到实践》,这本书的内容非常新,毕竟书籍的内容是开源的,可以随时改进。

如果想看视频的话,推荐这个:Docker 1 小时快速上手教程,没啥废话,干货挺多。而且,课件也是直接免费分享出来的:Docker 1 小时教程课件。

最后,在学习完 Docker 的常见操作之后,建议大家以一个前后端分离的项目为例,去实践部署一下。比如,你可以选择部署自己的简历项目,这样的话,项目经历部分贴上在线体验地址,也算是一个加分项了!
设计模式
软件开发中有一个概念叫做“软件复用”。简单来说,软件复用就是我们在构建一个新的软件的时候,不需要从零开始,通过复用已有的一些轮子(框架、第三方库等)、设计模式、设计原则等等现成的物料,我们可以更快地构建出一个满足要求的软件。
软件复用需要设计模式的帮助。因为,在软件开发中,设计模式可以通过封装变化来提高代码的可扩展性和可维护性!
在我们平时工作的业务开发中,如果你不会设计模式,你或许也可以完成项目的功能需求。但是!单纯 CRUD 多没意思啊!我们要思考如何写出质量更高的业务代码。另外,各种框架比如 Spring、MyBatis 中都大量使用了设计模式。如果,你想要搞懂他们的原理,设计模式也是你的必备利器。
设计模式不光需要我们在学习,最重要的还是要不断去实践体会。但是!设计模式不是银弹,不要为了用设计模式而用设计模式。
想要看书学习设计模式的话,首推 《重学 Java 设计模式》 。有趣的例子,配合形象的图片,通过实战案例讲解设计模式的方式秒极了!文中的每一个细节无不透露着作者的用心!每一种设计模式实际都不难理解,大部分读者最需要的还是设计模式的实战经验。如果你能细心思考实践《重学 Java 设计模式》 中的每一个案例,我相信,你对设计模式的理解一定会更上一层楼!
想要看视频学习的话,首推 《尚硅谷 Java 设计模式(图解+框架源码剖析)》 这个视频。
这个视频通过图解+框架源码分析的方式全面地讲解了设计模式相关的内容,包括设计模式七大原则、UML 类图-类的六大关系、23 种设计模式及其分类等知识点。
Linux
对于 Java 程序员来说, 我们需要掌握 Linux 基本的使用,尤其是是各种常用的命令比如:目录切换命令、目录操作命令、文件的操作命令、压缩或者解压文件的命令等等。像 Linux 内核架构、底层原理这些底层内容,不是必需的,可以根据自身情况来决定是否学习。
对于想要快速入门 Linux 的同学来说,建议阅读我写的 Linux 基础知识总结这篇文章,里面介绍了 Java 程序员必知的 Linux 的一些概念以及常见命令。
视频的话,我推荐 GeekHour 的 30 分钟 Linux 入门教程,通俗易懂,实战讲解!不过,相对偏基础一些,适合想要快速入门的同学。
对于想要系统学习的同学来说,还是建议看书籍,像《鸟哥的 Linux 私房菜》系列就挺不错的。不过,内容有点太多了,个人还是更建议作为工具书参考或者选择自己感兴趣的内容章节进行学习。

不要忘记学习一下 Shell 编程了,这个也是必须要掌握的,快速入门可以阅读我写的 Shell 编程基础知识总结这篇文章,总结了 Shell 变量、基本运算符、流程控制、函数这些重要的知识点。
前端基础
笔者主要从事 Java 后端开发的,对于前端的了解属于皮毛,刚刚入门的状态(当过一年全栈),这里只是简单聊聊自己的看法。
前端框架更新换代的很快,目前比较流行的是 Vue 和 React 。对于国内的同学,Vue 更适合投入精力学习,因为国内用 Vue 的公司更多一些。不过,前端框架并不是必学的,可以根据自身情况来决定是否学习。
不过,不管前端这些技术怎么变,前端三剑客(HTML、CSS、JavaScript )是不会变的,也是必学的。
HTML 和 CSS 相对 JS 来说就比较简单了。你可以在 W3school 上学习一些关于 HTML、CSS、JS 的基础知识。然后,通过一个简单的前端项目来实战一下。比如你可以做一个个人简历或者模仿某某官网写个类似的网页。
JavaScript 的水更深,也是前端面试中的重心。
学习 JS 的话,MDN 上的 JS 相关的内容是必须要看的!上面的内容很全面,质量非常高!
除此之外,开源的 JS 教程《The Modern JavaScript Tutorial》非常赞!目前的话,这个系列的教程还被翻译成了多国的语言。

这个教程的内容分为 3 部分
- JavaScript 编程语言 : JavaScript 入门,还会介绍 OOP 等相关高级概念。
- 浏览器(文档,事件,接口) : 学习如何管理浏览器页面
- 其他文章 : 按需学习其他 JavaScript 高级知识。
另外,除了一些老项目之外,现在一般都是前后端分离开发,也就是前端和后端可以独立开发、测试和部署,两者之间通过 API 进行通信。因此,后端程序员还需要掌握:
- HTTP 协议(计算机网络部分的内容,这里再多提一下)
- RESTful API 的设计和使用
- 前后端通信的常见方式:比如 Ajax(短连接)、WebSocket(长连接,双向的)
J2EE 基础
Servlet
Servlet 属于比较古老的技术了,现在你几乎不会直接使用到 Servlet 相关的 API。不过,学习 Servlet 有助于我们搞清各种封装的比较好的 Web 框架的原理,比如 Spring MVC 不过就是对 Servlet 的封装,它的底层还是依赖于 Servlet。
在 Java Web 程序中,Servlet 主要负责接收用户请求 HttpServletRequest,在doGet(),doPost()中做相应的处理,并将回应HttpServletResponse反馈给用户。
你可以通过书籍《Head First Servlets & JSP(中文版)》或者《Servlet 和 JSP 学习指南》来学习 Servlet 基础知识。
注意:JSP 就不要学了,过时的技术,已经被淘汰了!
Web 服务器
Tomcat 是 Apache 基金会下的一个项目,主要用作 Web 服务器。
如果你直接学习 Spring Boot 的话,不学习 Tomcat 也没什么影响(建议还是学一学)。因为 Spring Boot (spring-boot-starter-web)使用 Tomcat 作为默认的嵌入式 Servlet 容器, 你使用起来是无感知的。
简单来说,Tomcat 主要实现了 2 个核心功能:
- 处理
Socket连接,负责网络字节流与Request和Response对象的转化。 - 加载和管理
Servlet,以及具体处理Request请求。
如果你要深入研究 Tomcat 的话,首选极客时间的 《深入拆解 Tomcat & Jetty》 这个专栏。这是我看过讲解 Tomcat 底层原理最好的资料,强烈推荐!
这个专栏不光可以加深自己对于 Tomcat 的理解,还能提高自己对于系统架构、性能优化等领域的思考。

除了 Tomcat 之外,Nginx 也是必须要学习的!
Nginx 是一个高性能的 HTTP 和反向代理服务服务器,经常被拿来做反向代理和负载均衡。
如果你要学习 Nginx 的话,可以看看《Nginx 核心知识 150 讲》 。内容很全面,从概念、代码再到实战,从 HTTP 到 OpenResty 。
常用框架
实际面试中,框架类知识问的不多,学习常用框架更多地是为了满足项目开发需要以及工作要求。
Spring/SpringBoot
没有学习 Spring 可以直接上手学习 SpringBoot 吗?
明确的说,必须可以!目前绝大部分企业都是用的 SpringBoot ,Spring 也并不是学习 Spring Boot 的前置基础,相比于 Spring 来说,Spring Boot 要更容易上手一些!如果你只是想使用 Spring Boot 来做项目的话,直接学 Spring Boot 就可以了。
不过,个人还是建议提前搞懂 Spring AOP 和 IoC 这俩比较重要的概念之后再去学习 SpringBoot。除此之外,准备面试的话,Spring 中 bean 的作用域与生命周期、SpringMVC 工作原理详解等等知识点都是非常重要的,一定要搞懂。推荐阅读这篇文章:Spring 常见面试题总结。
学习 Spring Boot 的话,还是建议可以多看看 《Spring Boot 的官方文档》,写的很详细。
像 SpringBoot 和一些常见技术的整合你也要知道怎么做,比如 SpringBoot 整合 MyBatis、 ElasticSearch、SpringSecurity、Redis 等等。尽量还是实践一下,写一些 Demo。到了后期,甚至可以独立做一些小项目把这些知识都应用上。
书籍的话,个人其实并没有什么特别好的推荐,毕竟是框架类知识,更新换代的比较快,很多书籍的内容都已经过时了。
考虑到很多同学比较喜欢阅读书籍,我这里还是简单推荐几本吧!
对于想要实战的同学,我强烈不推荐看书,直接看尚硅谷的实战项目即可。这篇文章可以获取到最新的视频且对尚硅谷的实战项目做了介绍:【最新整理】尚硅谷 Java 后端全套教程 & 实战项目(推荐)。

对于专研 Spring Boot 底层原理同学,可以看看 《Spring Boot 编程思想(核心篇)》。

这本书稍微有点啰嗦,不过,原理介绍的比较清楚(不适合初学者)。
如果你比较喜欢看视频的话,推荐尚硅谷雷神的《2023 版 Spring Boot3 零基础入门》 。这可能是全网质量最高并且免费的 Spring Boot 教程了,好评爆炸!
另外,Spring Boot 这块还有很多优质的开源教程,我已经整理好放到 Java 优质开源技术教程 中了。

MyBatis
MyBatis 是国内使用最多的 ORM 框架。在学习 Spring/Spring Boot 的时候,你就要顺带去学习 MyBatis,这个我在上面也提到过。
另外,建议你还要掌握至少一个 MyBatis 增强框架,这里推荐两个国产的:
- MyBatis-Plus:简称 MP,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
- MyBatis-Flex:非常轻量、同时拥有极高的性能与灵活性的 MyBatis 增强框架。
对于做项目的同学,也可以直接选择学习使用 MyBatis 增强框架。
单元测试
对于单测来说,目前常用的单测框架有:JUnit、Mockito、Spock、PowerMock、JMockit、TestableMock 等等。
JUnit 几乎是默认选择,但是其不支持 Mock,因此我们还需要选择一个 Mock 工具。Mockito 和 Spock 是最主流的两款 Mock 工具,一般都是在这两者中选择。
究竟是选择 Mockito 还是 Spock 呢?我这里做了一些简单的对比分析:
- Spock 没办法 Mock 静态方法和私有方法,Mockito 3.4.0 以后,支持静态方法的 Mock,具体可以看这个 issue:mockito/mockito#1013,具体教程可以看这篇文章:Mocking Static Methods With Mockito。
- Spock 基于 Groovy,写出来的测试代码更清晰易读,比较规范(自带 given-when-then 的常用测试结构规范)。Mockito 没有具体的结构规范,需要项目组自己约定一个或者遵守比较好的测试代码实践。通常来说,同样的测试用例,Spock 的代码要更简洁。
- Mockito 使用的人群更广泛,稳定可靠。并且,Mockito 是 SpringBoot Test 默认集成的 Mock 工具。
Mockito 和 Spock 都是非常不错的 Mock 工具,相对来说,Mockito 的适用性更强一些。
这里顺带推荐一些测试相关的学习资料:
- 阿里内部单元测试培训教程
- 单元测试到底是什么?应该怎么做?
- Integration Testing in Spring
- Testing the Web Layer
- 可能是全网最好的 Spock 单测入门文章:
- 单元测试框架 Mockito 落地实践分享
- 如何写出有效的单元测试
Netty(可选)
Netty 是 Java 网络编程最热门的框架,大家可以根据个人需要决定是否进行学习,实际企业开发中用的不多。
不过,个人建议学有余力的同学还是抽时间认真学习一下,对个人开发能力的提升还是很有帮助的。
- Netty 基于 NIO (NIO 是一种同步非阻塞的 I/O 模型,在 Java 1.4 中引入了 NIO )。使用 Netty 可以极大地简化并简化了 TCP 和 UDP 套接字服务器等网络编程,并且性能以及安全性等很多方面都非常优秀。
- 我们平常经常接触的 Dubbo、RocketMQ、Elasticsearch、gRPC、Spark、Elasticsearch 等等热门开源项目都用到了 Netty。
- 大部分微服务框架底层涉及到网络通信的部分都是基于 Netty 来做的,比如说 Spring Cloud 生态系统中的网关 Spring Cloud Gateway 。
下面是一些比较推荐的书籍/专栏。

这本书可以用来入门 Netty ,内容从 BIO 聊到了 NIO、之后才详细介绍为什么有 Netty 、Netty 为什么好用以及 Netty 重要的知识点讲解。
这本书基本把 Netty 一些重要的知识点都介绍到了,而且基本都是通过实战的形式讲解。

内容都是关于使用 Netty 的实践案例比如内存泄露这些东西。如果你觉得你的 Netty 已经完全入门了,并且你想要对 Netty 掌握的更深的话,推荐你看一下这本书。
《跟闪电侠学 Netty:Netty 即时聊天实战与底层原理》

这本书分为上下两篇,上篇通过一个即时聊天系统的实战案例带你入门 Netty,下篇通过 Netty 源码分析带你搞清 Netty 比较重要的底层原理。
视频的话,黑马的 黑马程序员 Netty 全套教程 就挺不错的,从 Netty 的基础知识 NIO 讲起,比较容易接受。

工作流(可选)
国内用的比较多的开源工作流引擎是 Flowable 和 Activiti 这两个,参考资料也蛮多的。Camunda 也不错,更轻量,功能也很完善,性能和稳定性也很不错。关于开源流程引擎的选择,可以参考这篇文章:开源流程引擎选型参考。
ps:Flowable 和 Camunda 都是 Activiti5 的一个分支发展而来, 三者的理念有所差别。
国内比较火的工作流引擎 LiteFlow 只做基于逻辑的流转,而不做基于角色任务的流转。如果你想做基于角色任务的流转,推荐使用 Flowable 和 Activiti 这两个框架。也就是说,像审批流(A 审批完应该是 B 审批,然后再流转到 C 角色)这种 LiteFlow 就不适合了。LiteFlow 适用于拥有复杂逻辑的业务,比如说价格引擎,下单流程等,这些业务往往都拥有很多步骤,这些步骤完全可以按照业务粒度拆分成一个个独立的组件,进行装配复用变更。
这里就不推荐学习资料了,感兴趣的同学可以自己去找一下。
搜索引擎
搜索引擎用于提高搜索效率,功能和浏览器搜索引擎类似。比较常见的搜索引擎是 Elasticsearch(推荐) 和 Solr。
如果你要学习 Elasticsearch 的话,Elastic 中文社区以及 Elastic 官方博客都是非常不错的资源,上面会分享很多具体的实践案例。
视频教程可以看看尚硅谷的 《ElasticSearch 入门到精通》,前面基于 ElasticSearch 7.x 讲解,后面加更了 Elasticsearch8.x 新特性。
书籍可以看看《一本书讲透Elasticsearch:原理、进阶与工程实践》。这本书基于 8.x 版本编写,目前全网最新的 Elasticsearch 讲解书籍。内容覆盖 Elastic 官方认证的核心知识点,源自真实项目案例和企业级问题解答。

最后,再推荐一些 ElasticSearch 相关的优秀文章和专辑来帮助你学习和更好的使用 ElasticSearch:
- Elasticsearch 常见面试题总结 - JavaGuide
- Elasticsearch 基础入门详文 - 腾讯技术工程
- 在工作中 ElasticSearch 的一些使用规范
- 《滴滴技术的 ES 系列》
- 《死磕 Elasticsearch 系列》(上百篇 ES 的理论+实战文章,全网最全面的 ES 教程。部分内容对应的视频教程:https://space.bilibili.com/471049389 )
分布式&微服务(进阶)
这部门内容涉及到的知识点比较多,我这里只列举比较重要的部分比如分布式算法和协议、配置中心、分布式事务。
学习分布式知识,个人比较建议阅读书籍和博客。当然了,如果比较喜欢看视频的话,也可以找一些不错的教程视频或者公开课来看,用适合自己的学习方式去学习即可!
书籍推荐(理论向):
《深入理解分布式系统》这本书非常不错。这本书的作者用了大量篇幅来介绍分布式领域中非常重要的共识算法,并且还会基于 Go 语言带着你从零实现了一个共识算法的鼻祖 Paxos 算法。

《从零开始学架构》这本书的内容比较全面,分布式、微服务、高并发、高可用这些都有涉及到。这本书对应的是极客时间的专栏:《从零开始学架构》,里面的很多内容都是这个专栏里面的,两者选一个阅读就行了。

余老师的 《软件架构设计:大型网站技术架构与业务架构融合之道》这本书类似于《从零开始学架构》,内容同样比较全面,也很不错。

公开课推荐(理论向):
MIT6.824: Distributed System 这门公开课挺经典的。这门课每节课都会精读一篇分布式系统领域的经典论文,并由此传授分布式系统设计与实现的重要原则和关键技术。
- 如何的才能更好地学习 MIT6.824 分布式系统课程?
- MIT6.824: Distributed System(中文翻译 wiki)
- MIT6.824: Distributed System - CS 自学指南
视频推荐(实战向):
视频可以直接学习尚硅谷的 2024 最新版 Spring Cloud 教程,这门课程介绍了 SpringCloud 和 SpringCloud Alibaba 中目前最主流的组件。学完了这门课程之后,就可以直接上手为微服务项目的开发实战了。

理论&算法&协议
比较重要的分布式理论&算法&协议有:CAP 理论、BASE 理论、Paxos 算法、Gossip 协议、Raft 算法等等。
文章推荐:
远程调用
不同服务之间的调用一般有两种方法:
- RPC:RPC(Remote Procedure Call) 即远程过程调用,通过 RPC 可以帮助我们调用远程计算机上某个服务的方法,这个过程就像调用本地方法一样简单。Dubbo 是一款国产的 RPC 框架,由阿里开源,国内用的最多。
- HTTP 客户端 :通过 HTTP 协议调用其他服务的 RESTful API。Feign 和 OpenFeign(Spring Cloud 官方基于 Feign 开发的,用于替代已经进入停更维护状态的 Feign) 是目前最常用的 HTTP 客户端。
OpenFeign 和 Dubbo 都是目前广泛应用于微服务架构的远程调用框架,但两者实现方式不同(OpenFeign 基于 HTTP 协议,Dubbo 支持多种协议,还可以自定义协议),适合的场景也略有区别。Spring Cloud 微服务项目现在用的比较多的是基于 Rest 风格的调用方式的 OpenFeign,个人比较建议学习这个。
不过,如果你跟着教程做的项目用的是 Dubbo 或者工作需要用到 Dubbo 的话,那你可以主要学习 Dubbo。推荐一下我写的总结:
另外,Dubbo 官方文档是一定要看的,地址:https://cn.dubbo.apache.org/zh-cn/overview/home/。
服务注册与发现
Eureka、Zookeeper、Consul、Nacos 都可以提供服务注册与发现的功能。
个人比较建议学习 Nacos,国内用的比较多,功能也更强大!除了提供服务注册与发现工功能之外,还可以作为配置中心使用。
学习 Nacos 的话,官方文档是一定要看的:https://nacos.io/zh-cn/docs/v2/quickstart/quick-start.html 。
另外,再推荐一些我觉得还不错的学习资料:
Nacos 架构&原理 - 阿里藏经阁(推荐,像 Nacos 内核设计、底层原理、最佳实践)
图文解析 Nacos 配置中心的实现 - 掘金(没有过多代码粘贴,原理讲的很清楚)
API 网关
网关可以为我们提供请求转发、安全认证(身份/权限认证)、流量控制、负载均衡、降级熔断、日志、监控、参数校验、协议转换等功能。
关于 API 网关的基础知识和技术选型推荐阅读我写的 API 网关基础知识总结这篇文章。
Spring Cloud 微服务项目比较推荐实用 SpringCloud Gateway 作为 API 网关,这是 Spring Cloud 的一个全新项目,为了取代 Netflix Zuul。为了提升网关的性能,SpringCloud Gateway 是基于 WebFlux 实现。Spring Cloud Gateway 的目标是不仅提供统一的路由方式,并且基于 Filter 链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流。
下面这些是我觉得还不错的学习资料:
- Spring Cloud Gateway 常见问题总结 - JavaGuide
- 6000 字 | 16 图 | 深入理解 Spring Cloud Gateway 的原理 - 悟空聊架构
- Spring Cloud Gateway 夺命连环 10 问? - 不才陈某
- Spring Cloud Gateway 整合阿里 Sentinel 网关限流实战! - 不才陈某
- 实战 Spring Cloud Gateway 之限流篇 - aneasystone(对于常见的限流算法和组件都有介绍到)
配置中心
微服务下,业务的发展一般会导致服务数量的增加,进而导致程序配置(服务地址、数据库参数等等)增多。
传统的配置文件的方式已经无法满足当前需求,主要有两点原因:一是安全性得不到保障(配置放在代码库中容易泄露);二是时效性不行 (修改配置需要重启服务才能生效)。
Spring Cloud Config、Nacos 、Apollo、K8s ConfigMap 都可以用来做配置中心。
Apollo 和 Nacos 我个人更喜欢。Nacos 使用起来更加顺手,还能顺便作为注册中心使用,Apollo 在配置管理方面做的更加全面。
个人还是更建议学习 Nacos ,学习资料在上面的服务注册与发现已经推荐过了。
分布式 ID
ID 是数据的唯一标识,分布式 ID 是分布式系统下的 ID。
分布式 ID 的解决方案有很多,比如 :
- 算法 :UUID、Snowflake(雪花算法)
- 开源框架 : UidGenerator(百度)、Leaf(美团)、Tinyid(滴滴)、IdGenerator(个人)
这块内容比较简单,推荐阅读下面这两篇文章进行学习:
分布式事务
微服务架构下,一个系统被拆分为多个小的微服务。
每个微服务都可能存在不同的机器上,并且每个微服务可能都有一个单独的数据库供自己使用。这种情况下,一组操作可能会涉及到多个微服务以及多个数据库。
举个例子:电商系统中,你创建一个订单往往会涉及到订单服务(订单数加一)、库存服务(库存减一)等等服务,这些服务会有供自己单独使用的数据库。

那么如何保证这一组操作要么都执行成功,要么都执行失败呢?
这个时候单单依靠数据库事务就不行了!我们就需要引入 分布式事务 这个概念了!
常用分布式事务解决方案有 Seata 和 Hmily。
目前国内用的比较多的是 Seata,建议学习这个。
分布式链路追踪
不同于单体架构,在分布式架构下,请求需要在多个服务之间调用,排查问题会非常麻烦。我们需要分布式链路追踪系统来解决这个痛点。
目前分布式链路追踪系统基本都是根据谷歌的《Dapper 大规模分布式系统的跟踪系统》这篇论文发展而来,主流的有 Pinpoint,Skywalking ,CAT(当然也有其他的例如 Zipkin,Jaeger 等产品,不过总体来说不如前面选取的 3 个完成度高)等。
Zipkin 是 Twitter 公司开源的一个分布式链路追踪工具,Spring Cloud Sleuth 实际是基于 Zipkin 的。
SkyWalking 是国人吴晟(华为)开源的一款分布式追踪,分析,告警的工具,现在是 Apache 旗下开源项目。
目前国内用的比较多的是 SkyWalking,建议学习这个。
高性能(进阶)
CDN(掌握概念和原理即可)
CDN 就是将静态资源分发到多个不同的地方以实现就近访问,进而加快静态资源的访问速度,减轻服务器以及带宽的负担。
我们只需要掌握 CDN 的基本概念和原理以及会用云厂商提供的现成 CDN 服务即可,花费不了太多时间。推荐阅读我写的CDN 常见问题总结这篇文章。
消息队列
消息队列在分布式系统中主要是为了异步、解耦和削峰。
常用的消息队列如下:
- RocketMQ :阿里巴巴开源的一款高性能、高吞吐量的分布式消息中间件。
- Kafka: Kafka 是一种分布式的,基于发布 / 订阅的消息系统。
- RabbitMQ :基于 erlang 开发的基于 AMQP(Advanced Message Queue 高级消息队列协议)协议实现的消息队列。
- Pulsar:下一代云原生分布式消息流平台。
建议选择 RocketMQ 和 Kafka 其中的一个进行深入学习,其他消息队列了解即可。
关于消息队列基础概念、技术选型方面的介绍,建议阅读我写的消息队列基础知识总结这篇文章。
Kafka、RocketMQ、RabbitMQ 学习资源推荐请看知识星球的这篇帖子:https://t.zsxq.com/0bEDFwgon 。
读写分离&分库分表(掌握概念和原理即可)
读写分离主要是为了将数据库的读和写操作分不到不同的数据库节点上。主服务器负责写,从服务器负责读。另外,一主一从或者一主多从都可以。
读写分离可以大幅提高读性能,小幅提高写的性能。因此,读写分离更适合单机并发读请求比较多的场景。

分库分表是为了解决由于库、表数据量过大,而导致数据库性能持续下降的问题。
常见的分库分表工具有:sharding-jdbc(当当)、TSharding(蘑菇街)、MyCAT(基于 Cobar)、Cobar(阿里巴巴)...。 推荐使用 sharding-jdbc。 因为,sharding-jdbc 是一款轻量级 Java 框架,以 jar 包形式提供服务,不要我们做额外的运维工作,并且兼容性也很好。

现在很多公司都是用的类似于 TiDB 这种分布式关系型数据库,不需要我们手动进行分库分表,因此我们只需要掌握读写分离&分库分表的常见概念和原理即可,不需要花费太多时间去实践,推荐阅读我写的 读写分离&分库分表常见问题总结这篇文章。
负载均衡
负载均衡系统通常用于将任务比如用户请求处理分配到多个服务器处理以提高网站、应用或者数据库的性能和可靠性。
开发过程中,我们接触到的负载均衡可以简单分为 服务端负载均衡 和 客户端负载均衡 这两种。服务端负载均衡可以通过硬件(比如 F5、A10、Array )或者软件(比如 LVS、Nginx、HAproxy )实现。Java 领域主流的微服务框架 Dubbo、Spring Cloud 等都内置了开箱即用的客户端负载均衡实现。Dubbo 属于是默认自带了负载均衡功能,Spring Cloud 是通过组件的形式实现的负载均衡,属于可选项,比较常用的是 Spring Cloud Load Balancer(官方,推荐) 和 Ribbon(Netflix,已被启用)。
个人建议学习一下 Nginx 和 Spring Cloud Load Balancer。
负载均衡的常见概念、算法和技术方案可以看看这篇文章:负载均衡常见问题总结。
高可用(进阶)
高可用描述的是一个系统在大部分时间都是可用的,可以为我们提供服务的。高可用代表系统即使在发生硬件故障或者系统升级的时候,服务仍然是可用的 。
限流&降级&熔断
限流是从用户访问压力的角度来考虑如何应对系统故障。限流为了对服务端的接口接受请求的频率进行限制,防止服务挂掉。比如某一接口的请求限制为 100 个每秒, 对超过限制的请求放弃处理或者放到队列中等待处理。限流可以有效应对突发请求过多。
关于服务限流的介绍推荐阅读我写的服务限流详解这篇文章,里面有介绍常见的限流算法以及单机限流和分布式限流的技术方案。
降级是从系统功能优先级的角度考虑如何应对系统故障。服务降级指的是当服务器压力剧增的情况下,根据当前业务情况及流量对一些服务和页面有策略的降级,以此释放服务器资源以保证核心任务的正常运行。
熔断和降级是两个比较容易混淆的概念,两者的含义并不相同。降级的目的在于应对系统自身的故障,而熔断的目的在于应对当前系统依赖的外部系统或者第三方系统的故障。
Netflix 开源的Hystrix 和阿里开源的 Sentinel 都能实现限流、降级、熔断。不过,Hystrix 已经停止维护了,更建议使用功能更为强大的 Sentinel。另外,Sentinel 的 Wiki 中对比了常用限流降级组件,感兴趣的可以看看,传送门:常用限流降级组件对比。
Sentinel 的 wiki 中已经详细描述了其与 Hystrix 的区别,你可以看看。
学习 Sentinel 的话,官方文档是一定要看的:https://sentinelguard.io/zh-cn/docs/introduction.html 。
另外,再推荐一些我觉得还不错的学习资料:
- 阿里限流神器 Sentinel 夺命连环 17 问? - 不才陈某
- Sentinel 为什么这么强,我扒了扒背后的实现原理 - 三友的 java 日志
- Sentinel 流控滑动窗口算法设计 - 老周聊架构
排队
另类的一种限流,类比于现实世界的排队。玩过英雄联盟的小伙伴应该有体会,每次一有活动,就要经历一波排队才能进入游戏。
实现排队的方法有很多种,比如我们可以借助消息队列、JDK 中的各种阻塞队列。
集群
相同的服务部署多份,避免单点故障。
超时和重试机制
一旦用户的请求超过某个时间得不到响应就结束此次请求并抛出异常。 如果不进行超时设置可能会导致请求响应速度慢,甚至导致请求堆积进而让系统无法在处理请求。
另外,重试的次数一般设为 3 次,再多次的重试没有好处,反而会加重服务器压力(部分场景使用失败重试机制会不太适合)。
云原生(可选)
提示:云原生开发对能力要求很高,Java 后端岗位通常也不会要求云原生开发技能。因此,这部分内容不推荐对云原生开发不感兴趣或者不了解的同学学习,可以选择跳过。
云原生就是在云中构建、运行应用程序的一套完整的技术体系和方法论。这里的技术体系和方法论就目前来说指的是 微服务+DevOps+持续交付+容器化。
越来越多的编程语言、框架开始拥抱云原生,例如 Spring 推出了面向云原生的技术 Spring Native、RedHat 开源了 Java 云原生服务框架 Quarkus。
如果你对云原生领域比较感兴趣的话,建议你重点关注下面这些技术:
- 微服务:SpringCloud 或者 SpringCloud Alibaba 其实是不用学习的,云原生下一般基于后面提到的 Kubernetes 来构建微服务。
- 网关:网关是整个微服务架构的流量入口,负责认证授权、请求分发、认证授权、限流、API 管理、负载均衡等工作,是微服务架构中非常重要的一个组件。因此,我这里专门单独将网关拿出来提一嘴。
- 日志和监控告警:Metrics(借助它我们可以在 Grafana 中绘制出各种直观的面板,可以更加全面的了解我们系统的运行状态)、Trace(借助它我们可以构建出系统调用的全貌)、Logs(一些必要的日志记录)。
- 容器:容器技术是云原生发展的基石,以 Docker 为首的容器工具提出了“一次构建,到处运行”的口号。
- Kubernetes:K8s 被称为云原生时代的操作系统,云原生应用的优势与其提供的功能息息相关。
- DevOps:DevOps 关注的是如何实现应用程序的全生命周期(开发,测试,运维)自动化管理,从而实现更快速、更高质量、更频繁、更稳定的软件交付。DevOps 团队通常会使用微服务架构来构建应用程序,借助于持续集成和持续部署(CI/CD)来实施 DevOps。
- ServiceMesh:你可以将 Service Mesh 看作是为了简化开发工作专门抽象出来的一层,通常作为透明的一层接入到现有的分布式应用程序里。
- ……
其中,比较重要的是 Kubernetes。如果你做项目的话,建议优先考虑 Kubernetes 相关的项目。
我之前写过一篇文章来介绍云原生,可以看看: 云原生时代,程序员应该掌握哪些能力? 。
另外,还推荐看看这篇:2024年的云原生架构需要哪些技术栈。
AI 应用开发(拓展路线)
AI 已经成为 Java 后端能力体系的一部分,但不建议一开始就把它塞进 Java 主线里硬学。更稳的节奏是:先把 Java 基础、Spring、数据库、缓存、分布式和项目实战打牢,再按下面这条路线系统补 AI 应用开发。
- Java/Go 开发者 AI 应用开发与 Agent 学习路线(2026 最新版):面向后端开发者,按大模型基础、LLM API、Prompt、RAG、Agent、工程化和项目实战拆解学习路径。
- 后端开发者转型 AI Agent 学习建议(2026 最新版):如果你不确定要不要转 AI、Java AI 和 Python AI 怎么选、能投什么岗位,可以先看这篇。
- AI 应用开发知识体系:学习路线之外的系统文章入口,覆盖大模型基础、Agent、RAG、MCP、Prompt 工程、评测和 AI 系统设计。
- AI 编程实践指南:日常编码提效路线,重点看 Claude Code、Codex、AI IDE、CLI Agent、上下文管理和 AI 辅助开发工作流。
如果你只是在准备 Java 后端面试,AI 这部分可以先了解基本概念;如果目标是 AI 应用开发、Agent 工程师,建议直接按照上面的 AI 应用开发学习路线推进。
总结
这是一份非常详细的学习路线,把上面的内容学完之后,找到一份比较好的工作已经比较容易。
另外,我在上面也说了,如果你觉得内容比较多自己学不完或者如果你只想找到一份小厂的开发工作的话,建议你把重心放在 Java 基础、数据库、常用框架、常用工具上。
像 JVM、分布式、高并发、高可用、微服务这些知识点,如果你想进大厂或者说让自己在求职的时候更有竞争力,那你就也是要多花一点时间来学习的。
现在面试很卷,想要找到一个好工作的话,就需要你去多学一点,多练习一点。虽然,你目前学的很多知识,在你工作之后可能用不到,但是,面试的筛选就需要你会这些。毕竟,很多岗位是很多人一起竞争,为了达到筛选效果,面试难度通常都会比较大的。这也就是所谓的:“面试造火箭,入职拧螺丝”。
公众号(推荐)
学习路线的最新更新会第一时间同步在公众号,推荐大家关注一波!

知识星球
为了帮助更多同学准备 Java 面试以及学习 Java ,我创建了一个纯粹的Java 面试知识星球。虽然收费只有培训班/训练营的百分之一,但是知识星球里的内容质量更高,提供的服务也更全面,非常适合准备 Java 面试和学习 Java 的同学。
欢迎准备 Java 面试以及学习 Java 的同学加入我的 知识星球,干货非常多,学习氛围也很不错!收费虽然是白菜价,但星球里的内容或许比你参加上万的培训班质量还要高。

