日志、堆栈、JVM调优全面讲解,助力轻松应对各种Bug
项目异常不断,找不到问题所在?百度、Google搜个遍,也找不到答案?本课程针对Java开发中常见的各种异常,从日志、堆栈再深入到JVM,带你发现问题、定位问题、解决问题,最后在实战中搭建开箱即用的SpringBoot脚手架,强化巩固所学,助力你提升开发技能!
〖课程目录〗:
- 第1章 课程介绍 4 节 | 13分钟
- 本章主要对学习本门课程做具体说明。
-
- 图文:1-1 为何要学习本门课
- 视频:1-2 课程介绍 (12:12)
- 图文:1-3 课程内容与课程目标
- 图文:1-4 如何更好地使用慕课网平台
- 第2章 什么是Java异常 10 节 | 78分钟
- 本章主要讲解 Java 语言中的异常以及异常类层次结构,并对其中的常见异常、核心异常类进行详细讲解,让大家掌握Java是怎么定义异常。
-
- 图文:2-1 【本章预习】梳理Java异常类
- 视频:2-2 核心异常类 (05:12)
- 图文:2-3 【巩固总结】Java核心异常类
- 视频:2-4 要掌握的异常类中的重要方法 (09:38)
- 图文:2-5 【巩固总结】要掌握的异常类中的重要方法
- 视频:2-6 正确理解 Java 虚拟机堆栈 (11:20)
- 视频:2-7 如何打印完整的异常堆栈信息 (20:50)
- 视频:2-8 Java 对异常处理的两种方式 (24:38)
- 视频:2-9 回顾 Java 异常体系 (05:30)
- 图文:2-10 【本章回顾与总结】 Java 异常体系
- 第3章 Java 异常处理的基本原则10 节 | 76分钟
- 本章讲解处理异常的方法和处理异常时要遵循的一些原则。
-
- 图文:3-1 【本章预习】明确异常处理的基本原则
- 视频:3-2 只有在必要的时候才使用异常 (15:22)
- 视频:3-3 自定义异常和标准异常到底应该怎么选 (08:43)
- 图文:3-4 【巩固总结】自定义异常和标准异常到底应该怎么选
- 视频:3-5 异常可以被忽略,但是要做到有理有据 (12:46)
- 视频:3-6 尽最大的努力保证异常不影响系统的状态 (23:33)
- 视频:3-7 回顾下我们该怎么处理异常 (06:45)
- 图文:3-8 【巩固总结】我们该怎么处理异常
- 视频:3-9 里程碑:关于异常的一切 (08:31)
- 图文:3-10 【本章回顾与总结】关于异常的一切
- 第4章 深入理解 Java 日志框架体系 12 节 | 96分钟
- 本章对slf4j 和 commons-logging(JCL)两类日志框架进行详细讲解,并讲解什么是日志门面模式,以及为什么需要门面模式等。
-
- 图文:4-1 【本章预习】Java 日志框架的历史
- 视频:4-2 SLF4J 和 JCL 是怎么绑定日志实现的(上) (12:47)
- 视频:4-3 SLF4J 和 JCL 是怎么绑定日志实现的(下) (10:58)
- 视频:4-4 Log4j2 基础:学会使用它(搞懂配置并应用) (14:24)
- 图文:4-5 【巩固总结】Log4j2 基础:学会使用它(搞懂配置并应用)
- 视频:4-6 Log4j2 进阶:它是怎样工作的 (12:52)
- 视频:4-7 Logback 基础:学会使用它(搞懂配置并应用) (10:03)
- 视频:4-8 Logback 进阶:它是怎样工作的 (20:09)
- 图文:4-9 Logback 基础:学会使用它
- 视频:4-10 通过 Lombok 注解使用日志框架 (10:13)
- 视频:4-11 回顾下 Java 日志体系 (04:03)
- 图文:4-12 【本章回顾与总结】回顾下 Java 日志体系
- 第5章 优良的日志记录需要遵循一定的规范13 节 | 105分钟
- 本章以实例的形式讲解每一种日志级别对应的选择策略、日志内容的合理性及分布式下的日志逻辑等。
-
- 图文:5-1 选择合适的日志打印级别
- 视频:5-2 选择合适的日志打印级别 (12:28)
- 视频:5-3 对日志合理性、正确性、必要性的分析 (09:32)
- 图文:5-4 【巩固总结】对日志合理性、正确性、必要性的分析
- 视频:5-5 需要规避的日志打印过程 (14:55)
- 视频:5-6 日志要能够对业务逻辑进行解释 (20:17)
- 视频:5-7 Logback 的 MDC 解析 (13:56)
- 图文:5-8 Logback 的 MDC 源码解析
- 视频:5-9 微服务下的分布式调用链追踪日志 (24:11)
- 视频:5-10 如何更好的使用日志 (04:11)
- 图文:5-11 【巩固总结】如何更好的使用日志
- 视频:5-12 里程碑:学会打日志 (04:49)
- 图文:5-13 【巩固总结】学会打日志
- 第6章 彻底掌握 Intellij IDEA 的代码调试8 节 | 80分钟
- 本章将用实例演示,怎样使用 IDEA 去 debug 代码,其中涉及基本用法、变量查看、计算表达式、断点调试等。
-
- 图文:6-1 认识 IDEA 的 Debug 模式
- 视频:6-2 什么样的问题适用于代码调试 (11:22)
- 视频:6-3 使用断点追踪代码执行过程 (21:56)
- 视频:6-4 通过 Debug 跟踪、计算、修改变量的值 (19:43)
- 视频:6-5 远程 Debug SpringBoot 工程 (09:00)
- 图文:6-6 远程 Debug SpringBoot 工程
- 视频:6-7 代码调试要注意的点 (08:05)
- 视频:6-8 里程碑:学会解决显性问题 (09:02)
- 第7章 学会分析 Java 线程堆栈9 节 | 108分钟
- 本章主要讲解什么是线程堆栈、线程堆栈包含了哪些信息、怎样阅读线程堆栈以及堆栈信息能够用来解决什么问题。
-
- 视频:7-1 什么是线程堆栈,它又能解决什么问题 (14:31)
- 图文:7-2 使用 jstack 命令获取线程堆栈日志
- 视频:7-3 堆栈中的线程状态分析 (15:30)
- 图文:7-4 【巩固总结】堆栈中的线程状态分析
- 视频:7-5 通过线程堆栈日志定位并解决死锁问题 (22:43)
- 视频:7-6 通过线程堆栈日志定位资源不足问题 (24:21)
- 视频:7-7 通过线程堆栈日志排查系统中存在大量 WAITING 线程的原因 (22:57)
- 视频:7-8 回顾 Java 线程堆栈 (07:02)
- 图文:7-9 【本章总结】回顾 Java 线程堆栈
- 第8章 理解并学会 JVM 性能调优14 节 | 155分钟
- 本章讲解什么是 JVM 调优,为什么要进行 JVM 调优,以及调优之后程序会有怎样的性能提升等。
-
- 视频:8-1 什么是 JVM 调优,为什么需要做调优 (10:21)
- 图文:8-2 Java 内存模型及其对应的虚拟机参数
- 视频:8-3 需要知道的 GC 算法和常用的垃圾收集器 (10:21)
- 视频:8-4 学会使用 JDK 工具(1):用于查看 JVM 配置参数的 jinfo (17:44)
- 视频:8-5 学会使用 JDK 工具(2):用于查看 JVM 堆内存使用的 jmap (18:03)
- 视频:8-6 学会使用 JDK 工具(3):用于查看 JVM 统计信息的 jstat (18:37)
- 视频:8-7 获取并分析 Java GC 日志 (15:36)
- 视频:8-8 JVM 性能调优实战:频繁的 Minor GC 和 Major GC (21:00)
- 图文:8-9 获取并分析 Java GC 日志
- 视频:8-10 JVM 性能调优实战:频繁的 Full GC (24:25)
- 视频:8-11 回顾 JVM 调优 (09:07)
- 图文:8-12 回顾 JVM 调优
- 视频:8-13 里程碑:理解隐性问题 (08:58)
- 图文:8-14 里程碑:理解隐性问题
- 第9章 一次 SpringBoot 工程编写与调试过程11 节 | 150分钟
- 本章将会使用一个 SpringBoot 工程(毕竟是 java 工程最广泛使用的框架)来串起来这门课程中所涉及到的知识点。
-
- 视频:9-1 设计 SpringBoot 工程所承载的功能与 JVM 的环境配置 (17:06)
- 图文:9-2 设计 SpringBoot 工程所承载的功能与 JVM 环境配置
- 视频:9-3 工程启动失败,为什么没有任何异常日志 (09:13)
- 图文:9-4 基于 logback 配置优雅的工程日志
- 视频:9-5 认识并自定义启动异常分析接口 FailureAnalyzer (16:37)
- 视频:9-6 Tomcat 与 JVM 配置调优 (11:05)
- 视频:9-7 AOP 切面统一打印请求日志 (22:44)
- 视频:9-8 优雅的全局统一异常处理 (26:52)
- 视频:9-9 通过线程堆栈分析 CPU 过高问题 (20:07)
- 视频:9-10 GC 调优案例分析(上) (13:23)
- 视频:9-11 GC 调优案例分析(下) (12:32)
- 第10章 课程总结1 节 | 10分钟
- 本章对本门课程进行回顾与总结。
-
- 视频:10-1 课程总结 (09:04)
〖视频截图〗:
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。