# Java 学习路线 by 程序员鱼皮

本文作者:程序员鱼皮 (opens new window)

本站地址:https://codefather.cn (opens new window)

# 符号表

可以通过路线知识点前的表情字符,根据自己的实际情况选择学习:

  • 🌕 所有同学必须学习!!!
  • 🌖 非常急着找工作,才可不学;目标大厂,必须学习!
  • 🌗 急着找工作的话,可不学;目标大厂,建议学习
  • 🌘 时间充足的话,再去学
  • ⭐ 表示推荐资源

# 前言

首先呢,我们要了解 Java 的应用场景和就业方向,看看和自己的学习目的是否一致。

目前,Java 由于其优秀的特性以及火爆的生态,岗位需求量大,是后台开发、安卓开发、大数据开发的主流编程语言,因此学习资源也很丰富,值得学习!

# 阶段 1:编程语言基础

# 目标

培养兴趣、快速上手,能运行和编写简单的 Java 程序。

学完本阶段后,可以试着用 Java 解决一些数学计算问题、编写图书管理系统等桌面端 GUI 程序,甚至是五子棋之类的小游戏。

# 🌕 Java 编程基础(45 天)

# 知识

  • Java 特点(看不懂没事,别背!)
  • 环境搭建
  • IDEA 开发工具
    • 新建项目
    • 运行调试
    • 界面配置
    • 插件管理
  • Java 基础语法
    • 数据类型
    • 流程控制
  • 数组
  • 面向对象
    • 方法
    • 重载
    • 封装
    • 继承
    • 多态
  • 抽象类
  • 接口
  • 枚举
  • 常用类
    • String
    • 日期时间
  • 集合类
  • 泛型
  • 注解
  • 异常处理
  • 多线程
  • IO 流
  • 反射

# 学习建议

1)坚持:初学一门语言时,一定要持续学习,不能中断!

2)实践:想要学好编程,一定要多敲代码!建议先跟着书上的例子敲一遍代码,然后试着自主编写代码,并完成课后练习。

3)万事开头难:不理解代码也没关系,可以学习 Debug 后,一行一行地打断点执行,查看程序的执行过程。千万不要觉得麻烦,养成习惯后真的能节省很多重复学习的时间。

# 经典面试题

  1. 为什么重写 equals 还要重写 hashcode?
  2. == 和 equals 比较的区别
  3. 为啥有时会出现 4.0 - 3.6 = 0.40000001 这种现象?
  4. final 关键字的作用
  5. 介绍 Java 的集合类
  6. ArrayList 和 LinkedList 的区别

# 资源

# 🌖 Java 8(3 天)

# 知识

  • Stream API
  • Lambda 表达式
  • 新日期时间 API
  • 接口默认方法

# 学习建议

Java 8 是如今企业开发中最主流的 Java 稳定版本,在这个版本出现了很多实用的新特性,虽然面试考点不多,但能够提升编程效率,建议学习。

此外,很多同学不怎么在简历上写自己会 Java 8,因此如果你把 Java 8 的知识点写在简历上,会大大加分的。

# 经典面试题

  1. Java 8 有哪些新特性?
  2. HashMap 在 jdk 1.7 和 1.8 的区别?

# 资源

# 练手项目

# 尾声

学完了 Java 基础后,有些同学会感到迷茫了啊,感觉好像啥也做不出来,不知道下一步做什么,我这一身的本领该如何施展啊?

不要慌,也不要急着去学新技术,接下来我们要多用 Java 来写代码了,巩固基础,但是写什么呢?

当然是数据结构和算法!

# 阶段 2:巩固基础

注意!如果你时间不够(比如只有 6 个月左右),只是想快速找到工作,那么本章节甚至可以完全跳过,先去学习开发框架做项目,后面再慢慢弥补基础即可。

# 目标

想学好编程,计算机基础知识要学好。

比如算法,是程序员的灵魂。学好算法有助于我们理解程序、开拓思路,因此也是很多公司面试时考察的关键,在找工作前,还是要刷个上百道算法题目的。

我们这个阶段的目标是:熟练使用 Java 语言来编写程序,巩固 Java 基础。(那直接用 Java 来写算法题目,一举两得,岂不美哉?)

此外,建议大家利用零碎时间多去了解 计算机基础知识 ,比如操作系统、计算机网络等,对你后面学习开发框架之类的知识都有帮助。

# Java 基础(30 天)

# 学习建议

建议大家去阅读 《Java 核心技术卷 1》,这本书堪称经典,是帮助你复习巩固  Java 的不二之选,其中图形界面章节可以选择不看。

之后可以刷网上免费的 Java 练习题,检验自己的水平,我当时刷了两遍 1000 题(每天 30 题,1 个月也就刷完了,二刷会更快!)。虽然都是选择题,但能学到很多 Java 语言的特性、避免写代码时容易犯的错误。

# 资源

# 🌖 数据结构与算法

请参考学习路线:数据结构和算法学习路线 (opens new window)

# 🌘 计算机导论

详情请参考:计算机基础学习路线 (opens new window)

# 知识

  • 计算机发展历史
  • 计算机应用领域
  • 计算机发展方向
  • 计算机基本组成
  • 二进制
  • 编程语言发展

# 学习建议

大学计算机专业的同学一般刚开学就会上这门课,虽说学习它并不会直接提高你的编程技能,但能够让你更了解计算机和编程,从而在一定程度上帮助你培养学习兴趣、确定学习方向。

自学的话,不用刻意去学习计算机导论,而是可以通过看视频、阅读课外读物的方式慢慢地了解计算机的故事。

# 资源

# 🌖 操作系统

详情请参考学习路线:操作系统学习路线 (opens new window)

# 知识

  • 操作系统的组成
  • 进程、线程
  • 进程 / 线程间通讯方式
  • 进程调度算法
  • 进程 / 线程同步方式
  • 进程 / 线程状态
  • 死锁
  • 内存管理
  • 局部性原理

# 学习建议

说实话,操作系统这一块知识挺枯燥的。你说说我现在项目都不会做,你又让我看这些理论,是不是想让我头秃?

我的建议是,可以先利用课余时间看一些网课或者有趣的课外书,对一些操作系统的概念先有个大致的印象,比如进程、线程、死锁,等后面有时间了再系统学习、等到找工作了再去背相关八股文。

还在校园就跟着学校的进度学习就成,自学的话可以看下《清华操作系统原理》视频,有实力的小伙伴,能看懂大黑书就更好了,但如果看不懂也别担心,这并不影响你后续知识的学习。

# 经典面试题

  1. 什么是死锁?死锁产生的条件?
  2. 线程有哪几种状态?
  3. 有哪些进程调度算法?
  4. 什么是缓冲区溢出?

# 资源

# 🌖 计算机网络

详情请参考学习路线:计算机网络学习路线 (opens new window)

# 知识

  • 网络分层模型
  • 网络传输过程
  • IP、端口
  • HTTP / HTTPS 协议
  • UDP / TCP 协议
  • ARP 地址解析协议
  • 网络安全
  • DNS 域名解析

# 学习建议

很多学习 Java 开发的同学最后都是从事 后端开发 的工作,而计算机网络知识是后端开发的重点。

和操作系统一样,自学网络可能会很枯燥,建议先看有趣的课外书,比如《图解 HTTP》;或者有趣的视频,比如《计算机网络微课堂》。后面要找工作面试前,再重点去背一些八股文就好了。还在学校的同学好好上课一般就没问题。

学习基础能帮助自己今后发展更稳定,且更容易接受新知识,所以请不要相信基础无用论。

# 经典面试题

  1. 计算机网络各层有哪些协议?
  2. TCP 和 UDP 协议的区别?
  3. TCP 为什么需要三次握手和四次挥手?
  4. HTTP 和 HTTPS 协议的区别?

# 资源

# 尾声

巩固基础要花至少 1 个月的时间,当你读完《Java 核心技术卷1》并且不用查询文档也能熟练地用 Java 做题时,就可以接着往下了。

# 阶段 3:企业开发基础

# 目标

面向薪资编程,学习实际后台开发工作要用的基础技术和框架,并能 独立 做出一个具有完整功能的 Java Web 项目。

学完这个阶段后,你应该已经能独立开发出大多数常见的后台系统了,比如各种管理系统、商城系统等。

# 🌕 MySQL 数据库(7 天)

详情请参考学习路线:数据库学习路线 (opens new window)

企业中大部分业务数据都是用关系型数据库存储的,因此数据库是后台开发同学的必备技能,其中 MySQL 数据库是目前的主流,也是面试时的重点。

# 知识

  • 基本概念
  • MySQL 搭建
  • SQL 语句编写
  • 约束
  • 索引
  • 事务
  • 锁机制
  • 设计数据库表
  • 性能优化

# 学习建议

其中,SQL 语句编写设计数据库表 这两个能力一定要有!

比如让你做一个学生管理系统,你要能想到需要哪些表,比如学生表、班级表;每个表需要哪些字段、字段类型。

这就要求大家多写 SQL、多根据实际的业务场景去练习设计能力。

# 经典面试题

  1. MySQL 索引的最左原则
  2. InnoDB 和 MyIsam 引擎的区别?
  3. 有哪些优化数据库性能的方法?
  4. 如何定位慢查询?
  5. MySQL 支持行锁还是表锁?分别有哪些优缺点?

# 资源

# 🌕 开发框架(60 天)

Java 之所以能成为主流的企业开发语言,很大一部分原因是它完善的框架生态,用好框架,不仅能够大大提升开发效率,还能提高项目的稳定性、减少维护成本。

开发框架是后台开发工作中不可或缺的,也是面试考察的重点,一定要好好学!

不知道 Java 能做什么的朋友们,学完开发框架,就会有答案啦。

下面给大家推荐的都是企业中应用最多的主流开发框架,知识点比较零碎,就放在一起讲了。

# 知识

# 🌕 Java Web
  • 描述:Java 网页应用开发基础
  • 一丢丢前端基础
  • XML
  • JSON
  • Servlet
  • Filter
  • Listener
  • JSP
  • JSTL
  • Cookie
  • Session
# 🌕 Spring 5
  • 描述:Java 轻量级应用框架
  • IOC
  • AOP
  • 事务
# 🌕 SpringMVC
  • 描述:Java 轻量级 web 开发框架
  • 什么是 MVC?
  • 请求与响应
  • Restful API
  • 拦截器
  • 配置
  • 执行过程
# 🌕 MyBatis
  • 描述:数据访问框架,操作数据库进行增删改查等操作
  • 增删改查
  • 全局配置
  • 动态 SQL
  • 缓存
  • 和其他框架的整合
  • 逆向工程
# 🌗 MyBatis Plus
  • 描述:Mybatis 的增强工具,能够简化开发、提高效率
  • 引入
  • 通用 CRUD
  • 条件构造器
  • 代码生成器
  • 插件扩展
  • 自定义全局操作
# 🌕 SpringBoot 2
  • 描述:简化 Spring 应用的初始搭建以及开发过程,提高效率
  • 常用注解
  • 资源整合
  • 高级特性
  • 本地热部署
# 🌗 Spring Security
  • 描述:Spring 的安全管理框架
  • 用户认证
  • 权限管理
  • 相关技术:Shiro
# 🌗 Maven / Gradle
  • 描述:项目管理工具
  • 构建
  • 依赖管理
  • 插件
  • 配置
  • 子父工程
  • 多模块打包构建
  • Nexus 私服搭建

# 学习建议

由于技术较多,且框架之间存在一定的联系,因此建议大家看同一系列的视频教程(尚硅谷、狂神说等等都可以),以保证学习内容的连续以及体验上的一致。

学这些技术的时候,千万不能懒 !一定要多记笔记,并且跟着老师写代码。原理部分不要太过纠结,先以能跟着敲出代码、写出可运行的项目为主,有些东西做出来也能帮助你更好地理解理论。

学习顺序挺重要的,建议按我推荐的顺序学,不要一上手就学 Spring Boot。只有先学习下自己整合框架的方法,才能帮你理解 SpringBoot 解决的问题,感受到它的方便和高效。

Maven / Gradle 当成工具用就好,面试基本不问,跟着框架教程去用就行了,急着找工作的话,先不用花太多时间去深入学。大厂面试问这个的也不多。

# 经典面试题

  1. Spring 的 IOC 和 AOP 是什么,有哪些优点?
  2. Spring 框架用到了哪些设计模式?
  3. 介绍 Spring Bean 的生命周期
  4. MyBatis 如何实现延迟加载?
  5. 介绍 MyBatis 的多级缓存机制

# 资源

已下资源分为两大类,希望快速做出项目、快速就业的同学请看【速成视频】。

学习完框架后,即可跟着鱼皮的原创项目教程系列边学边做项目。用项目驱动学习,更快地掌握后端必学技术,并直接写在简历上:项目实战 - 鱼皮原创项目教程系列 (opens new window)

# 🌘 开发规范(3 天)

开发不规范,同事两行泪。

开发规范是团队开发中必须遵守的,有利于提高项目的开发效率、降低维护成本。

# 知识

  • 代码规范
    • 代码风格
    • 命名
    • 其他规则
  • 代码校验(CheckStyle)
  • 提交规范

# 学习建议

有时间的话,简单过一遍大厂团队的代码规范手册就好了,以后做项目的时候能想起来的话就去使用,或者从书中、网上查规范文档,再去遵守。

项目做得多了,自然会养成好的习惯,不用刻意去记(毕竟每个团队规范也不完全相同,背了也没用)。也可以直接利用开发工具自带的一些代码检查插件,帮忙养成好的编码习惯。

# 资源

# 🌕 Git(3 天)

详情请参考学习路线:Git & GitHub 学习路线 (opens new window)

此前大家可能听说过 GitHub,一流的代码开源托管平台。

Git 和它可不一样,是一个版本控制工具,可以更好地管理和共享项目代码,比如把自己的代码传到 GitHub 上、或者从远程下载。

无论自己做项目、还是团队开发,Git 都是现在不可或缺的神器。

# 知识

  • 区分 Git 和 GitHub
  • 工作区
  • 分支
  • 代码提交、推送、拉取、回退、重置
  • 分支操作
  • 代码合并、解决冲突
  • 标签
  • cherry-pick
  • Git Flow
  • 相关技术:SVN(比较老)

# 学习建议

每个命令跟着敲一遍,有个大致的印象,会用即可。

建议平时大家可以多把自己的代码使用 Git 命令上传到 GitHub 上,用的多了自然就熟悉了。

# 经典面试题

  1. 如何解决提交冲突?
  2. 提交不小心出现误操作,如何撤销?
  3. 什么是 Git Flow,它有什么好处?

# 资源

# 🌖 Linux(10 天)

详情请参考学习路线:Linux 学习路线 (opens new window)

企业中的很多前后台项目都是部署在 Linux 服务器上的,因此很有必要熟悉 Linux 的操作和脚本的编写。

后面学微服务、学架构都是在多台服务器操作,如果你不熟悉 Linux,会有点吃力。

# 知识

  • Linux 系统安装
  • 环境变量
  • 文件管理
  • 用户管理
  • 内存管理
  • 磁盘管理
  • 进程管理
  • 网络管理
  • 软件包管理
  • 服务管理
  • 日志管理
  • Linux 内核
  • 常用命令
  • 常用环境搭建
  • Shell 脚本编程
  • VIM 的使用

# 学习建议

多动手实践,建议自己购买一台云服务器,并且在本地搭建 Linux 虚拟机环境。

一定要自己从 0 开始手敲命令安装软件、部署服务,熟悉整个项目的上线流程。

每个命令至少要跟着敲一遍,了解它们的作用,并通过自然地练习,熟悉常用的 Linux 命令。

记不住没关系,用文档查就行了。

先会用,再理解。一般面试问的 Linux 题目也不会很难,面试前去背一下八股文就没什么问题,感兴趣的话可以去看看 Linux 内核设计。

# 经典面试题

  1. 如何查看某个进程的运行状态?
  2. 如何在 Linux 上查看 2 G 的大文件?
  3. Linux 软链接和硬链接的区别

# 资源

# 🌘 前端基础(14 天)

详情请参考鱼皮原创的前端学习路线:https://mp.weixin.qq.com/s/HbzLEt6NOP9Is9F3GOnbUQ (opens new window)

虽然 Java 程序员面试时基本不会出现前端相关问题,但是在企业中,往往需要前后端程序员配合完成工作。会一些前端,不仅可以提高你们的协作效率,还能提高自己对整个项目的了解和掌控力,甚至能独立开发出一个完整项目!这点也是能给面试加分的。

# 知识

  • HTML
  • CSS
  • JavaScript
    • Ajax
  • Vue

# 学习建议

不需要学习太多的前端技术,熟悉下基础的前端三件套,了解前端是如何向后端发送请求来做数据交互的一般就够了。有时间的话可以学下 Vue ,是比较容易上手的主流前端开发框架,Vue + SpringBoot 还是很香的。

# 练手项目

推荐跟着鱼皮的原创项目教程系列边学边做项目,每个项目都是前端 + 后端的全栈项目。用项目驱动学习,更快掌握前端基础和后端必学技术,并直接写在简历上:项目实战 - 鱼皮原创项目教程系列 (opens new window)

# 尾声

学完这个阶段的知识后,一定要再串起来回忆一遍,必须自己独立开发一个 Java Web 项目(量级可以不大,但你学过的技术尽可能地用上),能发布到 Linux 服务器上让其他小伙伴访问就更好了~

如果你只是对 Java 感兴趣、或者只是想试着自己开发后台,并不是想靠 Java 找工作的话,学到这里就可以了。可以把更多时间投入到你主方向的学习中。

但如果你是想找 Java 方向的工作,尤其是想进大厂的话,一定要继续努力,用心学习下个阶段的企业开发进阶知识。

# 阶段 4:企业开发进阶

# 目标

学习更多企业级开发技术和编程思想,能够结合多种技术,独立开发出架构合理的完整系统,解决实际问题

要了解为什么需要这个技术?什么时候用这个技术?某个需求该用哪些技术?

当然,这个阶段的内容有些过于丰富,不是所有的东西都要学,大家可以根据自己的实际情况(时间),有选择地学习。

# 🌘 软件工程

详情请参考学习路线:软件工程学习路线 (opens new window)

软件开发和管理的一些概念、原则、技术、方法、工具和经验。

# 知识

  • 软件的本质
  • 软件特性
  • 软件过程
  • 软件开发原则
    • 开闭原则
    • 里氏替换原则
    • 依赖倒置原则
    • 单一职责原则
    • 接口隔离原则
    • 迪米特法则
  • 软件过程模型
  • 敏捷开发
  • 软件开发模型
  • 需求建模
  • 软件设计
  • UML
  • 体系结构设计
  • 设计模式
  • 软件质量管理
  • 评审
  • 软件质量保证
  • 软件测试
    • 单元测试
    • 集成测试
    • 系统测试
    • 压力测试
    • 部署测试
  • 软件配置管理
  • 软件项目管理
  • 软件项目估算
  • 项目进度安排
  • 风险管理
  • 软件过程改进
    • 成熟度模型

# 学习建议

大学软件专业的必修课,偏理论,能学到很多企业软件开发的方法,也是对软件开发同学综合能力的提升,有时间的话可以了解下。但对想要快速找工作的同学来说,忽略即可,面试基本不会问。

# 资源

# 🌖 设计模式(21 天)

详情请参考学习路线:设计模式学习路线 (opens new window)

设计模式是软件开发中解决一类问题的通用方法。

使用设计模式能让你写出更优雅、可维护的代码,也正因如此,很多框架源码都用到了设计模式,你不学很难看懂。

此外,鱼皮改了几百份简历,基本上没有同学把设计模式写在项目经历中。因此学好设计模式并写在简历上是很加分的!

# 知识

  • 创建型模式:对象实例化的模式,创建型模式用于解耦对象的实例化过程
    • 单例模式
    • 工厂方法模式
    • 抽象工厂
    • 建造者模式
    • 原型模式
  • 结构型模式:把类或对象结合在一起形成一个更大的结构
    • 适配器模式
    • 组合模式
    • 装饰器模式
    • 代理模式
    • 享元模式
    • 外观模式
    • 桥接模式
  • 行为型模式:类和对象如何交互,及划分责任和算法
    • 迭代器模式
    • 模板方法模式
    • 策略模式
    • 命令模式
    • 状态模式
    • 责任链模式
    • 备忘录模式
    • 观察者模式
    • 访问者模式
    • 中介者模式
    • 解释器模式

# 学习建议

先理解概念,了解每个设计模式的特点和应用场景,再多加练习,运用到实际项目。

# 经典面试题

  1. 单例模式有哪些实现方式?有哪些优缺点?请手写其中一种
  2. 你用过哪些设计模式,为什么用它?

# 资源

# 🌕 Redis(14 天)

详情请参考学习路线:Redis 学习路线 (opens new window)

缓存是高并发系统不可或缺的技术,可以提高系统的性能和并发,而 Redis 是实现缓存的最主流技术,因此它是后台开发必学的知识点,也是面试重点。

# 知识

  • Redis 基础
  • 什么是缓存?
  • 本地缓存
    • Caffeine 库
  • 多级缓存
  • Redis 分布式缓存
    • 数据类型
    • 常用操作
    • Java 操作 Redis
      • Spring Boot Redis Template
      • Redisson
    • 主从模型搭建
    • 哨兵集群搭建
    • 日志持久化
  • 缓存(Redis)应用场景
    • 数据共享
    • 单点登录
    • 计数器
    • 限流
    • 点赞
    • 实时排行榜
    • 分布式锁
  • 缓存常见问题
    • 缓存雪崩
    • 缓存击穿
    • 缓存穿透
    • 缓存更新一致性
  • 相关技术:Memcached、Ehcache

# 学习建议

学会如何简单地使用缓存并不难,和数据库类似,无非就是调用 API 对数据进行增删改查。

因此,建议先能够独立使用它,了解缓存的应用场景;再学习如何在 Java 中操作缓存中间件,并尝试和项目相结合,提高系统的性能。

跟着视频教程实操一遍即可,可以等到面试前再去深入了解原理和高级特性。

# 经典面试题

  1. Redis 为什么快?
  2. Redis 有哪些常用的数据结构?
  3. Redis RDB 和 AOF 持久化的区别,如何选择?
  4. 如何解决缓存击穿、缓存穿透、雪崩问题?
  5. 如何用 Redis 实现点赞功能,怎么设计 Key / Value?

# 资源

# 🌖 消息队列(14 天)

消息队列是用于传输和保存消息的容器,也是大型分布式系统中常用的技术,主要解决应用耦合、异步消息、流量削锋等问题。后台开发必学,也是面试重点。

# 知识

  • 消息队列的作用
  • RabbitMQ 消息队列
    • 生产消费模型
    • 交换机模型
    • 死信队列
    • 延迟队列
    • 消息持久化
    • Java 操作
    • 集群搭建
  • 相关技术:Kafka、ActiveMQ、TubeMQ、RocketMQ

# 学习建议

和缓存一样,学会如何使用消息队列并不难,无非就是调用 API 去生产、转发和消费消息。

因此,建议先能够独立使用它,了解消息队列的应用场景;再学习如何在 Java 中操作消息队列中间件,并尝试和项目相结合,感受消息队列带来的好处。

这里我建议初学者先学习 RabbitMQ,比 Kafka 要好理解一些。跟着视频教程实操一遍即可,可以等到面试前再去深入了解原理和高级特性。

# 经典面试题

  1. 使用消息队列有哪些优缺点?
  2. 如何保证消息消费的幂等性?
  3. 消息队列有哪些路由模型?
  4. 你是否用过消息队列,解决过什么问题?

# 资源

# 🌖 Nginx(14 天)

Nginx 是主流的、开源的、高性能的 HTTP 和反向代理 web 服务器,可以用于挂载网站、请求转发、负载均衡、网关路由等。前后端开发同学都需要学习,在后端开发的面试中有时会考到。

# 知识

  • Nginx 作用
  • 正向代理
  • 反向代理(负载均衡)
  • 常用命令
  • 配置
  • 动静分离(网站部署)
  • 集群搭建
  • 相关技术:HAProxy、Apache

# 学习建议

Nginx 的基本使用非常简单,甚至不需要看任何的视频,跟着一篇文章就能够用它来提供网站访问能力、实现反向代理。

但是在企业中,Nginx 的使用往往没那么简单,作为负载均衡、请求转发的重要组件,往往需要针对实际场景去写一些特定的配置。因此建议有时间的话,实践下 Nginx 的配置方法,了解 Nginx 基本的设计思想,对今后自己设计系统时也有帮助。

# 经典面试题

  1. Nginx 有哪些作用?
  2. Nginx 为什么支持高并发?
  3. Nginx 有哪些负载均衡策略?
  4. 什么是 Nginx 惊群问题,如何解决它?

# 资源

# 🌗 Netty 网络编程(21 天)

开源的 Java 网络编程框架,用于开发高性能(事件驱动、异步非阻塞)、高可靠的网络服务器和客户端程序。

很多网络框架和服务器程序都用到了 Netty 作为底层,学好 Netty 不仅可以让我们自己实现高性能服务器,也能更好地理解其他的框架应用、阅读源码。

# 知识

# 学习建议

不同于之前学的 SSM 框架,Netty 还是需要一定学习成本的,一方面是国内资源太缺乏,另一方面很多重要的概念(比如 NIO)还是要多动手写代码调试才能理解。

还是建议先从视频入门,并且不建议在 Netty 上花太多时间,面试的时候一般也就考察一些 Netty 背后的思想(比如 NIO)而非框架本身的语法细节。

# 经典面试题

  1. Netty 有哪些优点?
  2. 什么是 NIO?
  3. 介绍 Netty 的零拷贝机制

# 资源

# 🌖 微服务(60 天)

随着互联网的发展,项目越来越复杂,单机且庞大的巨石项目已无法满足开发、运维、并发、可靠性等需求。

因此,后台架构不断演进,可以将庞大的项目拆分成一个个职责明确、功能独立的细小模块,模块可以部署在多台服务器上,相互配合协作,提供完整的系统能力。

换言之,想做大型项目,这块儿一定要好好学!

# 知识

# Dubbo
  • 架构演进
  • RPC
  • Zookeeper
  • 服务提供者
  • 服务消费者
  • 项目搭建
  • 相关技术:DubboX(对 Dubbo 的扩展)
# 🌖 微服务
  • 微服务概念
  • Spring Cloud 框架
    • 子父工程
    • 服务注册与发现
    • 注册中心 Eureka、Zookeeper、Consul
    • Ribbon 负载均衡
    • Feign 服务调用
    • Hystrix 服务限流、降级、熔断
    • Resilience4j 服务容错
    • Gateway(Zuul)微服务网关
    • Config 分布式配置中心
    • 分布式服务总线
    • Sleuth + Zipkin 分布式链路追踪
  • Spring Cloud Alibaba
    • Nacos 注册、配置中心
    • OpenFeign 服务调用
    • Sentinel 流控
    • Seata 分布式事务
# 接口管理
  • Swagger 接口文档
  • Postman 接口测试
  • 相关技术:YApi、ShowDoc

# 学习建议

时间不急的话,建议先从 Dubbo 学起,对分布式、RPC、微服务有些基本的了解,再去食用 Spring Cloud 全家桶会更香。学完 Spring Cloud 全家桶后,再去学 Spring Cloud Alibaba 就很简单了。

这部分内容的学习,原理 + 实践都很重要,也不要被各种高大上的词汇唬住了,都是上层(应用层)的东西,基本没有什么算法,跟着视频教程学,其实还是很好理解的。

分布式相关知识非常多,但这里不用刻意去背,先通过视频教程实战使用一些微服务框架,也能对其中的概念有基本的了解。

大厂面试的时候很少问 Spring Cloud 框架的细节,更多的是微服务以及各组件的一些思想,比如网关的好处、消息总线的好处等。

# 经典面试题

  1. 什么是微服务,有哪些优缺点?
  2. 什么是注册中心,能解决什么问题?

# 资源

# 🌖 容器(7 天)

将应用和环境进行封装,相互隔离、独立部署、便于移植,提高安全性、提高开发和维护效率。

便于实现微服务、持续集成和交付。

# 知识

  • 🌖 Docker
    • 容器概念
    • 镜像
    • 部署服务
    • Dockerfile
    • Docker Compose
    • Docker Machine
    • Docker Swarm
    • 多阶段构建
  • 🌘 K8S(Kubernetes)
    • K8S 架构
    • 工作负载
      • 资源类型
      • Pod
      • Pod 生命周期
      • Pod 安全策略
    • K8S 组件
    • K8S 对象
    • 部署应用
    • 服务
      • Ingress
    • Kubectl 命令行
    • 集群管理
  • 相关技术:Apache Mesos、Mesosphere

# 学习建议

业务上云是趋势,但是对于开发同学来说,会用 Docker / K8S 部署项目和服务就行。实际工作中,企业一般都有现成的平台直接用,面试考察的也不多,不用花太多时间。

# 经典面试题

  1. 什么是容器?
  2. 使用  Docker 有哪些好处?
  3. 如何快速启动多个 Docker 节点?

# 资源

# 🌗 CI / CD(3 天)

持续集成 / 持续交付,贯穿整个研发到项目上线的过程,提高效率。

大公司一般都有自己的 CI / CD 平台。

# 知识

  • 什么是 CI / CD
  • CI / CD 有什么好处
  • 使用任一 CI / CD 平台
  • 相关技术:Jenkins、GitLab、微信云托管

# 学习建议

了解它是什么,并且实战使用任一 CI / CD 平台,感受它和传统开发运维到底有什么不同,就足够了。其实很简单,不要花太多时间。

真正要自己去搭建的时候,跟着官方文档来就行。

# 资源

# 练手项目

学习完框架后,即可跟着鱼皮的原创项目教程系列边学边做项目。用项目驱动学习,更快地掌握后端必学技术,并直接写在简历上:项目实战 - 鱼皮原创项目教程系列 (opens new window)

# 尾声

看到这里,相信你已经感叹:编程语言一辈子学不完了!

但是,不用担心,通过对这么多知识点的学习,相信你已经有了一定的积累,也不知不觉地锻炼了自主学习能力、资源检索能力、代码阅读能力、问题解决能力,之后的学习会越来越轻松。

接下来,可以试着用你学到的技术来解决实际的问题,自主从 0 开始做一些项目,保持编程手感。

# 阶段 5:项目实战

# 目标

综合所学技术从 0 到 1 开发和上线一个全面、有特色的、可以写进简历的个人项目。

# 学习建议

其实在之前的框架学习视频中应该就做过几个项目了,但相对不够完整和体系化。

有想法的同学可以做任何自己想做的项目,推荐参加一些作品类竞赛,练手、拿奖、收获项目经历一举三得。

暂时没想法的朋友,建议先跟着专门带做项目的视频教程做 1 - 2 套 Java 完整项目,一定要从 0 到 1 自己手写!

有能力的朋友也可以试着用 GitHub 上的源码来学习啦~

做一个完整的项目的确很不容易,建议大家根据自己的 时间、兴趣 选择 较新的有配套源码的 教程,保持耐心。

如何选择编程学习资源,可以看下我的原创文章:https://mp.weixin.qq.com/s/mlMql9RJCd7THt6rpGb8UA (opens new window)

下面推荐一些优质的、较新的项目实战视频教程 + 50 套项目源码。

# 视频教程

编程导航知识星球 (opens new window) 内部分享:

  1. ⭐️ 鱼皮全程直播带做的保姆级全栈项目,带现成的简历写法和面试题:项目实战 - 鱼皮原创项目教程系列 (opens new window)
  2. 项目训练营(寻爱网项目) (opens new window):学习从立项到上线的完整做项目流程 + 优化思路
  3. 从 0 到 1 开发用户中心 (opens new window):保姆级前后端完整项目教程,适合刚学完框架的新手
  4. 伙伴匹配系统 (opens new window):移动端网站,设计分布式和并发编程知识,适合已经做过一个小项目的同学练习
  5. Web 终端项目经验分享 (opens new window):前后端技术选型 + 系统设计 + 源码解读 + 简历亮点全面分享
  6. 面试刷题网站项目经验分享 (opens new window):从 0 到 1 分享数万用户网站的创作过程和经验分享
  7. 瑞吉外卖 - 外卖点餐系统 (opens new window):Java Spring Boot 入门级项目,适合刚学完框架的同学
  8. 尚医通 - 在线预约挂号平台 (opens new window):业务功能完整的 Java Spring Cloud 微服务项目,适合刚学完微服务的同学
  9. 硅谷课堂 - 在线学习平台 (opens new window):业务功能完整的 Java Spring Cloud 微服务项目,适合想学习第三方服务对接的同学
  10. 黑马点评 - 类似大众点评的移动 APP (opens new window):专门为学习 Redis 定制的单体项目,适合刚学完 Spring Boot、想系统学习 Redis 的同学

公开:

# 常用类库

# 工具
  • Guava:谷歌开发的 Java 工具库(https://github.com/google/guava)
  • Apache Commons:各类工具库,比如 commons-lang、commons-io、commons-collections 等(https://github.com/apache/commons-lang)
  • Hutool:Java 工具集库(https://github.com/looly/hutool)
  • Lombok:Java 增强库(https://github.com/projectlombok/lombok)
  • Apache HttpComponents Client:HTTP 客户端库(https://github.com/apache/httpcomponents-client)
  • OkHttp:适用于 JVM、Android 等平台的 Http 客户端(https://github.com/square/okhttp)
  • Gson:谷歌的 JSON 处理库(https://github.com/google/gson)
  • Jcommander:Java 命令行参数解析框架(https://github.com/cbeust/jcommander)
  • Apache PDFBox:PDF 操作库(https://github.com/apache/pdfbox)
  • EasyExcel:阿里的 Excel 处理库(https://github.com/alibaba/easyexcel)
  • Apache POI:表格文件处理库(https://github.com/apache/poi)
# 测试
  • JUnit:Java 测试框架(https://github.com/junit-team/junit4)
  • Mockito:Java 单元测试 Mock 框架(https://github.com/mockito/mockito)
  • Selenium:浏览器自动化框架(https://github.com/SeleniumHQ/selenium)
  • htmlunit:Java 模拟浏览器(https://github.com/HtmlUnit/htmlunit)
  • TestNG:Java 测试框架(https://github.com/cbeust/testng)
  • Jacoco:Java 代码覆盖度库(https://github.com/jacoco/jacoco)
# 其他
  • cglib:字节码生成库(https://github.com/cglib/cglib)
  • Arthas:Java 诊断工具(https://github.com/alibaba/arthas)
  • config:针对 JVM 的配置库(https://github.com/lightbend/config)
  • Quasar:Java 纤程库(https://github.com/puniverse/quasar)
  • drools:Java 规则引擎(https://github.com/kiegroup/drools)
  • Caffeine:Java 高性能缓存库(https://github.com/ben-manes/caffeine)
  • Disruptor:高性能线程间消息传递库(https://github.com/LMAX-Exchange/disruptor)
  • Knife4j:Swagger 文档增强(https://doc.xiaominfo.com/)
  • Thumbnailator:Java 缩略图生成库(https://github.com/coobird/thumbnailator)
  • Logback:Java 日志库(https://github.com/qos-ch/logback)
  • Apache Camel:消息传输集成框架(https://github.com/apache/camel)
  • Quartz:定时任务调度库(https://github.com/quartz-scheduler/quartz)
  • Apache Mahout:机器学习库(https://github.com/apache/mahout)
  • Apache OpenNLP:NLP 工具库(https://github.com/apache/opennlp)
  • RxJava:JVM 反应式编程框架(https://github.com/ReactiveX/RxJava)
  • JProfiler:性能分析库(https://www.ej-technologies.com/products/jprofiler/overview.html)
  • jsoup:HTML 文档解析库(https://jsoup.org/)
  • webmagic:Java 爬虫框架(https://github.com/code4craft/webmagic/)

# IDEA 插件

综合实用性、易用性、流行度、维护频率,精选了以下插件,简单分类为天地二品。

# 精选地品插件

简单好用、增强功能

# 精选天品插件

提高开发效率和代码质量

# 美化类

# 代码生成类

# 功能提效类

# 源码阅读
# 代码规范
# 格式处理
# 代码统计
# 代码检索
# 其他

# 扩展增强类

# 常用软件

# 开发相关
  • JetBrains IDEA:Java 集成开发环境,凭学生邮箱可申请免费使用(https://www.jetbrains.com/idea/)
  • Reset Jetbrains:你懂的
  • Visual Studio Code:插件化代码编辑器(https://code.visualstudio.com/)
  • Sublime Text:轻量代码编辑器(https://www.sublimetext.com/)
  • Navicat:数据库管理软件(https://www.navicat.com.cn/)
  • JMeter:Java 性能测试工具(https://jmeter.apache.org/)
  • JVisual VM:Java 运行状态可视化工具(https://visualvm.github.io/)
  • XShell:SSH 连接软件(https://www.netsarang.com/zh/xshell/)
  • XFtp:FTP 连接软件(https://www.netsarang.com/zh/xftp/)
  • Redis Desktop Manager:Redis 可视化管理工具(https://github.com/uglide/RedisDesktopManager)
  • Postman:接口测试工具(https://www.postman.com/)
  • VMware:虚拟机软件(https://www.vmware.com/)
  • Chocolatey:Windows 软件包管理器(https://chocolatey.org/)
  • Typora:写文档软件(https://typora.io/)
# 效率
  • Ditto:强大的剪切板(https://ditto-cp.sourceforge.io/)
  • uTools:插件化的效率工具(https://u.tools/)
  • XMind:思维导图软件(https://www.xmind.cn/)
  • Qdir:Windows 多窗口管理器(https://q-dir.en.softonic.com/)

# 项目源码(50 套)

# 鱼皮原创项目

# 电商秒杀

# 博客论坛

  • Mblog (opens new window):开源 Java 博客系统
  • halo (opens new window):一个优秀的开源博客发布应用
  • forum-java (opens new window):一款用 Java(spring boot) 实现的现代化社区(论坛/问答/BBS/社交网络/博客)系统平台
  • vhr (opens new window):微人事是一个前后端分离的人力资源管理系统,项目采用 SpringBoot+Vue 开发。
  • favorites-web (opens new window):云收藏 Spring Boot 2.X 开源项目。云收藏是一个使用 Spring Boot 构建的开源网站,可以让用户在线随时随地收藏的一个网站,在网站上分类整理收藏的网站或者文章。
  • community (opens new window):码问,开源论坛、问答系统,现有功能提问、回复、通知、最新、最热、消除零回复功能。技术栈 Spring、Spring Boot、MyBatis、MySQL/H2、Bootstrap
  • NiterForum (opens new window):尼特社区-NiterForum-一个论坛/社区程序。后端Springboot/MyBatis/Maven/MySQL,前端Thymeleaf/Layui。可供初学者,学习、交流使用。
  • VBlog (opens new window):V部落,Vue+SpringBoot实现的多用户博客管理平台!
  • NiceFish (opens new window):SpringBoot/SpringCloud 前后端分离项目
  • My-Blog (opens new window): My Blog 是由 SpringBoot + Mybatis + Thymeleaf 等技术实现的 Java 博客系统,页面美观、功能齐全、部署简单及完善的代码,一定会给使用者无与伦比的体验。
  • My-Blog-layui (opens new window):layui 版本的 My-Blog : A simple & beautiful blogging system implemented with spring-boot & layui & thymeleaf & mybatis My Blog 是由  SpringBoot + Layui + Mybatis + Thymeleaf 等技术实现的 Java  博客系统,页面美观、功能齐全、部署简单及完善的代码,一定会给使用者无与伦比的体验
  • symphony (opens new window):Java 实现的现代化社区

# 管理系统

  • Spring-Cloud-Admin (opens new window):Cloud-Admin 是国内首个基于 Spring Cloud 微服务化开发平台,具有统一授权、认证后台管理系统,其中包含具备用户管理、资源权限管理、网关 API 管理等多个模块,支持多业务系统并行开发,可以作为后端服务的开发脚手架。代码简洁,架构清晰,适合学习和直接项目中使用。核心技术采用 Spring Boot2 以及 Spring Cloud Gateway 相关核心组件,前端采用 vue-element-admin 组件。
  • bootshiro (opens new window):基于 springboot+shiro+jwt 的资源无状态认证权限管理系统后端
  • 悟空CRM (opens new window):基于jfinal+vue+ElementUI的前后端分离CRM系统
  • EL-ADMIN (opens new window):基于 SpringBoot 的后台管理系统
  • pig (opens new window):基于 Spring Boot 2.2、 Spring Cloud Hoxton & Alibaba、 OAuth2 的 RBAC 权限管理系统。
  • FEBS-Shiro (opens new window):Spring Boot 2.1.3,Shiro1.4.0 & Layui 2.5.4 权限管理系统。
  • Spring Boot-Shiro-Vue (opens new window):基于Spring Boot-Shiro-Vue 的权限管理
  • studentmanager (opens new window):基于springboot+mybatis学生管理系统
  • jshERP (opens new window):华夏ERP基于SpringBoot框架和SaaS模式,立志为中小企业提供开源好用的ERP软件,目前专注进销存+财务功能。主要模块有零售管理、采购管理、销售管理、仓库管理、财务管理、报表查询、系统管理等。支持预付款、收入支出、仓库调拨、组装拆卸、订单等特色功能。拥有库存状况、出入库统计等报表。同时对角色和权限进行了细致全面控制,精确到每个按钮和菜单。
  • HotelSystem (opens new window):酒店管理系统 Java,tomcat,mysql,servlet,jsp实现,没有使用任何框架

# 开发平台

  • open-capacity-platform (opens new window):微服务能力开发平台
  • jeecg-boot (opens new window):JeecgBoot是一款基于BPM的低代码平台!前后端分离架构 SpringBoot 2.x,SpringCloud,Ant  Design&Vue,Mybatis-plus,Shiro,JWT,支持微服务。强大的代码生成器让前后端代码一键生成,实现低代码开发!

# 其他

# 阶段 6:Java 高级

# 目标

不满足于能做,而是通过更 深入广泛 的学习,实现高质量的代码和更优秀的架构,培养解决问题的能力。

已经到了这个阶段,建议除了看完成的教程外,平时多自主搜索信息去学习,积少成多。比如遇到了一个不了解的名词,可以去网上搜一下,感兴趣的话再进行下一步的学习。

# 🌖 并发编程(21 天)

对 Java 后端开发程序员来说,懂得如何利用有限的系统资源来提高系统的性能是很重要的,也是大厂面试考察的重点,因此并发编程(尤其是 Java 并发包的使用)这块的知识很重要。

把它放到高级,是因为在学并发编程前,需要有一定的编程经验、了解一定的操作系统知识。

# 知识

  • 线程和进程
  • 线程状态
  • 并行和并发
  • 同步和异步
  • Synchronized
  • Volatile 关键字
  • Lock 锁
  • 死锁
  • 可重入锁
  • 线程安全
  • 线程池
  • JUC 的使用
  • AQS
  • Fork Join
  • CAS

# 学习建议

并发编程入门不难,依然是 先学会使用 基础的 Java 并发包, 再通过大量地实践和测试,了解一些原理,才能真正掌握何时使用、如何更合理地使用并发编程。而不是张口闭口多线程,上天入地高并发。

# 经典面试题

  1. volatile 关键字的作用
  2. 使用线程池有哪些好处?
  3. 线程池参数如何设置?
  4. 什么是线程安全问题,如何解决?
  5. 介绍 synchronized 的锁升级机制
  6. CopyOnWriteArrayList 适用于哪种场景?

# 资源

# 🌖 JVM(30 天)

想要深入理解 Java,探秘 Java 跨平台的奥秘,一定要了解 Java 底层的虚拟机技术。

了解虚拟机、掌握虚拟机性能调优方法,有助于你写出更高性能、资源占用更小的优质程序。

在学习 JVM 的过程中,也能学到很多精妙的设计,开拓思路。

# 知识

  • JVM 内存结构
  • JVM 生命周期
  • 主流虚拟机
  • Java 代码执行流程
  • 类加载
    • 类加载器
    • 类加载过程
    • 双亲委派机制
  • 垃圾回收
    • 垃圾回收器
    • 垃圾回收策略
    • 垃圾回收算法
    • StopTheWorld
  • 字节码
  • 内存分配和回收
  • JVM 性能调优
    • 性能分析方法
    • 常用工具
    • 参数设置
  • Java 探针
  • 线上故障分析

# 学习建议

JVM 的知识略显枯燥,建议先看视频,有实操的地方一定要实操!自己多去分析。

第一遍不理解没有关系,可以再看书来巩固,想要真正学好,《深入理解 Java 虚拟机(第三版)》一定要读。

如果只是为了通过面试可以直接看更精简的视频,比如狂神的。

# 经典面试题

  1. 介绍 JVM 的内存模型?
  2. JVM 内存为什么要分代?
  3. 介绍一次完整的 GC 流程
  4. 介绍双亲委派模型,为什么需要它?

# 资源

# 🌖 Java 高级知识

通过阅读文章了解即可

# 知识

# 架构设计

# 🌖 分布式

# 🌗 高可用

  • 限流
  • 降级熔断
  • 冷备
  • 双机热备
  • 同城双活
  • 异地双活
  • 异地多活
  • 容灾备份

# 🌗 高并发

  • 数据库
    • 分库分表
      • MyCat 中间件
      • Apache ShardingSphere 中间件
    • 读写分离
  • 缓存
    • 缓存雪崩
    • 缓存击穿
    • 缓存穿透
  • 负载均衡
    • 负载均衡算法
    • 软硬件负载均衡(2、3、4、7 层)

# 🌘 服务网格

服务网格用来描述组成应用程序的微服务网络以及它们之间的交互。服务网格的规模和复杂性不断的增长,它将会变得越来越难以理解和管理,常见的需求包括服务发现、负载均衡、故障恢复、度量和监控等。

# 知识
  • Istio
    • 流量管理
    • 安全性
    • 可观测性
  • Envoy(开源的边缘和服务代理)
# 资源

# 🌘 DDD 领域驱动设计

将数据、业务流程抽象成容易理解的领域模型,通过用代码实现领域模型,来组成完整的业务系统。

# 知识
  • DDD 的优势
  • DDD 的适用场景
  • DDD 核心概念
    • 领域模型分类:失血、贫血、充血、涨血
    • 子域划分:核心域、通用域、支撑域
    • 限界上下文
    • 实体和值对象
    • 聚合设计
    • 领域事件
  • DDD 实践
# 资源

# 🌘 其他

  • Sidecar
  • Serverless
  • 云原生

# 学习建议

架构设计的学习没有顶点,多看文章,思考每种设计的优缺点和适用场景,有机会的话在企业中实践即可。

还在学校、或者初入这行的同学切记,千万不要一味地去背诵架构设计的八股文。你可以背,但是这一块的知识只有结合具体的项目才有意义,所以要多做项目去实践设计的合理性,而不是什么设计都咔咔往系统里去怼。比如面试问到分布式事务,能结合自己项目中用分布式事务解决问题的经验去回答最好。

# 🌘 其他技术

  • 热数据探测技术:京东 HotKey
  • 数据库流水订阅:阿里 Canal
  • 监控告警
  • 应用安全
  • 故障演练
  • 流量回放

# 阶段 7:Java 求职

# 目标

找到好工作

# 建议

  1. 尽早做规划,可以通过大厂招聘官网的岗位描述来了解岗位的要求
  2. 雕琢一份优秀的简历,推荐阅读:https://mp.weixin.qq.com/s/wfabzdpOPdq89faFFpZ4NA (opens new window)
  3. 多读面经,坚持刷算法
  4. 多参与面试,持续复盘总结

# 资源

# 校招岗位

# 社招岗位

# 实习

# 鱼皮经历

# 知识总结

# 面经

编程导航面经汇总:https://yuyuanweb.feishu.cn/wiki/PLHrwcEPCiJcxXk7Ki4csRoJn2f (opens new window)

# 面试题解

编程导航精选面试题汇总:https://yuyuanweb.feishu.cn/wiki/CmFywXs0Oi0MS9kU3yocJugFn2e (opens new window)

# 视频

# 阶段 8:持续学习

# 目标

持续追求技术的深度和广度,培养自己的 核心竞争力不可替代性 ,学无止境!

# 学习建议

自主学习,自主搜索教程,多看书,多阅读技术博客,多实践。

# 学习方向

# 框架源码

  • Spring
  • SpringBoot
  • SpringMVC
  • MyBatis
  • Netty
  • Dubbo
  • SpringCloud

# 计算机原理

# 数据库 / 中间件 / 分布式

  • 数据库
    • MySQL
    • PostgreSQL
  • 缓存
    • Redis
  • 队列
    • Apache Kafka
    • Apache Pulsar
  • 搜索引擎
    • Elastic Stack
      • Elasticsearch
      • logstash
      • kibana
      • beats
  • 容器
    • Docker
    • K8S

# 解决方案

  • 广告系统
  • 电商系统
  • 搜索系统
  • 支付转账
  • 游戏后台
  • 即时通讯
  • 社交系统
  • CMS 系统
  • ERP 系统
  • OA 系统
  • 代码生成
  • 权限管理
  • 秒杀活动

# 架构设计

同阶段 6 架构设计部分

# 大数据

  • 5V 特点
  • Hadoop
  • HDFS
  • MapReduce
  • Spark
  • Flink
  • Storm
  • Hive
  • HBase
  • Druid
  • Kylin
  • Pig
  • Mahout

# 前沿技术

# 自学 Java 专题资源

Java 学习路线 by 程序员鱼皮

编程导航   |