Java后端知识体系

基础重点(必须扎实)

Java语言

  • 语言基础 《Java核心技术》

    • 基础语法
    • 面向对象
    • 常用API
    • 异常处理
    • 集合
    • IO
    • 多线程
    • 网络编程
    • 泛型
    • 反射
    • 注解
  • JVM 《深入理解Java虚拟机》

    • 类加载机制

      • 双亲委托
    • 字节码执行机制

    • JVM内存模型

      • 堆区
      • 虚拟机栈
      • 方法区
    • GC垃圾回收

    • JVM性能监控与故障定位

    • JVM调优

  • 多线程、锁、并发 1:《Java并发编程的艺术》、2:《Java并发编程实战》

    • 并发编程基础

    • 线程池

      • 乐观锁、悲观锁
      • 互斥锁、共享锁
      • 可重入锁、偏向锁
      • 轻量级锁、CAS与自旋锁
    • 并发容器

    • 原子类

    • JUC并发工具类

  • 网络编程

    • 学习路径

      • Socket API + 多线程 + 网络模型/IO模型 + IO复用
      • Netty
    • 核心点

      • 进程间通信方式:信号量、管道、共享内存、socket 等
      • 多线程编程:互斥锁、条件变量、读写锁、线程池等
      • 五大 IO 模型:同步、异步、阻塞、非阻塞、信号驱动
      • 高性能 IO 两种模式:Reactor 和 Proactor
      • IO 复用机制:epoll、select、poll(破解 C10K 问题的利器)
  • Java源码

数据库/SQL

  • 《SQL必知必会》、《高性能MySQL》

  • SQL语句

    • 手写SQL

      • 联表
      • 聚合
  • SQL语句优化

  • 事务、隔离级别

  • 索引

数据结构与算法

  • 《漫画算法》、《算法》

  • 数据结构

    • 字符串
    • 数组
    • 链表
    • 队列
    • 二叉树
    • 哈希
  • 算法

    • 十大排序
    • 查找、二分
    • 贪心
    • 分治
    • 动态规划
    • 回溯

设计模式

  • 《重学Java设计模式》
  • 单例
  • 工厂
  • 代理
  • 策略
  • 模板方法
  • 观察者
  • 适配器
  • 责任链
  • 建造者
  • 。。。。

计算机网络

  • 《计算机网络:自顶向下方法》

  • HTTP、TCP、IP、ICMP、UDP、DNS、ARP

  • IP地址、MAC地址、OSI七层模型(或者 TCP/IP 五层模型)

  • HTTPS安全相关的:数字签名、数字证书、TLS

  • 常见网络攻击:局域网ARP泛洪、DDoS、TCP SYN Flood、XSS等

  • TCP协议(最重要)

    • TCP协议

      • 三次握手、四次挥手
      • 状态转换
      • TCP状态中TIME_WAIT
      • 拥塞控制
      • 快速重传、慢启动
    • 问题

      • TCP 如何实现可靠传输的(画外音:如何基于 UDP 实现可靠传输)
      • TCP 连接建立为什么不是两次握手(画外音:三次握手的充分必要性说明)
      • TIME_WAIT 的存在解决了什么问题,等待时间为什么是 2 MSL
    • 核心

      • 可靠传输 + 高效传输(流量控制和窗口管理)
  • HTTP、HTTPS

    • 从 URL 输入到页面展现到底发生什么
  • 学习方法

    • 学习抓住一条主线

      • 一个数据包是如何发送出去的
    • 带着问题去思考为什么这么做

操作系统

  • 《现代操作系统》

  • 进程管理

  • 并发、同步互斥、锁

  • 内存管理

  • 文件系统

  • 重点

    • OS四大模块的理论知识

      • 进程与线程管理
      • 内存管理
      • IO与文件系统
      • 设备管理
    • 了解Linux内核部分实现原理

      • 内存管理
      • 进程管理
      • 虚拟文件系统
    • 与编程最密切

      • 内存
      • 进程
      • IO
  • 认知

    • 操作系统由哪些构成
    • 进程的状态、切换、调度
    • 进程间通信方式(共享内存、管道、消息)
    • 进程和线程的区别
    • 线程的实现方式(一对一、多对一等)
    • 互斥与同步(信号量、管程、锁)
    • 死锁检测与避免
    • 并发经典的问题:读者写者、哲学家就餐问题
    • 为什么需要虚拟内存,MMU 具体如何做地址转换的
    • 内存为什么分段、分页
    • 页面置换算法
    • 文件系统是如何组织的
    • 虚拟文件系统(VFS)是如何抽象的
    • 。。。。

应用框架

后端

  • JSP、Servlet

  • Spring家族

    • Spring

      • IOC
      • AOP
    • Spring MVC

    • MyBatis

    • SSM

      • 打war包
      • Tomcat运行
    • Spring Boot

      • 打jar包

        • 内嵌Tomcat

          • 微服务架构
      • 知识点

        • 自动配置、开箱即用

        • 整合Web

        • 整合数据库(事务问题)

        • 整合权限

          • Shiro
          • SpringSecurity
        • 各种中间件

          • 缓存

          • MQ

          • RPC框架

            • Dubbo
          • NIO框架

            • Netty
    • Spring Cloud

      • Netflix

        • Eureka

          • 服务治理组件,包括服务端的注册中心和客户端的服务发现机制。
        • Ribbon

          • 负载均衡的服务调用组件,具有多种负载均衡调用策略。
        • Hystrix

          • 服务容错组件,实现了断路器模式,为依赖服务的出错和延迟提供了容错能力。
        • Feign

          • 基于Ribbon和Hystrix的声明式服务调用组件。
        • Zuul

          • API 网关服务,过滤、安全、监控、限流、路由。
      • Alibaba

        • Nacos

          • 阿里巴巴开源产品,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
        • Sentinel

          • 面向分布式服务架构的轻量级流量控制产品,把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
        • RocketMQ

          • 一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。
        • Dubbo

          • Apache Dubbo 是一款高性能 Java RPC 框架,用于实现服务通信。
        • Seata

          • 阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。
      • Config

        • 分布式配置中心。配置管理工具,支持使用 Git 存储配置内容,支持应用配置的外部化存储,支持客户端配置信息刷新、加解密配置内容等。
      • Bus

        • 事件、消息总线,用于在集群(例如,配置变化事件)中传播状态变化,可与 Spring Cloud Config 联合实现热部署。
      • Consul

        • 服务注册和配置管理中心。
      • Security

        • 安全工具包,对Zuul代理中的负载均衡OAuth2客户端及登录认证进行支持。
      • Sleuth

        • SpringCloud应用程序的分布式请求链路跟踪,支持使用Zipkin、HTrace和基于日志(例如ELK)的跟踪。
      • Stream

        • 轻量级事件驱动微服务框架,可以使用简单的声明式模型来发送及接收消息,主要实现为Apache Kafka及RabbitMQ。
      • Task

        • 用于快速构建短暂、有限数据处理任务的微服务框架,用于向应用中添加功能性和非功能性的特性。
      • Zookeeper

        • 服务注册中心。
      • Gateway(可替代 Zuul)

        • Spring Cloud Gateway 是 Spring 官方基于 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等技术开发的网关,Spring Cloud Gateway 旨在为微服务架构提供一种简单而有效的统一的 API 路由管理方式。Spring Cloud Gateway 作为 Spring Cloud 生态系中的网关,目标是替代 Netflix Zuul,其不仅提供统一的路由方式,并且基于 Filter 链的方式提供了网关基本的功能,例如:安全,监控/埋点,和限流等。
      • OpenFeign(可替代 Feign)

        • OpenFeign 是 Spring Cloud 在 Feign 的基础上支持了 Spring MVC 的注解,如 @RequesMapping等等。OpenFeign 的 @FeignClient 可以解析 SpringMVC 的 @RequestMapping 注解下的接口,并通过动态代理的方式产生实现类,实现类中做负载均衡并调用其他服务。
    • 项目经验

      • 总结
  • 中间件

    • 缓存

      • Redis

        • 5大数据类型
        • 事务
        • 消息通知
        • 管道
        • 持久化
        • 集群
    • 消息

      • RabbitMQ
      • RocketMQ
      • Kafka
    • 搜索

      • ElasticSearch

前端

  • 基础套餐

    • 三大件

      • HTML
      • CSS
      • JavaScript
    • 基础库

      • jQuery
      • Ajax
  • 模板框架

    • JSP
    • Thymeleaf
    • FreeMaker
  • 组件化框架

    • Node
    • VUE
    • React
    • Angular

开发工具

集成开发环境

  • Eclipse
  • IDEA
  • VSCode

Linux系统

  • Linux常用命令
  • 基本Shell脚本

代码管理工具

  • Git

    • Git命令和使用
  • SVN

项目管理/构建工具

  • Maven
  • Gradle

应用运维

Web服务器

  • Nginx

应用服务器

  • Tomcat

容器技术

  • Docker
  • Kubernetes(K8S)
    • 管理运维容器

持续集成、持续发布

  • Jenkins

代码质量检测

  • Sonar

日志收集、分析

  • ELK

CDN加速

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容