昨晚,我在路口等车的时候,听到几个人在那讨论问题:
“之前我用 jprofiler 监控 jvm 里的对象,当老年代满了,我手动触发一次 fgc,发现只能回收一半,再触发一次,就完全回收,这种情况正常吗?”
“是不是你的应用正在执行过程中啊?”
“可以考虑下 finalize,弱引用缓存等。”
“那你们怎么确定 CPU 线程上下文切换消耗资源的?你们咋改进的?”
“一般我们的业务系统 CPU 切换消耗很低,你可以试下分批加法,算 100 亿个数字相加什么的,开 10 个,100 个,1000 个,10000 个线程。线程数量太大才会有影响,本质是资源争用,和锁资源有些类似。线程数量要测试,还是要看业务类型,高并发低 CPU 的 Redis 之类影响非常明显,Java 的主要领域是企业业务系统,如果你要实现 Redis,Mongo,MySQL 等基础服务,必须考虑 CPU 切换。”
......
车来了,我坐上车后看着窗外的冬夜叹了口气:这几天的北京可真冷啊,连天都黑的太快了。
是啊,冬天本来就冷,黑夜也会变得漫长,都是自然现象而已。
但是每个人的心里总会因为一些原因莫名的感到寒冷。比如我就是因为听到刚才那些人的聊天觉得心烦意乱。
因为我也是一名 Java 从业者,虽然近些年来,无论是使用规模、开发者人数,还是技术生态成熟度、相关工具的丰富程度,Java 都当之无愧是后端开发语言中不可撼动的王者,也是开发各类业务系统的首选语言。
而且薪资也不菲
但我总有种坐不动的感觉。项目还好说,让我用 Java 写系统代码都没有问题,但是如果有人问我 Java 程序运行起来以后内部发生了什么,可以怎么让它运行的更好的话,我就真的有点答不上来。
而且我发现,现在面试 Java 岗位,无论什么规模的公司,一般面试官面着面着就会问到 JVM 相关的问题,什么线程、内存模型、JVM 运行时内存、垃圾回收与算法、GC 垃圾收集器、JAVA IO/NIO 、JVM 类加载机制等等知识点。
如果答不好,甚至影响薪酬的多少。
所以了解 JVM 则是深入学习 Java 必不可少的一环,也是 Java 开发人员迈向更高水平的一个阶梯。
我们不仅要会用 Java 写代码做系统,更要懂得如何理解和分析 Java 程序运行起来以后内部发生了什么,然后可以怎么让它运行的更好。
就像我们要想多年开车的老司机,仅仅会开车肯定不能当一个好司机。车开多了,总会有一些多多少少大大小小的故障毛病。老司机需要知道什么现象说明有了什么毛病,需要怎么处理,不然就会导致经常抛锚,影响我们的行程。本专栏的目的就是教会我们怎么去了解 JVM 这辆优秀跑车的一些原理以及怎么去用各种工具分析修理它。
市面上各类 JVM 相关的资料虽多如牛毛,但是明显都很难让大家系统性地学明白,同时一线大厂技术面试现在 JVM 知识也是必考科目。
所以在这个背景下,两位在大厂摸爬滚打 10 多年的 Java 专家全面梳理了系统化学习 JVM 的知识和经验,包括 JVM 的技术和内存模型、JVM 参数和内置工具、GC 算法、GC 日志、内存和线程等相关问题排查分析,以及常见的面试问题深度剖析等高级的进阶方法与实战。既满足大家快速系统化学习和全面掌握知识的需求,又兼顾大家的面试经验辅导。
- 通过体系化的学习,了解一般原理,知其然知其所以然;
- 熟悉工具和方案,知道从何下手,工作中如何分析和解决问题;
- 随着课程的演示和练习,加深理解,不管大家之前的基础如何,都能够融会贯通;
- 面试题的解析部分,会根据大家的反馈进行持续更新,长期助力于大家的学习和进步
今天面了个25岁的Java,各方面都挺好,问啥都会,最后问了个JVM调优问题,没答上,走时几乎落泪...唉!
细想想...
- 1、当面试官向你提问JVM的实战问题时,你是否感觉到无所适从?
- 2、想解决生产环境中的GC问题,你是否感觉到狗咬刺猬,无处下嘴?
- 3、面对JVM的海量参数,你是否感觉到迷茫无助?
- 4、看过很多的JVM文章,但当遇到了生产环境中真实问题的时候,你是否依然不知道如何进行分析排查?
我感到很慌…
如果是这样,我觉得我们大家先想清楚“自己想要什么”最为重要
那么我的建议就是“实战”!
“实战”可以让我们快速消除痛点,解决面试,积累实战经验,横扫一切关于JVM的面试问题,吊打所有敢于提问JVM的面试官。简历填写JVM调优经历,为升职加薪添上浓墨重彩的一笔。
现在小编邀请你参加【马士兵老师】的「JVM实战调优」训练营,可以点击此处来获取就可以了!
马士兵老师
马士兵老师,清华大学,推动Java生根中国,推动大数据生根中国,推动AI生根中国,视频课程下载次数累计数27000万次。
马老师带你走进JVM实战调优的世界,帮助你在面对那些上亿用户,千万QPS,百万TPS,以及每天上PB级大数据量处理系统的时候,不再胆怯,不再心虚,开启涨薪升级之旅!
本次新增:深入hotspot源码拆解G1运行机制
第一天:Jvm垃圾回收快速入门
1、什么是垃圾?
2、如何定位垃圾?
3、常用垃圾回收算法
4、常用垃圾回收器
5、系统上线前预估系统的内存占用情况
6、系统上线前预估系统的并发访问情况
7、根据预估值设定JVM初始参数
8、压力测试方法论
9、根据压测结果调整参数值
10、系统上线后设定日志参数
11、定期观察日志情况
12、根据日志解决实战问题
第二天:生产环境中的垃圾回收方法理论与动手实战
13、为什么一个百万级TPS系统会频繁GC?
14、定位JVM问题的实用参数设置
15、用top命令观察系统运行情况
16、用jps定位虚拟机进程
17、用jstat定位JVM问题
18、用jmap导出内存转储文件
19、用jstack定位问题线程
20、用jhat分析转储文件
21、其他给力的工具visual VM,MAT,Arthas介绍
22、动手实战
23、集中答疑,解决同学们学习中的问题
24、面向未来,学习路线指引与职业规划
往期JVM录播视频:
如何获取?