全网最硬核 JDK 解析 - 7. JFR 事件采集原理与演进2025年12月1日·62525 字·125 分钟全面解析 JFR(Java Flight Recorder)的配置体系、使用方式和事件采集机制。涵盖 JFR 配置体系(全局配置、记录级别配置、JFC 配置文件)、多种使用方式(JVM 参数、jcmd 命令、JDK API、JMX)、jfr 工具分析、事件类型分类与配置适用性,以及从 JDK 11 到 JDK 25 的核心变化和最佳实践。
为什么应该避免在生产环境中启用 HeapDumpOnOutOfMemoryError2025年5月1日·1536 字·4 分钟全面指南,探讨为什么启用 HeapDumpOnOutOfMemoryError 会在生产环境中导致严重的性能问题,哪些 OutOfMemoryError 类型实际触发堆转储,以及使用 JFR 进行内存泄漏检测和自动服务重启策略等更好的替代方案。
PostgreSQL vs MySQL:为你的 OLTP 工作负载找到合适的选择2024年5月1日·1529 字·4 分钟PostgreSQL 和 MySQL 在 OLTP 场景下的全面比较,探讨它们在二级索引处理和 MVCC 实现方面的根本架构差异,以及何时选择每个数据库的实用见解。
GraalVM Native Image 进程能否被 jps 检测到?以及我们的生产策略2024年4月19日·666 字·2 分钟了解 GraalVM Native Image 进程何时会在 jps 中显示,并学习我们在生产环境中在 GraalVM Native Image 和 JVM 之间选择的经过实战验证的方法。我们详细介绍了针对 Lambda 风格任务与长期运行的微服务的策略。
最大化第三方 API 请求吞吐量:实用测试方法2024年4月18日·1408 字·3 分钟学习如何使用 WebClient、TestContainers 和 toxicproxy 开发和测试高性能 API 客户端。本综合指南涵盖异步请求处理、隔离测试环境和真实故障模拟,用于构建健壮的微服务。
解决神秘的 JVM Safepoint 问题:从问题到解决方案的探索之旅2022年6月19日·2347 字·5 分钟深入探讨诊断和解决生产 JVM 问题,其中应用在每小时日志同步任务期间会冻结。我们探索 safepoint 分析、JVM 日志输出阻塞、异步日志实现和 WebFlux 优化以实现完整解决方案。
解决 JVM Safepoint 延迟:从 EFS 集成到异步日志的探索之旅2022年6月16日·2317 字·5 分钟深入调查升级到 Java 17 并实施 AWS EFS 集中式日志收集后出现的神秘 JVM safepoint 延迟问题。我们发现日志输出期间的文件 I/O 阻塞如何冻结整个 JVM 进程,并通过异步日志和正确的 WebFlux 实现解决了这个问题。
解决分片 MySQL 表的性能下降:理解根本原因和解决方案2022年5月27日·3316 字·7 分钟全面指南,了解为什么 MySQL 查询在分片环境中随时间变慢,探讨存储碎片和 MVCC 相关问题的根本原因,并提供使用 OPTIMIZE TABLE 表重建技术维护最佳数据库性能的实用解决方案。
隐藏的性能杀手:为什么日志中的代码位置会摧毁你的微服务性能2022年3月2日·1855 字·4 分钟了解在日志中启用代码位置如何导致微服务中的严重 CPU 性能问题,特别是响应式应用。这个深入分析揭示了 Log4j2 中堆栈遍历的隐藏成本,并为高吞吐量系统提供了可行的解决方案。
MySQL 优化器统计:为什么你的查询选择了错误的索引2022年2月24日·3158 字·7 分钟深入探讨 MySQL 的 InnoDB 优化器统计以及采样不准确如何导致索引选择不当,造成相似查询之间的显著性能差异。学习防止由优化器误判导致的慢 SQL 查询的实用解决方案。
配置 Spring Data Redis 与 Lettuce 以实现有效的 Pipeline 操作2022年1月5日·1994 字·4 分钟关于如何正确配置 Spring Data Redis 与 Lettuce 以启用 pipeline 功能的综合指南。了解连接共享、AutoFlushCommands 和 PipeliningFlushPolicy 配置,以优化你的 Redis 批量操作并减少网络往返时间。
Spring Data Redis 连接泄漏之谜:当你的微服务失控时2021年10月14日·3499 字·7 分钟生产事件调查,揭示 Spring Data Redis + Lettuce 在混合使用 SessionCallback 和 executeWithStickyConnection 操作时如何泄漏连接。深入探讨连接管理机制、JFR 分析技术和实用解决方案,防止你的 Redis 连接池成为黑洞。
网关雪崩危机:同步 Redis 调用如何几乎摧毁我们的系统2021年9月1日·2602 字·6 分钟深入探讨生产事件,其中我们的 Spring Cloud Gateway 由于阻塞的 Redis 操作而经历了级联故障。了解响应式环境中的同步 API 调用如何导致线程饥饿,导致健康检查失败和系统范围的雪崩,以及使用异步模式的完整解决方案。
通过 SQL 优化发现的隐藏生产问题2021年8月7日·1800 字·4 分钟当我们的运维团队带来一个执行时间极长的复杂 SQL 查询时,我们以为这只是一个性能问题。我们不知道,这次调查会发现一个深深隐藏的字符编码不匹配问题,它一直在我们的生产数据库中默默地导致全表扫描。
使用 JFR 排查 SSL 性能瓶颈2021年3月27日·868 字·2 分钟深入分析微服务性能问题,包括 CPU 峰值和数据库连接异常。通过 JFR 分析,我们发现根本原因是 Java SecureRandom 在 /dev/random 上阻塞,并提供使用 /dev/urandom 的解决方案。
全网最硬核 JDK 分析 - 1. TLAB 全面解析2021年2月3日·21531 字·43 分钟深入探讨 JVM 的线程本地分配缓冲区(TLAB)机制,涵盖设计原理、实现细节、性能优化和源代码分析。了解 TLAB 如何提高多线程环境中的内存分配效率,并掌握 TLAB 调优技术。
OpenJDK 11 JVM 日志:新统一配置完整指南2020年2月6日·2259 字·5 分钟了解 OpenJDK 11 如何通过其统一配置系统彻底改变 JVM 日志记录。学习用于 GC 分析、类加载和运行时编译的基本日志标签,以及使用 jcmd 进行实时性能调优的动态日志配置。