阶段6:Java高级


目标

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

并发编程(21 天)

对 Java 后端开发程序员来说,懂得如何利用有限的系统资源来提高系统的性能是很重要的,也是大厂面试考察的重点,因此并发编程(尤其是 Java 并发包的使用)这块的知识很重要。 把它放到高级,是因为在学并发编程前,需要有一定的编程经验、了解一定的操作系统知识。

知识

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

学习建议

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

资源

JVM(30 天)

想要深入理解 Java,探秘 Java 跨平台的奥秘,一定要了解 Java 底层的虚拟机技术。 了解虚拟机、掌握虚拟机性能调优方法,有助于你写出更高性能、资源占用更小的优质程序。 在学习 JVM 的过程中,也能学到很多精妙的设计,开拓思路。

知识

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

学习建议

JVM 的知识略显枯燥,建议先看视频,有实操的地方一定要实操!自己多去分析。 第一遍不理解没有关系,可以再看书来巩固,想要真正学好,《深入理解 Java 虚拟机(第三版)》一定要读。 如果只是为了通过面试可以直接看更精简的视频,比如狂神的。

资源

架构

分布式

  • 分布式理论
    • CAP
    • BASE
  • 分布式缓存
    • Redis
    • Memcached
    • Etcd
  • 一致性算法
    • Raft
    • 一致性哈希
  • 分布式事务
  • 分布式 id 生成
  • 分布式服务调用
  • 分布式存储
  • 分布式数据库
  • 分布式文件系统
  • 分布式协调
    • Zookeeper
  • 分布式监控
    • Prometheus
  • 分布式消息队列
    • RabbitMQ
    • Kafka
    • rocketmq
  • 分布式日志收集
    • Elastic Stack
    • Loki
  • 分布式搜索引擎
    • Elasticsearch
  • 分布式链路追踪
    • Apache SkyWalking
  • 分布式配置中心
    • Apollo
    • Nacos

高可用

  • 主从
  • 异地多活
  • 容灾备份

高并发

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

其他

  • 监控告警
  • 领域驱动设计
  • 应用安全
  • 线上故障分析
  • 服务网格
  • Serverless
  • 云原生

评论
评论
  目录