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加速

本文转载自: 掘金

开发者博客 – 和开发相关的 这里全都有

0%